anymap-ts 0.9.0 → 0.10.1
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/anymap_ts/static/deckgl.js +1 -1
- package/anymap_ts/static/leaflet.js +1 -1
- package/anymap_ts/static/mapbox.css +1 -1
- package/anymap_ts/static/mapbox.js +26608 -408
- package/anymap_ts/static/maplibre.js +1 -1
- package/anymap_ts/static/openlayers.js +7 -7
- package/package.json +1 -1
- package/src/core/BaseMapRenderer.ts +3 -24
- package/src/mapbox/MapboxRenderer.ts +2006 -80
- package/src/mapbox/index.ts +2 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
var wt={ADD:"add",REMOVE:"remove"};var Ee={PROPERTYCHANGE:"propertychange"};var L={CHANGE:"change",ERROR:"error",BLUR:"blur",CLEAR:"clear",CONTEXTMENU:"contextmenu",CLICK:"click",DBLCLICK:"dblclick",DRAGENTER:"dragenter",DRAGOVER:"dragover",DROP:"drop",FOCUS:"focus",KEYDOWN:"keydown",KEYPRESS:"keypress",LOAD:"load",RESIZE:"resize",TOUCHMOVE:"touchmove",WHEEL:"wheel"};var ta=class{constructor(){this.disposed=!1}dispose(){this.disposed||(this.disposed=!0,this.disposeInternal())}disposeInternal(){}},Ci=ta;function qc(n,t,e){let i,r;e=e||jt;let s=0,o=n.length,a=!1;for(;s<o;)i=s+(o-s>>1),r=+e(n[i],t),r<0?s=i+1:(o=i,a=!r);return a?s:~s}function jt(n,t){return n>t?1:n<t?-1:0}function $c(n,t){return n<t?1:n>t?-1:0}function Ri(n,t,e){if(n[0]<=t)return 0;let i=n.length;if(t<=n[i-1])return i-1;if(typeof e=="function"){for(let r=1;r<i;++r){let s=n[r];if(s===t)return r;if(s<t)return e(t,n[r-1],s)>0?r-1:r}return i-1}if(e>0){for(let r=1;r<i;++r)if(n[r]<t)return r-1;return i-1}if(e<0){for(let r=1;r<i;++r)if(n[r]<=t)return r;return i-1}for(let r=1;r<i;++r){if(n[r]==t)return r;if(n[r]<t)return n[r-1]-t<t-n[r]?r-1:r}return i-1}function Jc(n,t,e){for(;t<e;){let i=n[t];n[t]=n[e],n[e]=i,++t,--e}}function It(n,t){let e=Array.isArray(t)?t:[t],i=e.length;for(let r=0;r<i;r++)n[n.length]=e[r]}function Ot(n,t){let 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 Qc(n,t,e){let i=t||jt;return n.every(function(r,s){if(s===0)return!0;let o=i(n[s-1],r);return!(o>0||e&&o===0)})}function ei(){return!0}function ii(){return!1}function ni(){}function ms(n){let t,e,i;return function(){let r=Array.prototype.slice.call(arguments);return(!e||this!==i||!Ot(r,e))&&(i=this,e=r,t=n.apply(this,arguments)),t}}function ps(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 ze(n){for(let t in n)delete n[t]}function $t(n){let t;for(t in n)return!1;return!t}var ea=class{constructor(t){this.propagationStopped,this.defaultPrevented,this.type=t,this.target=null}preventDefault(){this.defaultPrevented=!0}stopPropagation(){this.propagationStopped=!0}};var mt=ea;var ia=class extends Ci{constructor(t){super(),this.eventTarget_=t,this.pendingRemovals_=null,this.dispatching_=null,this.listeners_=null}addEventListener(t,e){if(!t||!e)return;let i=this.listeners_||(this.listeners_={}),r=i[t]||(i[t]=[]);r.includes(e)||r.push(e)}dispatchEvent(t){let e=typeof t=="string",i=e?t:t.type,r=this.listeners_&&this.listeners_[i];if(!r)return;let s=e?new mt(t):t;s.target||(s.target=this.eventTarget_||this);let 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 c=0,h=r.length;c<h;++c)if("handleEvent"in r[c]?l=r[c].handleEvent(s):l=r[c].call(this,s),l===!1||s.propagationStopped){l=!1;break}if(--o[i]===0){let c=a[i];for(delete a[i];c--;)this.removeEventListener(i,ni);delete o[i]}return l}disposeInternal(){this.listeners_&&ze(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;let i=this.listeners_[t];if(!i)return;let r=i.indexOf(e);r!==-1&&(this.pendingRemovals_&&t in this.pendingRemovals_?(i[r]=ni,++this.pendingRemovals_[t]):(i.splice(r,1),i.length===0&&delete this.listeners_[t]))}},je=ia;function G(n,t,e,i,r){if(r){let o=e;e=function(a){return n.removeEventListener(t,e),o.call(i??this,a)}}else i&&i!==n&&(e=e.bind(i));let s={target:n,type:t,listener:e};return n.addEventListener(t,e),s}function _n(n,t,e,i){return G(n,t,e,i,!0)}function B(n){n&&n.target&&(n.target.removeEventListener(n.type,n.listener),ze(n))}var yn=class extends je{constructor(){super(),this.on=this.onInternal,this.once=this.onceInternal,this.un=this.unInternal,this.revision_=0}changed(){++this.revision_,this.dispatchEvent(L.CHANGE)}getRevision(){return this.revision_}onInternal(t,e){if(Array.isArray(t)){let i=t.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=G(this,t[s],e);return r}return G(this,t,e)}onceInternal(t,e){let i;if(Array.isArray(t)){let r=t.length;i=new Array(r);for(let s=0;s<r;++s)i[s]=_n(this,t[s],e)}else i=_n(this,t,e);return e.ol_key=i,i}unInternal(t,e){let i=e.ol_key;if(i)Ag(i);else if(Array.isArray(t))for(let r=0,s=t.length;r<s;++r)this.removeEventListener(t[r],e);else this.removeEventListener(t,e)}};yn.prototype.on;yn.prototype.once;yn.prototype.un;function Ag(n){if(Array.isArray(n))for(let t=0,e=n.length;t<e;++t)B(n[t]);else B(n)}var _s=yn;function F(){throw new Error("Unimplemented abstract method.")}var Pg=0;function U(n){return n.ol_uid||(n.ol_uid=String(++Pg))}var ys=class extends mt{constructor(t,e,i){super(t),this.key=e,this.oldValue=i}},na=class extends _s{constructor(t){super(),this.on,this.once,this.un,U(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 ys(i,t,e)),i=Ee.PROPERTYCHANGE,this.hasListener(i)&&this.dispatchEvent(new ys(i,t,e))}addChangeListener(t,e){this.addEventListener(`change:${t}`,e)}removeChangeListener(t,e){this.removeEventListener(`change:${t}`,e)}set(t,e,i){let r=this.values_||(this.values_={});if(i)r[t]=e;else{let s=r[t];r[t]=e,s!==e&&this.notify(t,s)}}setProperties(t,e){for(let 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_){let i=this.values_[t];delete this.values_[t],$t(this.values_)&&(this.values_=null),e||this.notify(t,i)}}},pt=na;var tu={LENGTH:"length"},xn=class extends mt{constructor(t,e,i){super(t),this.element=e,this.index=i}},ra=class extends pt{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,r=this.array_.length;i<r;++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){let e=this.array_;for(let i=0,r=e.length;i<r;++i)t(e[i],i,e)}getArray(){return this.array_}item(t){return this.array_[t]}getLength(){return this.get(tu.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 xn(wt.ADD,e,t))}pop(){return this.removeAt(this.getLength()-1)}push(t){let e=this.getLength();return this.insertAt(e,t),this.getLength()}remove(t){let e=this.array_;for(let i=0,r=e.length;i<r;++i)if(e[i]===t)return this.removeAt(i)}removeAt(t){if(t<0||t>=this.getLength())return;let e=this.array_[t];return this.array_.splice(t,1),this.updateLength_(),this.dispatchEvent(new xn(wt.REMOVE,e,t)),e}setAt(t,e){let 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);let r=this.array_[t];this.array_[t]=e,this.dispatchEvent(new xn(wt.REMOVE,r,t)),this.dispatchEvent(new xn(wt.ADD,e,t))}updateLength_(){this.set(tu.LENGTH,this.array_.length)}assertUnique_(t,e){let i=this.array_;for(let r=0,s=i.length;r<s;++r)if(i[r]===t&&r!==e)throw new Error("Duplicate item added to a unique collection")}},Mt=ra;var sa=class extends mt{constructor(t,e,i){super(t),this.map=e,this.frameState=i!==void 0?i:null}},wi=sa;var oa=class extends wi{constructor(t,e,i,r,s,o){super(t,e,s),this.originalEvent=i,this.pixel_=null,this.coordinate_=null,this.dragging=r!==void 0?r:!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()}},We=oa;var at={SINGLECLICK:"singleclick",CLICK:L.CLICK,DBLCLICK:L.DBLCLICK,POINTERDRAG:"pointerdrag",POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"};var Ji=typeof navigator<"u"&&typeof navigator.userAgent<"u"?navigator.userAgent.toLowerCase():"",Og=Ji.includes("safari")&&!Ji.includes("chrom"),dy=Og&&(Ji.includes("version/15.4")||/cpu (os|iphone os) 15_4 like mac os x/.test(Ji)),eu=Ji.includes("webkit")&&!Ji.includes("edge"),aa=Ji.includes("macintosh"),iu=typeof devicePixelRatio<"u"?devicePixelRatio:1,xt=typeof WorkerGlobalScope<"u"&&typeof OffscreenCanvas<"u"&&self instanceof WorkerGlobalScope,xs=typeof Image<"u"&&Image.prototype.decode,la=typeof createImageBitmap=="function",Es=(function(){let n=!1;try{let t=Object.defineProperty({},"passive",{get:function(){n=!0}});window.addEventListener("_",null,t),window.removeEventListener("_",null,t)}catch{}return n})();var Si={POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"};var ha=class extends je{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;let i=this.map_.getViewport();this.activePointers_=[],this.trackedTouches_={},this.element_=i,this.pointerdownListenerKey_=G(i,Si.POINTERDOWN,this.handlePointerDown_,this),this.originalPointerMoveEvent_,this.relayedListenerKey_=G(i,Si.POINTERMOVE,this.relayMoveEvent_,this),this.boundHandleTouchMove_=this.handleTouchMove_.bind(this),this.element_.addEventListener(L.TOUCHMOVE,this.boundHandleTouchMove_,Es?{passive:!1}:!1)}emulateClick_(t){let e=new We(at.CLICK,this.map_,t);this.dispatchEvent(e),this.clickTimeoutId_!==void 0?(clearTimeout(this.clickTimeoutId_),this.clickTimeoutId_=void 0,e=new We(at.DBLCLICK,this.map_,t),this.dispatchEvent(e)):this.clickTimeoutId_=setTimeout(()=>{this.clickTimeoutId_=void 0;let i=new We(at.SINGLECLICK,this.map_,t);this.dispatchEvent(i)},250)}updateActivePointers_(t){let e=t,i=e.pointerId;if(e.type==at.POINTERUP||e.type==at.POINTERCANCEL){delete this.trackedTouches_[i];for(let r in this.trackedTouches_)if(this.trackedTouches_[r].target!==e.target){delete this.trackedTouches_[r];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);let e=new We(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(B),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);let e=new We(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){let i=this.map_.getOwnerDocument();this.dragListenerKeys_.push(G(i,at.POINTERMOVE,this.handlePointerMove_,this),G(i,at.POINTERUP,this.handlePointerUp_,this),G(this.element_,at.POINTERCANCEL,this.handlePointerUp_,this)),this.element_.getRootNode&&this.element_.getRootNode()!==i&&this.dragListenerKeys_.push(G(this.element_.getRootNode(),at.POINTERUP,this.handlePointerUp_,this))}}handlePointerMove_(t){if(this.isMoving_(t)){this.updateActivePointers_(t),this.dragging_=!0;let e=new We(at.POINTERDRAG,this.map_,t,this.dragging_,void 0,this.activePointers_);this.dispatchEvent(e)}}relayMoveEvent_(t){this.originalPointerMoveEvent_=t;let e=!!(this.down_&&this.isMoving_(t));this.dispatchEvent(new We(at.POINTERMOVE,this.map_,t,e))}handleTouchMove_(t){let 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_&&(B(this.relayedListenerKey_),this.relayedListenerKey_=null),this.element_.removeEventListener(L.TOUCHMOVE,this.boundHandleTouchMove_),this.pointerdownListenerKey_&&(B(this.pointerdownListenerKey_),this.pointerdownListenerKey_=null),this.dragListenerKeys_.forEach(B),this.dragListenerKeys_.length=0,this.element_=null,super.disposeInternal()}},nu=ha;var Xe={POSTRENDER:"postrender",MOVESTART:"movestart",MOVEEND:"moveend",LOADSTART:"loadstart",LOADEND:"loadend"};var _t={LAYERGROUP:"layergroup",SIZE:"size",TARGET:"target",VIEW:"view"};var O={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4};function V(n,t){if(!n)throw new Error(t)}var lr=1/0,ca=class{constructor(t,e){this.priorityFunction_=t,this.keyFunction_=e,this.elements_=[],this.priorities_=[],this.queuedElements_={}}clear(){this.elements_.length=0,this.priorities_.length=0,ze(this.queuedElements_)}dequeue(){let 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));let r=this.keyFunction_(i);return delete this.queuedElements_[r],i}enqueue(t){V(!(this.keyFunction_(t)in this.queuedElements_),"Tried to enqueue an `element` that was already added to the queue");let 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){let e=this.elements_,i=this.priorities_,r=e.length,s=e[t],o=i[t],a=t;for(;t<r>>1;){let l=this.getLeftChildIndex_(t),c=this.getRightChildIndex_(t),h=c<r&&i[c]<i[l]?c:l;e[t]=e[h],i[t]=i[h],t=h}e[t]=s,i[t]=o,this.siftDown_(a,t)}siftDown_(t,e){let i=this.elements_,r=this.priorities_,s=i[e],o=r[e];for(;e>t;){let a=this.getParentIndex_(e);if(r[a]>o)i[e]=i[a],r[e]=r[a],e=a;else break}i[e]=s,r[e]=o}reprioritize(){let t=this.priorityFunction_,e=this.elements_,i=this.priorities_,r=0,s=e.length,o,a,l;for(a=0;a<s;++a)o=e[a],l=t(o),l==lr?delete this.queuedElements_[this.keyFunction_(o)]:(i[r]=l,e[r++]=o);e.length=r,i.length=r,this.heapify_()}},ru=ca;var ua=class extends ru{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){let e=super.enqueue(t);return e&&t[0].addEventListener(L.CHANGE,this.boundHandleTileChange_),e}getTilesLoading(){return this.tilesLoading_}handleTileChange(t){let e=t.target,i=e.getState();if(i===O.LOADED||i===O.ERROR||i===O.EMPTY){i!==O.ERROR&&e.removeEventListener(L.CHANGE,this.boundHandleTileChange_);let r=e.getKey();r in this.tilesLoadingKeys_&&(delete this.tilesLoadingKeys_[r],--this.tilesLoading_),this.tileChangeCallback_()}}loadMoreTiles(t,e){let i=0;for(;this.tilesLoading_<t&&i<e&&this.getCount()>0;){let r=this.dequeue()[0],s=r.getKey();r.getState()===O.IDLE&&!(s in this.tilesLoadingKeys_)&&(this.tilesLoadingKeys_[s]=!0,++this.tilesLoading_,++i,r.load())}}},su=ua;function ou(n,t,e,i,r){if(!n||!(e in n.wantedTiles))return lr;if(!n.wantedTiles[e][t.getKey()])return lr;let s=n.viewState.center,o=i[0]-s[0],a=i[1]-s[1];return 65536*Math.log(r)+Math.sqrt(o*o+a*a)/r}var dt={ANIMATING:0,INTERACTING:1};var ae={CENTER:"center",RESOLUTION:"resolution",ROTATION:"rotation"};function Q(n,t,e){return Math.min(Math.max(n,t),e)}function au(n,t,e,i,r,s){let o=r-e,a=s-i;if(o!==0||a!==0){let l=((n-e)*o+(t-i)*a)/(o*o+a*a);l>1?(e=r,i=s):l>0&&(e+=o*l,i+=a*l)}return Ce(n,t,e,i)}function Ce(n,t,e,i){let r=e-n,s=i-t;return r*r+s*s}function lu(n){let t=n.length;for(let i=0;i<t;i++){let r=i,s=Math.abs(n[i][i]);for(let a=i+1;a<t;a++){let l=Math.abs(n[a][i]);l>s&&(s=l,r=a)}if(s===0)return null;let o=n[r];n[r]=n[i],n[i]=o;for(let a=i+1;a<t;a++){let l=-n[a][i]/n[i][i];for(let c=i;c<t+1;c++)i==c?n[a][c]=0:n[a][c]+=l*n[i][c]}}let e=new Array(t);for(let i=t-1;i>=0;i--){e[i]=n[i][t]/n[i][i];for(let r=i-1;r>=0;r--)n[r][t]-=n[r][i]*e[i]}return e}function Cs(n){return n*180/Math.PI}function Re(n){return n*Math.PI/180}function Wt(n,t){let e=n%t;return e*t<0?e+t:e}function bt(n,t,e){return n+e*(t-n)}function Ti(n,t){let e=Math.pow(10,t);return Math.round(n*e)/e}function da(n,t){return Math.round(Ti(n,t))}function vi(n,t){return Math.floor(Ti(n,t))}function Ue(n,t){return Math.ceil(Ti(n,t))}function Rs(n,t,e){if(n>=t&&n<e)return n;let i=e-t;return((n-t)%i+i)%i+t}function fa(n,t,e){return(function(i,r,s,o,a){if(!i)return;if(!r&&!t)return i;let l=t?0:s[0]*r,c=t?0:s[1]*r,h=a?a[0]:0,u=a?a[1]:0,d=n[0]+l/2+h,f=n[2]-l/2+h,g=n[1]+c/2+u,p=n[3]-c/2+u;d>f&&(d=(f+d)/2,f=d),g>p&&(g=(p+g)/2,p=g);let m=Q(i[0],d,f),_=Q(i[1],g,p);if(o&&e&&r){let y=30*r;m+=-y*Math.log(1+Math.max(0,d-i[0])/y)+y*Math.log(1+Math.max(0,i[0]-f)/y),_+=-y*Math.log(1+Math.max(0,g-i[1])/y)+y*Math.log(1+Math.max(0,i[1]-p)/y)}return[m,_]})}function hu(n){return n}var yt={UNKNOWN:0,INTERSECTING:1,ABOVE:2,RIGHT:4,BELOW:8,LEFT:16};function ga(n){let t=ct();for(let e=0,i=n.length;e<i;++e)Qi(t,n[e]);return t}function Fg(n,t,e){let i=Math.min.apply(null,n),r=Math.min.apply(null,t),s=Math.max.apply(null,n),o=Math.max.apply(null,t);return Qt(i,r,s,o,e)}function ri(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 Ss(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n.slice()}function Xt(n,t,e){let i,r;return t<n[0]?i=n[0]-t:n[2]<t?i=t-n[2]:i=0,e<n[1]?r=n[1]-e:n[3]<e?r=e-n[3]:r=0,i*i+r*r}function Jt(n,t){return hr(n,t[0],t[1])}function le(n,t){return n[0]<=t[0]&&t[2]<=n[2]&&n[1]<=t[1]&&t[3]<=n[3]}function hr(n,t,e){return n[0]<=t&&t<=n[2]&&n[1]<=e&&e<=n[3]}function ws(n,t){let e=n[0],i=n[1],r=n[2],s=n[3],o=t[0],a=t[1],l=yt.UNKNOWN;return o<e?l=l|yt.LEFT:o>r&&(l=l|yt.RIGHT),a<i?l=l|yt.BELOW:a>s&&(l=l|yt.ABOVE),l===yt.UNKNOWN&&(l=yt.INTERSECTING),l}function ct(){return[1/0,1/0,-1/0,-1/0]}function Qt(n,t,e,i,r){return r?(r[0]=n,r[1]=t,r[2]=e,r[3]=i,r):[n,t,e,i]}function si(n){return Qt(1/0,1/0,-1/0,-1/0,n)}function Ts(n,t){let e=n[0],i=n[1];return Qt(e,i,e,i,t)}function En(n,t,e,i,r){let s=si(r);return ma(s,n,t,e,i)}function we(n,t){return n[0]==t[0]&&n[2]==t[2]&&n[1]==t[1]&&n[3]==t[3]}function vs(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 Qi(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 ma(n,t,e,i,r){for(;e<i;e+=r)Dg(n,t[e],t[e+1]);return n}function Dg(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 Is(n,t){let e;return e=t(Cn(n)),e||(e=t(Rn(n)),e)||(e=t(wn(n)),e)||(e=t(he(n)),e)?e:!1}function cr(n){let t=0;return Yt(n)||(t=W(n)*et(n)),t}function Cn(n){return[n[0],n[1]]}function Rn(n){return[n[2],n[1]]}function St(n){return[(n[0]+n[2])/2,(n[1]+n[3])/2]}function cu(n,t){let e;if(t==="bottom-left")e=Cn(n);else if(t==="bottom-right")e=Rn(n);else if(t==="top-left")e=he(n);else if(t==="top-right")e=wn(n);else throw new Error("Invalid corner");return e}function oi(n,t,e,i,r){let[s,o,a,l,c,h,u,d]=pa(n,t,e,i);return Qt(Math.min(s,a,c,u),Math.min(o,l,h,d),Math.max(s,a,c,u),Math.max(o,l,h,d),r)}function pa(n,t,e,i){let r=t*i[0]/2,s=t*i[1]/2,o=Math.cos(e),a=Math.sin(e),l=r*o,c=r*a,h=s*o,u=s*a,d=n[0],f=n[1];return[d-l+u,f-c-h,d-l-u,f-c+h,d+l-u,f+c+h,d+l+u,f+c-h,d-l+u,f-c-h]}function et(n){return n[3]-n[1]}function Ut(n,t,e){let i=e||ct();return lt(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]):si(i),i}function he(n){return[n[0],n[3]]}function wn(n){return[n[2],n[3]]}function W(n){return n[2]-n[0]}function lt(n,t){return n[0]<=t[2]&&n[2]>=t[0]&&n[1]<=t[3]&&n[3]>=t[1]}function Yt(n){return n[2]<n[0]||n[3]<n[1]}function uu(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n}function du(n,t,e){let i=!1,r=ws(n,t),s=ws(n,e);if(r===yt.INTERSECTING||s===yt.INTERSECTING)i=!0;else{let o=n[0],a=n[1],l=n[2],c=n[3],h=t[0],u=t[1],d=e[0],f=e[1],g=(f-u)/(d-h),p,m;s&yt.ABOVE&&!(r&yt.ABOVE)&&(p=d-(f-c)/g,i=p>=o&&p<=l),!i&&s&yt.RIGHT&&!(r&yt.RIGHT)&&(m=f-(d-l)*g,i=m>=a&&m<=c),!i&&s&yt.BELOW&&!(r&yt.BELOW)&&(p=d-(f-a)/g,i=p>=o&&p<=l),!i&&s&yt.LEFT&&!(r&yt.LEFT)&&(m=f-(d-o)*g,i=m>=a&&m<=c)}return i}function fu(n,t,e,i){if(Yt(n))return si(e);let r=[];if(i>1){let a=n[2]-n[0],l=n[3]-n[1];for(let c=0;c<i;++c)r.push(n[0]+a*c/i,n[1],n[2],n[1]+l*c/i,n[2]-a*c/i,n[3],n[0],n[3]-l*c/i)}else r=[n[0],n[1],n[2],n[1],n[2],n[3],n[0],n[3]];t(r,r,2);let s=[],o=[];for(let a=0,l=r.length;a<l;a+=2)s.push(r[a]),o.push(r[a+1]);return Fg(s,o,e)}function _a(n,t){let e=t.getExtent(),i=St(n);if(t.canWrapX()&&(i[0]<e[0]||i[0]>=e[2])){let r=W(e),o=Math.floor((i[0]-e[0])/r)*r;n[0]-=o,n[2]-=o}return n}function Ms(n,t,e){if(t.canWrapX()){let i=t.getExtent();if(!isFinite(n[0])||!isFinite(n[2]))return[[i[0],n[1],i[2],n[3]]];_a(n,t);let r=W(i);if(W(n)>r&&!e)return[[i[0],n[1],i[2],n[3]]];if(n[0]<i[0])return[[n[0]+r,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]-r,n[3]]]}return[n]}function ur(n,t){let e=(""+n).split("."),i=(""+t).split(".");for(let r=0;r<Math.max(e.length,i.length);r++){let s=parseInt(e[r]||"0",10),o=parseInt(i[r]||"0",10);if(s>o)return 1;if(o>s)return-1}return 0}function gu(n,t){return n[0]+=+t[0],n[1]+=+t[1],n}function mu(n){return(function(t){return Ng(t,n)})}function kg(n,t,e){return n?t.replace("{x}",n[0].toFixed(e)).replace("{y}",n[1].toFixed(e)):""}function tn(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 Sn(n,t){let e=Math.cos(t),i=Math.sin(t),r=n[0]*e-n[1]*i,s=n[1]*e+n[0]*i;return n[0]=r,n[1]=s,n}function pu(n,t){return n[0]*=t,n[1]*=t,n}function Ng(n,t){return kg(n,"{x}, {y}",t)}function Tn(n,t){if(t.canWrapX()){let e=W(t.getExtent()),i=_u(n,t,e);i&&(n[0]-=i*e)}return n}function _u(n,t,e){let i=t.getExtent(),r=0;return t.canWrapX()&&(n[0]<i[0]||n[0]>i[2])&&(e=e||W(i),r=Math.floor((n[0]-i[0])/e)),r}function yu(n,t,e){let i=Math.sqrt((t[0]-n[0])*(t[0]-n[0])+(t[1]-n[1])*(t[1]-n[1])),r=[(t[0]-n[0])/i,(t[1]-n[1])/i],s=[-r[1],r[0]],o=Math.sqrt((e[0]-n[0])*(e[0]-n[0])+(e[1]-n[1])*(e[1]-n[1])),a=[(e[0]-n[0])/o,(e[1]-n[1])/o],l=i===0||o===0?0:Math.acos(Q(a[0]*r[0]+a[1]*r[1],-1,1));return l=Math.max(l,1e-5),a[0]*s[0]+a[1]*s[1]>0?l:Math.PI*2-l}function ya(n){return Math.pow(n,3)}function ce(n){return 1-ya(1-n)}function xu(n){return 3*n*n-2*n*n*n}function Eu(n){return n}var Gg=63710088e-1;function xa(n,t,e){e=e||Gg;let i=Re(n[1]),r=Re(t[1]),s=(r-i)/2,o=Re(t[0]-n[0])/2,a=Math.sin(s)*Math.sin(s)+Math.sin(o)*Math.sin(o)*Math.cos(i)*Math.cos(r);return 2*e*Math.atan2(Math.sqrt(a),Math.sqrt(1-a))}var Cu={info:1,warn:2,error:3,none:4},zg=Cu.info;function bs(...n){zg>Cu.warn||console.warn(...n)}var Se={radians:6370997/(2*Math.PI),degrees:2*Math.PI*6370997/360,ft:.3048,m:1,"us-ft":1200/3937};var Ea=class{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_||Se[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_}},vn=Ea;var dr=6378137,In=Math.PI*dr,jg=[-In,-In,In,In],Wg=[-180,-85,180,85],Ls=dr*Math.log(Math.tan(Math.PI/2)),Ii=class extends vn{constructor(t){super({code:t,units:"m",extent:jg,global:!0,worldExtent:Wg,getPointResolution:function(e,i){return e/Math.cosh(i[1]/dr)}})}},Ca=[new Ii("EPSG:3857"),new Ii("EPSG:102100"),new Ii("EPSG:102113"),new Ii("EPSG:900913"),new Ii("http://www.opengis.net/def/crs/EPSG/0/3857"),new Ii("http://www.opengis.net/gml/srs/epsg.xml#3857")];function Ru(n,t,e,i){let r=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(r));for(let s=0;s<r;s+=i){t[s]=In*n[s]/180;let o=dr*Math.log(Math.tan(Math.PI*(+n[s+1]+90)/360));o>Ls?o=Ls:o<-Ls&&(o=-Ls),t[s+1]=o}return t}function wu(n,t,e,i){let r=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(r));for(let s=0;s<r;s+=i)t[s]=180*n[s]/In,t[s+1]=360*Math.atan(Math.exp(n[s+1]/dr))/Math.PI-90;return t}var Xg=6378137,Su=[-180,-90,180,90],Ug=Math.PI*Xg/180,ai=class extends vn{constructor(t,e){super({code:t,units:"degrees",extent:Su,axisOrientation:e,global:!0,metersPerUnit:Ug,worldExtent:Su})}},Ra=[new ai("CRS:84"),new ai("EPSG:4326","neu"),new ai("urn:ogc:def:crs:OGC:1.3:CRS84"),new ai("urn:ogc:def:crs:OGC:2:84"),new ai("http://www.opengis.net/def/crs/OGC/1.3/CRS84"),new ai("http://www.opengis.net/gml/srs/epsg.xml#4326","neu"),new ai("http://www.opengis.net/def/crs/EPSG/0/4326","neu")];var wa={};function Tu(n){return wa[n]||wa[n.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\w+)$/,"EPSG:$3")]||null}function vu(n,t){wa[n]=t}var Mn={};function bn(n,t,e){let i=n.getCode(),r=t.getCode();i in Mn||(Mn[i]={}),Mn[i][r]=e}function As(n,t){return n in Mn&&t in Mn[n]?Mn[n][t]:null}var Ps=.9996,ue=.00669438,Fs=ue*ue,Ds=Fs*ue,en=ue/(1-ue),Iu=Math.sqrt(1-ue),Ln=(1-Iu)/(1+Iu),Au=Ln*Ln,Sa=Au*Ln,Ta=Sa*Ln,Pu=Ta*Ln,Ou=1-ue/4-3*Fs/64-5*Ds/256,Yg=3*ue/8+3*Fs/32+45*Ds/1024,Kg=15*Fs/256+45*Ds/1024,Vg=35*Ds/3072,Bg=3/2*Ln-27/32*Sa+269/512*Pu,Zg=21/16*Au-55/32*Ta,Hg=151/96*Sa-417/128*Pu,qg=1097/512*Ta,Os=6378137;function $g(n,t,e){let i=n-5e5,o=(e.north?t:t-1e7)/Ps/(Os*Ou),a=o+Bg*Math.sin(2*o)+Zg*Math.sin(4*o)+Hg*Math.sin(6*o)+qg*Math.sin(8*o),l=Math.sin(a),c=l*l,h=Math.cos(a),u=l/h,d=u*u,f=d*d,g=1-ue*c,p=Math.sqrt(1-ue*c),m=Os/p,_=(1-ue)/g,y=en*h**2,E=y*y,x=i/(m*Ps),C=x*x,T=C*x,I=T*x,S=I*x,w=S*x,M=a-u/_*(C/2-I/24*(5+3*d+10*y-4*E-9*en))+w/720*(61+90*d+298*y+45*f-252*en-3*E),N=(x-T/6*(1+2*d+y)+S/120*(5-2*y+28*d-3*E+8*en+24*f))/h;return N=Rs(N+Re(Fu(e.number)),-Math.PI,Math.PI),[Cs(N),Cs(M)]}var Mu=-80,bu=84,Jg=-180,Qg=180;function tm(n,t,e){n=Rs(n,Jg,Qg),t<Mu?t=Mu:t>bu&&(t=bu);let i=Re(t),r=Math.sin(i),s=Math.cos(i),o=r/s,a=o*o,l=a*a,c=Re(n),h=Fu(e.number),u=Re(h),d=Os/Math.sqrt(1-ue*r**2),f=en*s**2,g=s*Rs(c-u,-Math.PI,Math.PI),p=g*g,m=p*g,_=m*g,y=_*g,E=y*g,x=Os*(Ou*i-Yg*Math.sin(2*i)+Kg*Math.sin(4*i)-Vg*Math.sin(6*i)),C=Ps*d*(g+m/6*(1-a+f)+y/120*(5-18*a+l+72*f-58*en))+5e5,T=Ps*(x+d*o*(p/2+_/24*(5-a+9*f+4*f**2)+E/720*(61-58*a+l+600*f-330*en)));return e.north||(T+=1e7),[C,T]}function Fu(n){return(n-1)*6-180+3}var em=[/^EPSG:(\d+)$/,/^urn:ogc:def:crs:EPSG::(\d+)$/,/^http:\/\/www\.opengis\.net\/def\/crs\/EPSG\/0\/(\d+)$/];function Du(n){let t=0;for(let r of em){let s=n.match(r);if(s){t=parseInt(s[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 Lu(n,t){return function(e,i,r,s){let o=e.length;r=r>1?r:2,s=s??r,i||(r>2?i=e.slice():i=new Array(o));for(let a=0;a<o;a+=s){let l=e[a],c=e[a+1],h=n(l,c,t);i[a]=h[0],i[a+1]=h[1]}return i}}function ku(n){return Du(n)?new vn({code:n,units:"m"}):null}function Nu(n){let t=Du(n.getCode());return t?{forward:Lu(tm,t),inverse:Lu($g,t)}:null}var im=[Nu],nm=[ku];var Ia=!0;function ba(n){Ia=!(n===void 0?!0:n)}function La(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 zu(n,t){if(t!==void 0&&n!==t){for(let e=0,i=n.length;e<i;++e)t[e]=n[e];n=t}return n}function Ma(n){vu(n.getCode(),n),bn(n,n,La)}function rm(n){n.forEach(Ma)}function q(n){if(typeof n!="string")return n;let t=Tu(n);if(t)return t;for(let e of nm){let i=e(n);if(i)return i}return null}function An(n,t,e,i){n=q(n);let r,s=n.getPointResolutionFunc();if(s){if(r=s(t,e),i&&i!==n.getUnits()){let o=n.getMetersPerUnit();o&&(r=r*o/Se[i])}}else{let o=n.getUnits();if(o=="degrees"&&!i||i=="degrees")r=t;else{let a=Ye(n,q("EPSG:4326"));if(!a&&o!=="degrees")r=t*n.getMetersPerUnit();else{let c=[e[0]-t/2,e[1],e[0]+t/2,e[1],e[0],e[1]-t/2,e[0],e[1]+t/2];c=a(c,c,2);let h=xa(c.slice(0,2),c.slice(2,4)),u=xa(c.slice(4,6),c.slice(6,8));r=(h+u)/2}let l=i?Se[i]:n.getMetersPerUnit();l!==void 0&&(r/=l)}}return r}function Gu(n){rm(n),n.forEach(function(t){n.forEach(function(e){t!==e&&bn(t,e,La)})})}function sm(n,t,e,i){n.forEach(function(r){t.forEach(function(s){bn(r,s,e),bn(s,r,i)})})}function ks(n,t){return n?typeof n=="string"?q(n):n:q(t)}function ju(n){return(function(t,e,i,r){let s=t.length;i=i!==void 0?i:2,r=r??i,e=e!==void 0?e:new Array(s);for(let o=0;o<s;o+=r){let a=n(t.slice(o,o+i)),l=a.length;for(let c=0,h=r;c<h;++c)e[o+c]=c>=l?t[o+c]:a[c]}return e})}function nn(n,t){return ba(),de(n,"EPSG:4326",t!==void 0?t:"EPSG:3857")}function Wu(n,t){let e=de(n,t!==void 0?t:"EPSG:3857","EPSG:4326"),i=e[0];return(i<-180||i>180)&&(e[0]=Wt(i+180,360)-180),e}function ve(n,t){if(n===t)return!0;let e=n.getUnits()===t.getUnits();return(n.getCode()===t.getCode()||Ye(n,t)===La)&&e}function Ye(n,t){let e=n.getCode(),i=t.getCode(),r=As(e,i);if(r)return r;let s=null,o=null;for(let l of im)s||(s=l(n)),o||(o=l(t));if(!s&&!o)return null;let a="EPSG:4326";if(o)if(s)r=va(s.inverse,o.forward);else{let l=As(e,a);l&&(r=va(l,o.forward))}else{let l=As(a,i);l&&(r=va(s.inverse,l))}return r&&(Ma(n),Ma(t),bn(n,t,r)),r}function va(n,t){return function(e,i,r,s){return i=n(e,i,r,s),t(i,i,r,s)}}function li(n,t){let e=q(n),i=q(t);return Ye(e,i)}function de(n,t,e){let i=li(t,e);if(!i){let r=q(t).getCode(),s=q(e).getCode();throw new Error(`No transform available between ${r} and ${s}`)}return i(n,void 0,n.length)}function fr(n,t,e,i){let r=li(t,e);return fu(n,r,void 0,i)}var Te=null;function hi(){return Te}function gr(n,t){return Te?de(n,t,Te):n}function Ie(n,t){return Te?de(n,Te,t):(Ia&&!tn(n,[0,0])&&n[0]>=-180&&n[0]<=180&&n[1]>=-90&&n[1]<=90&&(Ia=!1,bs("Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates.")),n)}function Mi(n,t){return Te?fr(n,t,Te):n}function Gt(n,t){return Te?fr(n,Te,t):n}function Xu(n,t){if(!Te)return n;let e=q(t).getMetersPerUnit(),i=Te.getMetersPerUnit();return e&&i?n*e/i:n}function om(){Gu(Ca),Gu(Ra),sm(Ra,Ca,Ru,wu)}om();var wx=new Array(6);function Tt(){return[1,0,0,1,0,0]}function Uu(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 ht(n,t){let 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 Et(n,t,e,i,r,s,o,a){let l=Math.sin(s),c=Math.cos(s);return n[0]=i*c,n[1]=r*l,n[2]=-i*l,n[3]=r*c,n[4]=o*i*c-a*i*l+t,n[5]=o*r*l+a*r*c+e,n}function Gs(n,t){let e=am(t);V(e!==0,"Transformation matrix cannot be inverted");let i=t[0],r=t[1],s=t[2],o=t[3],a=t[4],l=t[5];return n[0]=o/e,n[1]=-r/e,n[2]=-s/e,n[3]=i/e,n[4]=(s*l-o*a)/e,n[5]=-(i*l-r*a)/e,n}function am(n){return n[0]*n[3]-n[1]*n[2]}var lm=[1e5,1e5,1e5,1e5,2,2];function Yu(n){return"matrix("+n.join(", ")+")"}function Ns(n){return n.substring(7,n.length-1).split(",").map(parseFloat)}function Ku(n,t){let e=Ns(n),i=Ns(t);for(let r=0;r<6;++r)if(Math.round((e[r]-i[r])*lm[r])!==0)return!1;return!0}function Kt(n,t,e,i,r,s,o){s=s||[],o=o||2;let a=0;for(let l=t;l<e;l+=i){let c=n[l],h=n[l+1];s[a++]=r[0]*c+r[2]*h+r[4],s[a++]=r[1]*c+r[3]*h+r[5];for(let u=2;u<o;u++)s[a++]=n[l+u]}return s&&s.length!=a&&(s.length=a),s}function zs(n,t,e,i,r,s,o){o=o||[];let a=Math.cos(r),l=Math.sin(r),c=s[0],h=s[1],u=0;for(let d=t;d<e;d+=i){let f=n[d]-c,g=n[d+1]-h;o[u++]=c+f*a-g*l,o[u++]=h+f*l+g*a;for(let p=d+2;p<d+i;++p)o[u++]=n[p]}return o&&o.length!=u&&(o.length=u),o}function Vu(n,t,e,i,r,s,o,a){a=a||[];let l=o[0],c=o[1],h=0;for(let u=t;u<e;u+=i){let d=n[u]-l,f=n[u+1]-c;a[h++]=l+r*d,a[h++]=c+s*f;for(let g=u+2;g<u+i;++g)a[h++]=n[g]}return a&&a.length!=h&&(a.length=h),a}function Bu(n,t,e,i,r,s,o){o=o||[];let a=0;for(let l=t;l<e;l+=i){o[a++]=n[l]+r,o[a++]=n[l+1]+s;for(let c=l+2;c<l+i;++c)o[a++]=n[c]}return o&&o.length!=a&&(o.length=a),o}var Zu=Tt(),hm=[NaN,NaN],Aa=class extends pt{constructor(){super(),this.extent_=ct(),this.extentRevision_=-1,this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=0,this.simplifyTransformedInternal=ms((t,e,i)=>{if(!i)return this.getSimplifiedGeometry(e);let r=this.clone();return r.applyTransform(i),r.getSimplifiedGeometry(e)})}simplifyTransformed(t,e){return this.simplifyTransformedInternal(this.getRevision(),t,e)}clone(){return F()}closestPointXY(t,e,i,r){return F()}containsXY(t,e){return this.closestPointXY(t,e,hm,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 F()}getExtent(t){if(this.extentRevision_!=this.getRevision()){let e=this.computeExtent(this.extent_);(isNaN(e[0])||isNaN(e[1]))&&si(e),this.extentRevision_=this.getRevision()}return uu(this.extent_,t)}rotate(t,e){F()}scale(t,e,i){F()}simplify(t){return this.getSimplifiedGeometry(t*t)}getSimplifiedGeometry(t){return F()}getType(){return F()}applyTransform(t){F()}intersectsExtent(t){return F()}translate(t,e){F()}transform(t,e){let i=q(t),r=i.getUnits()=="tile-pixels"?function(s,o,a){let l=i.getExtent(),c=i.getWorldExtent(),h=et(c)/et(l);Et(Zu,c[0],c[3],h,-h,0,0,0);let u=Kt(s,0,s.length,a,Zu,o),d=li(i,e);return d?d(u,u,a):u}:li(i,e);return this.applyTransform(r),this}},js=Aa;var Pa=class extends js{constructor(){super(),this.layout="XY",this.stride=2,this.flatCoordinates}computeExtent(t){return En(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinates(){return F()}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;let 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=Hu(t),this.layout=t,this.flatCoordinates=e}setCoordinates(t,e){F()}setLayout(t,e,i){let r;if(t)r=Hu(t);else{for(let s=0;s<i;++s){if(e.length===0){this.layout="XY",this.stride=2;return}e=e[0]}r=e.length,t=bi(r)}this.layout=t,this.stride=r}applyTransform(t){this.flatCoordinates&&(t(this.flatCoordinates,this.flatCoordinates,this.layout.startsWith("XYZ")?3:2,this.stride),this.changed())}rotate(t,e){let i=this.getFlatCoordinates();if(i){let r=this.getStride();zs(i,0,i.length,r,t,e,i),this.changed()}}scale(t,e,i){e===void 0&&(e=t),i||(i=St(this.getExtent()));let r=this.getFlatCoordinates();if(r){let s=this.getStride();Vu(r,0,r.length,s,t,e,i,r),this.changed()}}translate(t,e){let i=this.getFlatCoordinates();if(i){let r=this.getStride();Bu(i,0,i.length,r,t,e,i),this.changed()}}};function bi(n){let t;return n==2?t="XY":n==3?t="XYZ":n==4&&(t="XYZM"),t}function Hu(n){let t;return n=="XY"?t=2:n=="XYZ"||n=="XYM"?t=3:n=="XYZM"&&(t=4),t}function qu(n,t,e){let i=n.getFlatCoordinates();if(!i)return null;let r=n.getStride();return Kt(i,0,i.length,r,t,e)}var Vt=Pa;function Oa(n,t,e,i){let r=0,s=n[e-i],o=n[e-i+1],a=0,l=0;for(;t<e;t+=i){let c=n[t]-s,h=n[t+1]-o;r+=l*c-a*h,a=c,l=h}return r/2}function Fa(n,t,e,i){let r=0;for(let s=0,o=e.length;s<o;++s){let a=e[s];r+=Oa(n,t,a,i),t=a}return r}function $u(n,t,e,i){let r=0;for(let s=0,o=e.length;s<o;++s){let a=e[s];r+=Fa(n,t,a,i),t=a[a.length-1]}return r}function Ju(n,t,e,i,r,s,o){let a=n[t],l=n[t+1],c=n[e]-a,h=n[e+1]-l,u;if(c===0&&h===0)u=t;else{let d=((r-a)*c+(s-l)*h)/(c*c+h*h);if(d>1)u=e;else if(d>0){for(let f=0;f<i;++f)o[f]=bt(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 mr(n,t,e,i,r){let s=n[t],o=n[t+1];for(t+=i;t<e;t+=i){let a=n[t],l=n[t+1],c=Ce(s,o,a,l);c>r&&(r=c),s=a,o=l}return r}function pr(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];r=mr(n,t,a,i,r),t=a}return r}function Qu(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];r=pr(n,t,a,i,r),t=a[a.length-1]}return r}function _r(n,t,e,i,r,s,o,a,l,c,h){if(t==e)return c;let u,d;if(r===0){if(d=Ce(o,a,n[t],n[t+1]),d<c){for(u=0;u<i;++u)l[u]=n[t+u];return l.length=i,d}return c}h=h||[NaN,NaN];let f=t+i;for(;f<e;)if(Ju(n,f-i,f,i,o,a,h),d=Ce(o,a,h[0],h[1]),d<c){for(c=d,u=0;u<i;++u)l[u]=h[u];l.length=i,f+=i}else f+=i*Math.max((Math.sqrt(d)-Math.sqrt(c))/r|0,1);if(s&&(Ju(n,e-i,t,i,o,a,h),d=Ce(o,a,h[0],h[1]),d<c)){for(c=d,u=0;u<i;++u)l[u]=h[u];l.length=i}return c}function yr(n,t,e,i,r,s,o,a,l,c,h){h=h||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){let f=e[u];c=_r(n,t,f,i,r,s,o,a,l,c,h),t=f}return c}function td(n,t,e,i,r,s,o,a,l,c,h){h=h||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){let f=e[u];c=yr(n,t,f,i,r,s,o,a,l,c,h),t=f[f.length-1]}return c}function ed(n,t,e,i){for(let r=0,s=e.length;r<s;++r)n[t++]=e[r];return t}function rn(n,t,e,i){for(let r=0,s=e.length;r<s;++r){let o=e[r];for(let a=0;a<i;++a)n[t++]=o[a]}return t}function Li(n,t,e,i,r){r=r||[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=rn(n,t,e[o],i);r[s++]=l,t=l}return r.length=s,r}function Ws(n,t,e,i,r){r=r||[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=Li(n,t,e[o],i,r[s]);l.length===0&&(l[0]=t),r[s++]=l,t=l[l.length-1]}return r.length=s,r}function fe(n,t,e,i,r){r=r!==void 0?r:[];let s=0;for(let o=t;o<e;o+=i)r[s++]=n.slice(o,o+i);return r.length=s,r}function Ai(n,t,e,i,r){r=r!==void 0?r:[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=e[o];r[s++]=fe(n,t,l,i,r[s]),t=l}return r.length=s,r}function xr(n,t,e,i,r){r=r!==void 0?r:[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=e[o];r[s++]=l.length===1&&l[0]===t?[]:Ai(n,t,l,i,r[s]),t=l[l.length-1]}return r.length=s,r}function sn(n,t,e,i,r,s,o){let a=(e-t)/i;if(a<3){for(;t<e;t+=i)s[o++]=n[t],s[o++]=n[t+1];return o}let l=new Array(a);l[0]=1,l[a-1]=1;let c=[t,e-i],h=0;for(;c.length>0;){let u=c.pop(),d=c.pop(),f=0,g=n[d],p=n[d+1],m=n[u],_=n[u+1];for(let y=d+i;y<u;y+=i){let E=n[y],x=n[y+1],C=au(E,x,g,p,m,_);C>f&&(h=y,f=C)}f>r&&(l[(h-t)/i]=1,d+i<h&&c.push(d,h),h+i<u&&c.push(h,u))}for(let u=0;u<a;++u)l[u]&&(s[o++]=n[t+u*i],s[o++]=n[t+u*i+1]);return o}function Xs(n,t,e,i,r,s,o,a){for(let l=0,c=e.length;l<c;++l){let h=e[l];o=sn(n,t,h,i,r,s,o),a.push(o),t=h}return o}function Pi(n,t){return t*Math.round(n/t)}function cm(n,t,e,i,r,s,o){if(t==e)return o;let a=Pi(n[t],r),l=Pi(n[t+1],r);t+=i,s[o++]=a,s[o++]=l;let c,h;do if(c=Pi(n[t],r),h=Pi(n[t+1],r),t+=i,t==e)return s[o++]=c,s[o++]=h,o;while(c==a&&h==l);for(;t<e;){let u=Pi(n[t],r),d=Pi(n[t+1],r);if(t+=i,u==c&&d==h)continue;let f=c-a,g=h-l,p=u-a,m=d-l;if(f*m==g*p&&(f<0&&p<f||f==p||f>0&&p>f)&&(g<0&&m<g||g==m||g>0&&m>g)){c=u,h=d;continue}s[o++]=c,s[o++]=h,a=c,l=h,c=u,h=d}return s[o++]=c,s[o++]=h,o}function Er(n,t,e,i,r,s,o,a){for(let l=0,c=e.length;l<c;++l){let h=e[l];o=cm(n,t,h,i,r,s,o),a.push(o),t=h}return o}function id(n,t,e,i,r,s,o,a){for(let l=0,c=e.length;l<c;++l){let h=e[l],u=[];o=Er(n,t,h,i,r,s,o,u),a.push(u),t=h[h.length-1]}return o}var Da=class n extends Vt{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,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(mr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),_r(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!0,t,e,i,r))}getArea(){return Oa(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinates(){return fe(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getSimplifiedGeometryInternal(t){let e=[];return e.length=sn(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=rn(this.flatCoordinates,0,t,this.stride),this.changed()}},ka=Da;var Na=class n extends Vt{constructor(t,e){super(),this.setCoordinates(t,e)}clone(){let t=new n(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,r){let s=this.flatCoordinates,o=Ce(t,e,s[0],s[1]);if(o<r){let a=this.stride;for(let l=0;l<a;++l)i[l]=s[l];return i.length=a,o}return r}getCoordinates(){return this.flatCoordinates.slice()}computeExtent(t){return Ts(this.flatCoordinates,t)}getType(){return"Point"}intersectsExtent(t){return hr(t,this.flatCoordinates[0],this.flatCoordinates[1])}setCoordinates(t,e){this.setLayout(e,t,0),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=ed(this.flatCoordinates,0,t,this.stride),this.changed()}},Oi=Na;function nd(n,t,e,i,r){return!Is(r,function(o){return!Fi(n,t,e,i,o[0],o[1])})}function Fi(n,t,e,i,r,s){let o=0,a=n[e-i],l=n[e-i+1];for(;t<e;t+=i){let c=n[t],h=n[t+1];l<=s?h>s&&(c-a)*(s-l)-(r-a)*(h-l)>0&&o++:h<=s&&(c-a)*(s-l)-(r-a)*(h-l)<0&&o--,a=c,l=h}return o!==0}function Cr(n,t,e,i,r,s){if(e.length===0||!Fi(n,t,e[0],i,r,s))return!1;for(let o=1,a=e.length;o<a;++o)if(Fi(n,e[o-1],e[o],i,r,s))return!1;return!0}function rd(n,t,e,i,r,s){if(e.length===0)return!1;for(let o=0,a=e.length;o<a;++o){let l=e[o];if(Cr(n,t,l,i,r,s))return!0;t=l[l.length-1]}return!1}function Rr(n,t,e,i,r,s,o){let a,l,c,h,u,d,f,g=r[s+1],p=[];for(let y=0,E=e.length;y<E;++y){let x=e[y];for(h=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)&&(c=(g-d)/(f-d)*(u-h)+h,p.push(c)),h=u,d=f}let m=NaN,_=-1/0;for(p.sort(jt),h=p[0],a=1,l=p.length;a<l;++a){u=p[a];let y=Math.abs(u-h);y>_&&(c=(h+u)/2,Cr(n,t,e,i,c,g)&&(m=c,_=y)),h=u}return isNaN(m)&&(m=r[s]),o?(o.push(m,g,_),o):[m,g,_]}function Us(n,t,e,i,r){let s=[];for(let o=0,a=e.length;o<a;++o){let l=e[o];s=Rr(n,t,l,i,r,2*o,s),t=l[l.length-1]}return s}function Ys(n,t,e,i,r){let s;for(t+=i;t<e;t+=i)if(s=r(n.slice(t-i,t),n.slice(t,t+i)),s)return s;return!1}function wr(n,t,e,i,r,s){return s=s??ma(ct(),n,t,e,i),lt(r,s)?s[0]>=r[0]&&s[2]<=r[2]||s[1]>=r[1]&&s[3]<=r[3]?!0:Ys(n,t,e,i,function(o,a){return du(r,o,a)}):!1}function sd(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){if(wr(n,t,e[s],i,r))return!0;t=e[s]}return!1}function Ga(n,t,e,i,r){return!!(wr(n,t,e,i,r)||Fi(n,t,e,i,r[0],r[1])||Fi(n,t,e,i,r[0],r[3])||Fi(n,t,e,i,r[2],r[1])||Fi(n,t,e,i,r[2],r[3]))}function za(n,t,e,i,r){if(!Ga(n,t,e[0],i,r))return!1;if(e.length===1)return!0;for(let s=1,o=e.length;s<o;++s)if(nd(n,e[s-1],e[s],i,r)&&!wr(n,e[s-1],e[s],i,r))return!1;return!0}function od(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];if(za(n,t,a,i,r))return!0;t=a[a.length-1]}return!1}function ad(n,t,e,i){for(;t<e-i;){for(let r=0;r<i;++r){let s=n[t+r];n[t+r]=n[e-i+r],n[e-i+r]=s}t+=i,e-=i}}function ja(n,t,e,i){let r=0,s=n[e-i],o=n[e-i+1];for(;t<e;t+=i){let a=n[t],l=n[t+1];r+=(a-s)*(l+o),s=a,o=l}return r===0?void 0:r>0}function Sr(n,t,e,i,r){r=r!==void 0?r:!1;for(let s=0,o=e.length;s<o;++s){let a=e[s],l=ja(n,t,a,i);if(s===0){if(r&&l||!r&&!l)return!1}else if(r&&!l||!r&&l)return!1;t=a}return!0}function Ks(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];if(!Sr(n,t,a,i,r))return!1;a.length&&(t=a[a.length-1])}return!0}function Pn(n,t,e,i,r){r=r!==void 0?r:!1;for(let s=0,o=e.length;s<o;++s){let a=e[s],l=ja(n,t,a,i);(s===0?r&&l||!r&&!l:r&&!l||!r&&l)&&ad(n,t,a,i),t=a}return t}function Tr(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s)t=Pn(n,t,e[s],i,r);return t}function ld(n,t){let e=[],i=0,r=0,s;for(let o=0,a=t.length;o<a;++o){let l=t[o],c=ja(n,i,l,2);if(s===void 0&&(s=c),c===s)e.push(t.slice(r,o+1));else{if(e.length===0)continue;e[e.length-1].push(t[r])}r=o+1,i=l}return e}var Vs=class n extends Vt{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?It(this.flatCoordinates,t.getFlatCoordinates()):this.flatCoordinates=t.getFlatCoordinates().slice(),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(pr(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),yr(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!0,t,e,i,r))}containsXY(t,e){return Cr(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,e)}getArea(){return Fa(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),Pn(e,0,this.ends_,this.stride,t)):e=this.flatCoordinates,Ai(e,0,this.ends_,this.stride)}getEnds(){return this.ends_}getFlatInteriorPoint(){if(this.flatInteriorPointRevision_!=this.getRevision()){let t=St(this.getExtent());this.flatInteriorPoint_=Rr(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,0),this.flatInteriorPointRevision_=this.getRevision()}return this.flatInteriorPoint_}getInteriorPoint(){return new Oi(this.getFlatInteriorPoint(),"XYM")}getLinearRingCount(){return this.ends_.length}getLinearRing(t){return t<0||this.ends_.length<=t?null:new ka(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLinearRings(){let t=this.layout,e=this.flatCoordinates,i=this.ends_,r=[],s=0;for(let o=0,a=i.length;o<a;++o){let l=i[o],c=new ka(e.slice(s,l),t);r.push(c),s=l}return r}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){let t=this.flatCoordinates;Sr(t,0,this.ends_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=Pn(this.orientedFlatCoordinates_,0,this.ends_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){let e=[],i=[];return e.length=Er(this.flatCoordinates,0,this.ends_,this.stride,Math.sqrt(t),e,0,i),new n(e,"XY",i)}getType(){return"Polygon"}intersectsExtent(t){return za(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,2),this.flatCoordinates||(this.flatCoordinates=[]);let i=Li(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}},Di=Vs;function Wa(n){if(Yt(n))throw new Error("Cannot create polygon from empty extent");let t=n[0],e=n[1],i=n[2],r=n[3],s=[t,e,t,r,i,r,i,e,t,e];return new Vs(s,"XY",[s.length])}function Xa(n,t,e,i){let r=W(t)/e[0],s=et(t)/e[1];return i?Math.min(n,Math.max(r,s)):Math.min(n,Math.min(r,s))}function Ua(n,t,e){let i=Math.min(n,t),r=50;return i*=Math.log(1+r*Math.max(0,n/t-1))/r+1,e&&(i=Math.max(i,e),i/=Math.log(1+r*Math.max(0,e/n-1))/r+1),Q(i,e/2,t*2)}function hd(n,t,e,i){return t=t!==void 0?t:!0,(function(r,s,o,a){if(r!==void 0){let l=n[0],c=n[n.length-1],h=e?Xa(l,e,o,i):l;if(a)return t?Ua(r,h,c):Q(r,c,h);let u=Math.min(h,r),d=Math.floor(Ri(n,u,s));return n[d]>h&&d<n.length-1?n[d+1]:n[d]}})}function cd(n,t,e,i,r,s){return i=i!==void 0?i:!0,e=e!==void 0?e:0,(function(o,a,l,c){if(o!==void 0){let h=r?Xa(t,r,l,s):t;if(c)return i?Ua(o,h,e):Q(o,e,h);let u=1e-9,d=Math.ceil(Math.log(t/h)/Math.log(n)-u),f=-a*(.5-u)+.5,g=Math.min(h,o),p=Math.floor(Math.log(t/g)/Math.log(n)+f),m=Math.max(d,p),_=t/Math.pow(n,m);return Q(_,e,h)}})}function Ya(n,t,e,i,r){return e=e!==void 0?e:!0,(function(s,o,a,l){if(s!==void 0){let c=i?Xa(n,i,a,r):n;return!e||!l?Q(s,t,c):Ua(s,c,t)}})}function On(n){if(n!==void 0)return 0}function Ka(n){if(n!==void 0)return n}function ud(n){let 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 dd(n){let t=n===void 0?Re(5):n;return(function(e,i){return i||e===void 0?e:Math.abs(e)<=t?0:e})}var Va=0,Za=class extends pt{constructor(t){super(),this.on,this.once,this.un,t=Object.assign({},t),this.hints_=[0,0],this.animations_=[],this.updateAnimationKey_,this.projection_=ks(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&&ba(),t.center&&(t.center=Ie(t.center,this.projection_)),t.extent&&(t.extent=Gt(t.extent,this.projection_)),this.applyOptions_(t)}applyOptions_(t){let e=Object.assign({},t);for(let a in ae)delete e[a];this.setProperties(e,!0);let 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;let r=um(t),s=i.constraint,o=fm(t);this.constraints_={center:r,resolution:s,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;let i=this.getCenterInternal();if(i){let r=t||[0,0,0,0];e=e||[0,0,0,0];let s=this.getResolution(),o=s/2*(r[3]-e[3]+e[1]-r[1]),a=s/2*(r[0]-e[0]+e[2]-r[2]);this.setCenterInternal([i[0]+o,i[1]-a])}}getUpdatedOptions_(t){let 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);let e=new Array(arguments.length);for(let i=0;i<e.length;++i){let r=arguments[i];r.center&&(r=Object.assign({},r),r.center=Ie(r.center,this.getProjection())),r.anchor&&(r=Object.assign({},r),r.anchor=Ie(r.anchor,this.getProjection())),e[i]=r}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 r=0;for(;r<e&&!this.isDef();++r){let h=arguments[r];h.center&&this.setCenterInternal(h.center),h.zoom!==void 0?this.setZoom(h.zoom):h.resolution&&this.setResolution(h.resolution),h.rotation!==void 0&&this.setRotation(h.rotation)}if(r===e){i&&Bs(i,!0);return}let s=Date.now(),o=this.targetCenter_.slice(),a=this.targetResolution_,l=this.targetRotation_,c=[];for(;r<e;++r){let h=arguments[r],u={start:s,complete:!1,anchor:h.anchor,duration:h.duration!==void 0?h.duration:1e3,easing:h.easing||xu,callback:i};if(h.center&&(u.sourceCenter=o,u.targetCenter=h.center.slice(),o=u.targetCenter),h.zoom!==void 0?(u.sourceResolution=a,u.targetResolution=this.getResolutionForZoom(h.zoom),a=u.targetResolution):h.resolution&&(u.sourceResolution=a,u.targetResolution=h.resolution,a=u.targetResolution),h.rotation!==void 0){u.sourceRotation=l;let d=Wt(h.rotation-l+Math.PI,2*Math.PI)-Math.PI;u.targetRotation=l+d,l=u.targetRotation}gm(u)?u.complete=!0:s+=u.duration,c.push(u)}this.animations_.push(c),this.setHint(dt.ANIMATING,1),this.updateAnimations_()}getAnimating(){return this.hints_[dt.ANIMATING]>0}getInteracting(){return this.hints_[dt.INTERACTING]>0}cancelAnimations(){this.setHint(dt.ANIMATING,-this.hints_[dt.ANIMATING]);let t;for(let e=0,i=this.animations_.length;e<i;++e){let r=this.animations_[e];if(r[0].callback&&Bs(r[0].callback,!1),!t)for(let s=0,o=r.length;s<o;++s){let a=r[s];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;let t=Date.now(),e=!1;for(let i=this.animations_.length-1;i>=0;--i){let r=this.animations_[i],s=!0;for(let o=0,a=r.length;o<a;++o){let l=r[o];if(l.complete)continue;let c=t-l.start,h=l.duration>0?c/l.duration:1;h>=1?(l.complete=!0,h=1):s=!1;let u=l.easing(h);if(l.sourceCenter){let d=l.sourceCenter[0],f=l.sourceCenter[1],g=l.targetCenter[0],p=l.targetCenter[1];this.nextCenter_=l.targetCenter;let m=d+u*(g-d),_=f+u*(p-f);this.targetCenter_=[m,_]}if(l.sourceResolution&&l.targetResolution){let d=u===1?l.targetResolution:l.sourceResolution+u*(l.targetResolution-l.sourceResolution);if(l.anchor){let 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){let d=u===1?Wt(l.targetRotation+Math.PI,2*Math.PI)-Math.PI:l.sourceRotation+u*(l.targetRotation-l.sourceRotation);if(l.anchor){let 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(s){this.animations_[i]=null,this.setHint(dt.ANIMATING,-1),this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN;let o=r[0].callback;o&&Bs(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,r=this.getCenterInternal();return r!==void 0&&(i=[r[0]-e[0],r[1]-e[1]],Sn(i,t-this.getRotation()),gu(i,e)),i}calculateCenterZoom(t,e){let i,r=this.getCenterInternal(),s=this.getResolution();if(r!==void 0&&s!==void 0){let o=e[0]-t*(e[0]-r[0])/s,a=e[1]-t*(e[1]-r[1])/s;i=[o,a]}return i}getViewportSize_(t){let e=this.viewportSize_;if(t){let i=e[0],r=e[1];return[Math.abs(i*Math.cos(t))+Math.abs(r*Math.sin(t)),Math.abs(i*Math.sin(t))+Math.abs(r*Math.cos(t))]}return e}setViewportSize(t){this.viewportSize_=Array.isArray(t)?t.slice():[100,100],this.getAnimating()||this.resolveConstraints(0)}getCenter(){let t=this.getCenterInternal();return t&&gr(t,this.getProjection())}getCenterInternal(){return this.get(ae.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){let e=this.calculateExtentInternal(t);return Mi(e,this.getProjection())}calculateExtentInternal(t){t=t||this.getViewportSizeMinusPadding_();let e=this.getCenterInternal();V(e,"The view center is not defined");let i=this.getResolution();V(i!==void 0,"The view resolution is not defined");let r=this.getRotation();return V(r!==void 0,"The view rotation is not defined"),oi(e,i,r,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(ae.RESOLUTION)}getResolutions(){return this.resolutions_}getResolutionForExtent(t,e){return this.getResolutionForExtentInternal(Gt(t,this.getProjection()),e)}getResolutionForExtentInternal(t,e){e=e||this.getViewportSizeMinusPadding_();let i=W(t)/e[0],r=et(t)/e[1];return Math.max(i,r)}getResolutionForValueFunction(t){t=t||2;let e=this.getConstrainedResolution(this.maxResolution_),i=this.minResolution_,r=Math.log(e/i)/Math.log(t);return(function(s){return e/Math.pow(t,s*r)})}getRotation(){return this.get(ae.ROTATION)}getValueForResolutionFunction(t){let e=Math.log(t||2),i=this.getConstrainedResolution(this.maxResolution_),r=this.minResolution_,s=Math.log(i/r)/e;return(function(o){return Math.log(i/o)/e/s})}getViewportSizeMinusPadding_(t){let e=this.getViewportSize_(t),i=this.padding_;return i&&(e=[e[0]-i[1]-i[3],e[1]-i[0]-i[2]]),e}getState(){let t=this.getProjection(),e=this.getResolution(),i=this.getRotation(),r=this.getCenterInternal(),s=this.padding_;if(s){let o=this.getViewportSizeMinusPadding_();r=Ba(r,this.getViewportSize_(),[o[0]/2+s[3],o[1]/2+s[0]],e,i)}return{center:r.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,e=this.getResolution();return e!==void 0&&(t=this.getZoomForResolution(e)),t}getZoomForResolution(t){let e=this.minZoom_||0,i,r;if(this.resolutions_){let s=Ri(this.resolutions_,t,1);e=s,i=this.resolutions_[s],s==this.resolutions_.length-1?r=2:r=i/this.resolutions_[s+1]}else i=this.maxResolution_,r=this.zoomFactor_;return e+Math.log(i/t)/Math.log(r)}getResolutionForZoom(t){if(this.resolutions_?.length){if(this.resolutions_.length===1)return this.resolutions_[0];let e=Q(Math.floor(t),0,this.resolutions_.length-2),i=this.resolutions_[e]/this.resolutions_[e+1];return this.resolutions_[e]/Math.pow(i,Q(t-e,0,1))}return this.maxResolution_/Math.pow(this.zoomFactor_,t-this.minZoom_)}fit(t,e){let i;if(V(Array.isArray(t)||typeof t.getSimplifiedGeometry=="function","Invalid extent or geometry provided as `geometry`"),Array.isArray(t)){V(!Yt(t),"Cannot fit empty extent provided as `geometry`");let r=Gt(t,this.getProjection());i=Wa(r)}else if(t.getType()==="Circle"){let r=Gt(t.getExtent(),this.getProjection());i=Wa(r),i.rotate(this.getRotation(),St(r))}else{let r=hi();r?i=t.clone().transform(r,this.getProjection()):i=t}this.fitInternal(i,e)}rotatedExtentForGeometry(t){let e=this.getRotation(),i=Math.cos(e),r=Math.sin(-e),s=t.getFlatCoordinates(),o=t.getStride(),a=1/0,l=1/0,c=-1/0,h=-1/0;for(let u=0,d=s.length;u<d;u+=o){let f=s[u]*i-s[u+1]*r,g=s[u]*r+s[u+1]*i;a=Math.min(a,f),l=Math.min(l,g),c=Math.max(c,f),h=Math.max(h,g)}return[a,l,c,h]}fitInternal(t,e){e=e||{};let i=e.size;i||(i=this.getViewportSizeMinusPadding_());let r=e.padding!==void 0?e.padding:[0,0,0,0],s=e.nearest!==void 0?e.nearest:!1,o;e.minResolution!==void 0?o=e.minResolution:e.maxZoom!==void 0?o=this.getResolutionForZoom(e.maxZoom):o=0;let a=this.rotatedExtentForGeometry(t),l=this.getResolutionForExtentInternal(a,[i[0]-r[1]-r[3],i[1]-r[0]-r[2]]);l=isNaN(l)?o:Math.max(l,o),l=this.getConstrainedResolution(l,s?0:1);let c=this.getRotation(),h=Math.sin(c),u=Math.cos(c),d=St(a);d[0]+=(r[1]-r[3])/2*l,d[1]+=(r[0]-r[2])/2*l;let f=d[0]*u-d[1]*h,g=d[1]*u+d[0]*h,p=this.getConstrainedCenter([f,g],l),m=e.callback?e.callback:ni;e.duration!==void 0?this.animateInternal({resolution:l,center:p,duration:e.duration,easing:e.easing},m):(this.targetResolution_=l,this.targetCenter_=p,this.applyTargetState_(!1,!0),Bs(m,!0))}centerOn(t,e,i){this.centerOnInternal(Ie(t,this.getProjection()),e,i)}centerOnInternal(t,e,i){this.setCenterInternal(Ba(t,e,i,this.getResolution(),this.getRotation()))}calculateCenterShift(t,e,i,r){let s,o=this.padding_;if(o&&t){let a=this.getViewportSizeMinusPadding_(-i),l=Ba(t,r,[a[0]/2+o[3],a[1]/2+o[0]],e,i);s=[t[0]-l[0],t[1]-l[1]]}return s}isDef(){return!!this.getCenterInternal()&&this.getResolution()!==void 0}adjustCenter(t){let e=gr(this.targetCenter_,this.getProjection());this.setCenter([e[0]+t[0],e[1]+t[1]])}adjustCenterInternal(t){let e=this.targetCenter_;this.setCenterInternal([e[0]+t[0],e[1]+t[1]])}adjustResolution(t,e){e=e&&Ie(e,this.getProjection()),this.adjustResolutionInternal(t,e)}adjustResolutionInternal(t,e){let i=this.getAnimating()||this.getInteracting(),r=this.getViewportSize_(this.getRotation()),s=this.constraints_.resolution(this.targetResolution_*t,0,r,i);e&&(this.targetCenter_=this.calculateCenterZoom(s,e)),this.targetResolution_*=t,this.applyTargetState_()}adjustZoom(t,e){this.adjustResolution(Math.pow(this.zoomFactor_,-t),e)}adjustRotation(t,e){e&&(e=Ie(e,this.getProjection())),this.adjustRotationInternal(t,e)}adjustRotationInternal(t,e){let i=this.getAnimating()||this.getInteracting(),r=this.constraints_.rotation(this.targetRotation_+t,i);e&&(this.targetCenter_=this.calculateCenterRotate(r,e)),this.targetRotation_+=t,this.applyTargetState_()}setCenter(t){this.setCenterInternal(t&&Ie(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){let i=this.getAnimating()||this.getInteracting()||e,r=this.constraints_.rotation(this.targetRotation_,i),s=this.getViewportSize_(r),o=this.constraints_.resolution(this.targetResolution_,0,s,i),a=this.constraints_.center(this.targetCenter_,o,s,i,this.calculateCenterShift(this.targetCenter_,o,r,s));this.get(ae.ROTATION)!==r&&this.set(ae.ROTATION,r),this.get(ae.RESOLUTION)!==o&&(this.set(ae.RESOLUTION,o),this.set("zoom",this.getZoom(),!0)),(!a||!this.get(ae.CENTER)||!tn(this.get(ae.CENTER),a))&&this.set(ae.CENTER,a),this.getAnimating()&&!t&&this.cancelAnimations(),this.cancelAnchor_=void 0}resolveConstraints(t,e,i){t=t!==void 0?t:200;let r=e||0,s=this.constraints_.rotation(this.targetRotation_),o=this.getViewportSize_(s),a=this.constraints_.resolution(this.targetResolution_,r,o),l=this.constraints_.center(this.targetCenter_,a,o,!1,this.calculateCenterShift(this.targetCenter_,a,s,o));if(t===0&&!this.cancelAnchor_){this.targetResolution_=a,this.targetRotation_=s,this.targetCenter_=l,this.applyTargetState_();return}i=i||(t===0?this.cancelAnchor_:void 0),this.cancelAnchor_=void 0,(this.getResolution()!==a||this.getRotation()!==s||!this.getCenterInternal()||!tn(this.getCenterInternal(),l))&&(this.getAnimating()&&this.cancelAnimations(),this.animateInternal({rotation:s,center:l,resolution:a,duration:t,easing:ce,anchor:i}))}beginInteraction(){this.resolveConstraints(0),this.setHint(dt.INTERACTING,1)}endInteraction(t,e,i){i=i&&Ie(i,this.getProjection()),this.endInteractionInternal(t,e,i)}endInteractionInternal(t,e,i){this.getInteracting()&&(this.setHint(dt.INTERACTING,-1),this.resolveConstraints(t,e,i))}getConstrainedCenter(t,e){let i=this.getViewportSize_(this.getRotation());return this.constraints_.center(t,e||this.getResolution(),i)}getConstrainedZoom(t,e){let i=this.getResolutionForZoom(t);return this.getZoomForResolution(this.getConstrainedResolution(i,e))}getConstrainedResolution(t,e){e=e||0;let i=this.getViewportSize_(this.getRotation());return this.constraints_.resolution(t,e,i)}};function Bs(n,t){setTimeout(function(){n(t)},0)}function um(n){if(n.extent!==void 0){let e=n.smoothExtentConstraint!==void 0?n.smoothExtentConstraint:!0;return fa(n.extent,n.constrainOnlyCenter,e)}let t=ks(n.projection,"EPSG:3857");if(n.multiWorld!==!0&&t.isGlobal()){let e=t.getExtent().slice();return e[0]=-1/0,e[2]=1/0,fa(e,!1,!1)}return hu}function dm(n){let t,e,i,o=n.minZoom!==void 0?n.minZoom:Va,a=n.maxZoom!==void 0?n.maxZoom:28,l=n.zoomFactor!==void 0?n.zoomFactor:2,c=n.multiWorld!==void 0?n.multiWorld:!1,h=n.smoothResolutionConstraint!==void 0?n.smoothResolutionConstraint:!0,u=n.showFullExtent!==void 0?n.showFullExtent:!1,d=ks(n.projection,"EPSG:3857"),f=d.getExtent(),g=n.constrainOnlyCenter,p=n.extent;if(!c&&!p&&d.isGlobal()&&(g=!1,p=f),n.resolutions!==void 0){let m=n.resolutions;e=m[o],i=m[a]!==void 0?m[a]:m[m.length-1],n.constrainResolution?t=hd(m,h,!g&&p,u):t=Ya(e,i,h,!g&&p,u)}else{let _=(f?Math.max(W(f),et(f)):360*Se.degrees/d.getMetersPerUnit())/256/Math.pow(2,Va),y=_/Math.pow(2,28-Va);e=n.maxResolution,e!==void 0?o=0:e=_/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=_/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=cd(l,e,i,h,!g&&p,u):t=Ya(e,i,h,!g&&p,u)}return{constraint:t,maxResolution:e,minResolution:i,minZoom:o,zoomFactor:l}}function fm(n){if(n.enableRotation!==void 0?n.enableRotation:!0){let e=n.constrainRotation;return e===void 0||e===!0?dd():e===!1?Ka:typeof e=="number"?ud(e):Ka}return On}function gm(n){return!(n.sourceCenter&&n.targetCenter&&!tn(n.sourceCenter,n.targetCenter)||n.sourceResolution!==n.targetResolution||n.sourceRotation!==n.targetRotation)}function Ba(n,t,e,i,r){let s=Math.cos(-r),o=Math.sin(-r),a=n[0]*s-n[1]*o,l=n[1]*s+n[0]*o;a+=(t[0]/2-e[0])*i,l+=(e[1]-t[1]/2)*i,o=-o;let c=a*s-l*o,h=l*s+a*o;return[c,h]}var Bt=Za;var vr="ol-hidden";var ge="ol-unselectable",Ha="ol-unsupported",ki="ol-control",qa="ol-collapsed",mm=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"),gd=["style","variant","weight","size","lineHeight","family"],Zs={normal:400,bold:700},Hs=function(n){let t=n.match(mm);if(!t)return null;let e={lineHeight:"normal",size:"1.2em",style:"normal",weight:"400",variant:"normal"};for(let i=0,r=gd.length;i<r;++i){let s=t[i+1];s!==void 0&&(e[gd[i]]=typeof s=="string"?s.trim():s)}return isNaN(Number(e.weight))&&e.weight in Zs&&(e.weight=Zs[e.weight]),e.families=e.family.split(/,\s?/).map(i=>i.trim().replace(/^['"]|['"]$/g,"")),e};function nt(n,t,e,i){let r;return e&&e.length?r=e.shift():xt?r=new class extends OffscreenCanvas{style={}}(n??300,t??150):r=document.createElement("canvas"),n&&(r.width=n),t&&(r.height=t),r.getContext("2d",i)}var $a;function Fn(){return $a||($a=nt(1,1)),$a}function on(n){let t=n.canvas;t.width=1,t.height=1,n.clearRect(0,0,1,1)}function Dn(n,t){let e=t.parentNode;e&&e.replaceChild(n,t)}function md(n){for(;n.lastChild;)n.lastChild.remove()}function pd(n,t){let e=n.childNodes;for(let i=0;;++i){let r=e[i],s=t[i];if(!r&&!s)break;if(r!==s){if(!r){n.appendChild(s);continue}if(!s){n.removeChild(r),--i;continue}n.insertBefore(s,r)}}}function qs(){return new Proxy({childNodes:[],appendChild:function(t){return this.childNodes.push(t),t},remove:function(){},removeChild:function(t){let 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){let 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 Me(n){return typeof HTMLCanvasElement<"u"&&n instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&n instanceof OffscreenCanvas}var Ja=class extends pt{constructor(t){super();let 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)B(this.listenerKeys[e]);if(this.listenerKeys.length=0,this.map_=t,t){let e=this.target_??t.getOverlayContainerStopEvent();this.element&&e.appendChild(this.element),this.render!==ni&&this.listenerKeys.push(G(t,Xe.POSTRENDER,this.render,this)),t.render()}}render(t){}setTarget(t){this.target_=typeof t=="string"?document.getElementById(t):t}},me=Ja;var Qa=class extends me{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;let e=t.className!==void 0?t.className:"ol-attribution",i=t.tipLabel!==void 0?t.tipLabel:"Attributions",r=t.expandClassName!==void 0?t.expandClassName:e+"-expand",s=t.collapseLabel!==void 0?t.collapseLabel:"\u203A",o=t.collapseClassName!==void 0?t.collapseClassName:e+"-collapse";typeof s=="string"?(this.collapseLabel_=document.createElement("span"),this.collapseLabel_.textContent=s,this.collapseLabel_.className=o):this.collapseLabel_=s;let a=t.label!==void 0?t.label:"i";typeof a=="string"?(this.label_=document.createElement("span"),this.label_.textContent=a,this.label_.className=r):this.label_=a;let 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(L.CLICK,this.handleClick_.bind(this),!1);let c=e+" "+ge+" "+ki+(this.collapsed_&&this.collapsible_?" "+qa:"")+(this.collapsible_?"":" ol-uncollapsible"),h=this.element;h.className=c,h.appendChild(this.toggleButton_),h.appendChild(this.ulElement_),this.renderedAttributions_=[],this.renderedVisible_=!0}collectSourceAttributions_(t){let e=this.getMap().getAllLayers(),i=new Set(e.flatMap(r=>r.getAttributions(t)));if(this.attributions_!==void 0&&(Array.isArray(this.attributions_)?this.attributions_.forEach(r=>i.add(r)):i.add(this.attributions_)),!this.overrideCollapsible_){let r=!e.some(s=>s.getSource()?.getAttributionsCollapsible()===!1);this.setCollapsible(r)}return Array.from(i)}async updateElement_(t){if(!t){this.renderedVisible_&&(this.element.style.display="none",this.renderedVisible_=!1);return}let e=await Promise.all(this.collectSourceAttributions_(t).map(r=>ps(()=>r))),i=e.length>0;if(this.renderedVisible_!=i&&(this.element.style.display=i?"":"none",this.renderedVisible_=i),!Ot(e,this.renderedAttributions_)){md(this.ulElement_);for(let r=0,s=e.length;r<s;++r){let o=document.createElement("li");o.innerHTML=e[r],this.ulElement_.appendChild(o)}this.renderedAttributions_=e}}handleClick_(t){t.preventDefault(),this.handleToggle_(),this.userCollapsed_=this.collapsed_}handleToggle_(){this.element.classList.toggle(qa),this.collapsed_?Dn(this.collapseLabel_,this.label_):Dn(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)}},Ir=Qa;var tl=class extends me{constructor(t){t=t||{},super({element:document.createElement("div"),render:t.render,target:t.target});let e=t.className!==void 0?t.className:"ol-rotate",i=t.label!==void 0?t.label:"\u21E7",r=t.compassClassName!==void 0?t.compassClassName:"ol-compass";this.label_=null,typeof i=="string"?(this.label_=document.createElement("span"),this.label_.className=r,this.label_.textContent=i):(this.label_=i,this.label_.classList.add(r));let s=t.tipLabel?t.tipLabel:"Reset rotation",o=document.createElement("button");o.className=e+"-reset",o.setAttribute("type","button"),o.title=s,o.appendChild(this.label_),o.addEventListener(L.CLICK,this.handleClick_.bind(this),!1);let a=e+" "+ge+" "+ki,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(vr)}handleClick_(t){t.preventDefault(),this.callResetNorth_!==void 0?this.callResetNorth_():this.resetNorth_()}resetNorth_(){let e=this.getMap().getView();if(!e)return;let i=e.getRotation();i!==void 0&&(this.duration_>0&&i%(2*Math.PI)!==0?e.animate({rotation:0,duration:this.duration_,easing:ce}):e.setRotation(0))}render(t){let e=t.frameState;if(!e)return;let i=e.viewState.rotation;if(i!=this.rotation_){let r="rotate("+i+"rad)";if(this.autoHide_){let s=this.element.classList.contains(vr);!s&&i===0?this.element.classList.add(vr):s&&i!==0&&this.element.classList.remove(vr)}this.label_.style.transform=r}this.rotation_=i}},Mr=tl;var el=class extends me{constructor(t){t=t||{},super({element:document.createElement("div"),target:t.target});let e=t.className!==void 0?t.className:"ol-zoom",i=t.delta!==void 0?t.delta:1,r=t.zoomInClassName!==void 0?t.zoomInClassName:e+"-in",s=t.zoomOutClassName!==void 0?t.zoomOutClassName:e+"-out",o=t.zoomInLabel!==void 0?t.zoomInLabel:"+",a=t.zoomOutLabel!==void 0?t.zoomOutLabel:"\u2013",l=t.zoomInTipLabel!==void 0?t.zoomInTipLabel:"Zoom in",c=t.zoomOutTipLabel!==void 0?t.zoomOutTipLabel:"Zoom out",h=document.createElement("button");h.className=r,h.setAttribute("type","button"),h.title=l,h.appendChild(typeof o=="string"?document.createTextNode(o):o),h.addEventListener(L.CLICK,this.handleClick_.bind(this,i),!1);let u=document.createElement("button");u.className=s,u.setAttribute("type","button"),u.title=c,u.appendChild(typeof a=="string"?document.createTextNode(a):a),u.addEventListener(L.CLICK,this.handleClick_.bind(this,-i),!1);let d=e+" "+ge+" "+ki,f=this.element;f.className=d,f.appendChild(h),f.appendChild(u),this.duration_=t.duration!==void 0?t.duration:250}handleClick_(t,e){e.preventDefault(),this.zoomByDelta_(t)}zoomByDelta_(t){let i=this.getMap().getView();if(!i)return;let r=i.getZoom();if(r!==void 0){let s=i.getConstrainedZoom(r+t);this.duration_>0?(i.getAnimating()&&i.cancelAnimations(),i.animate({zoom:s,duration:this.duration_,easing:ce})):i.setZoom(s)}}},br=el;function kn(n){n=n||{};let t=new Mt;return(n.zoom===void 0||n.zoom)&&t.push(new br(n.zoomOptions)),(n.rotate===void 0||n.rotate)&&t.push(new Mr(n.rotateOptions)),(n.attribution===void 0||n.attribution)&&t.push(new Ir(n.attributionOptions)),t}var il=class{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;let 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;let r=this.points_[e+2]-this.points_[i+2];if(r<1e3/60)return!1;let s=this.points_[e]-this.points_[i],o=this.points_[e+1]-this.points_[i+1];return this.angle_=Math.atan2(o,s),this.initialVelocity_=Math.sqrt(s*s+o*o)/r,this.initialVelocity_>this.minVelocity_}getDistance(){return(this.minVelocity_-this.initialVelocity_)/this.decay_}getAngle(){return this.angle_}},_d=il;var nl={ACTIVE:"active"};var rl=class extends pt{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(nl.ACTIVE)}getMap(){return this.map_}handleEvent(t){return!0}setActive(t){this.set(nl.ACTIVE,t)}setMap(t){this.map_=t}};function yd(n,t,e){let i=n.getCenterInternal();if(i){let r=[i[0]+t[0],i[1]+t[1]];n.animateInternal({duration:e!==void 0?e:250,easing:Eu,center:n.getConstrainedCenter(r)})}}function Nn(n,t,e,i){let r=n.getZoom();if(r===void 0)return;let s=n.getConstrainedZoom(r+t),o=n.getResolutionForZoom(s);n.getAnimating()&&n.cancelAnimations(),n.animate({resolution:o,anchor:e,duration:i!==void 0?i:250,easing:ce})}var Ke=rl;var sl=class extends Ke{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){let i=t.originalEvent,r=t.map,s=t.coordinate,o=i.shiftKey?-this.delta_:this.delta_,a=r.getView();Nn(a,o,s,this.duration_),i.preventDefault(),e=!0}return!e}},xd=sl;function Lr(n){let t=arguments;return function(e){let i=!0;for(let r=0,s=t.length;r<s&&(i=i&&t[r](e),!!i);++r);return i}}var Ed=function(n){let t=n.originalEvent;return t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},pm=function(n){let t=n.map.getTargetElement(),e=t.getRootNode(),i=n.map.getOwnerDocument().activeElement;return e instanceof ShadowRoot?e.host.contains(i):t.contains(i)},$s=function(n){let t=n.map.getTargetElement(),e=t.getRootNode();return(e instanceof ShadowRoot?e.host:t).hasAttribute("tabindex")?pm(n):!0},Cd=ei;var Js=function(n){let t=n.originalEvent;return"pointerId"in t&&t.button==0&&!(eu&&aa&&t.ctrlKey)};var Qs=function(n){let t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&!t.shiftKey};var Rd=function(n){let t=n.originalEvent;return aa?t.metaKey:t.ctrlKey},to=function(n){let t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},eo=function(n){let t=n.originalEvent,e=t.target.tagName;return e!=="INPUT"&&e!=="SELECT"&&e!=="TEXTAREA"&&!t.target.isContentEditable},Ni=function(n){let t=n.originalEvent;return"pointerId"in t&&t.pointerType=="mouse"};var wd=function(n){let t=n.originalEvent;return"pointerId"in t&&t.isPrimary&&t.button===0};var ol=class extends Ke{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){let i=this.handleUpEvent(t);this.handlingDownUpSequence=i&&this.targetPointers.length>0}}else if(t.type==at.POINTERDOWN){let 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 Gn(n){let t=n.length,e=0,i=0;for(let r=0;r<t;r++)e+=n[r].clientX,i+=n[r].clientY;return{clientX:e/t,clientY:i/t}}var pe=ol;var al=class extends pe{constructor(t){super({stopDown:ii}),t=t||{},this.kinetic_=t.kinetic,this.lastCentroid=null,this.lastPointersCount_,this.panning_=!1;let e=t.condition?t.condition:Lr(Qs,wd);this.condition_=t.onFocusOnly?Lr($s,e):e,this.noKinetic_=!1}handleDragEvent(t){let e=t.map;this.panning_||(this.panning_=!0,e.getView().beginInteraction());let i=this.targetPointers,r=e.getEventPixel(Gn(i));if(i.length==this.lastPointersCount_){if(this.kinetic_&&this.kinetic_.update(r[0],r[1]),this.lastCentroid){let s=[this.lastCentroid[0]-r[0],r[1]-this.lastCentroid[1]],a=t.map.getView();pu(s,a.getResolution()),Sn(s,a.getRotation()),a.adjustCenterInternal(s)}}else this.kinetic_&&this.kinetic_.begin();this.lastCentroid=r,this.lastPointersCount_=i.length,t.originalEvent.preventDefault()}handleUpEvent(t){let e=t.map,i=e.getView();if(this.targetPointers.length===0){if(!this.noKinetic_&&this.kinetic_&&this.kinetic_.end()){let r=this.kinetic_.getDistance(),s=this.kinetic_.getAngle(),o=i.getCenterInternal(),a=e.getPixelFromCoordinateInternal(o),l=e.getCoordinateFromPixelInternal([a[0]-r*Math.cos(s),a[1]-r*Math.sin(s)]);i.animateInternal({center:i.getConstrainedCenter(l),duration:500,easing:ce})}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)){let 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}},Sd=al;var ll=class extends pe{constructor(t){t=t||{},super({stopDown:ii}),this.condition_=t.condition?t.condition:Ed,this.lastAngle_=void 0,this.duration_=t.duration!==void 0?t.duration:250}handleDragEvent(t){if(!Ni(t))return;let e=t.map,i=e.getView();if(i.getConstraints().rotation===On)return;let r=e.getSize(),s=t.pixel,o=Math.atan2(r[1]/2-s[1],s[0]-r[0]/2);if(this.lastAngle_!==void 0){let a=o-this.lastAngle_;i.adjustRotationInternal(-a)}this.lastAngle_=o}handleUpEvent(t){return Ni(t)?(t.map.getView().endInteraction(this.duration_),!1):!0}handleDownEvent(t){return Ni(t)&&Js(t)&&this.condition_(t)?(t.map.getView().beginInteraction(),this.lastAngle_=void 0,!0):!1}},Td=ll;var hl=class extends Ci{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_(){let t=this.startPixel_,e=this.endPixel_,i="px",r=this.element_.style;r.left=Math.min(t[0],e[0])+i,r.top=Math.min(t[1],e[1])+i,r.width=Math.abs(e[0]-t[0])+i,r.height=Math.abs(e[1]-t[1])+i}setMap(t){if(this.map_){this.map_.getOverlayContainer().removeChild(this.element_);let 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;let t=this.startPixel_,e=this.endPixel_,r=[t,[t[0],e[1]],e,[e[0],t[1]]].map(this.map_.getCoordinateFromPixelInternal,this.map_);r[4]=r[0].slice(),this.geometry_?this.geometry_.setCoordinates([r]):this.geometry_=new Di([r])}getGeometry(){return this.geometry_}},vd=hl;var zn={BOXSTART:"boxstart",BOXDRAG:"boxdrag",BOXEND:"boxend",BOXCANCEL:"boxcancel"},an=class extends mt{constructor(t,e,i){super(t),this.coordinate=e,this.mapBrowserEvent=i}},cl=class extends pe{constructor(t){super(),this.on,this.once,this.un,t=t??{},this.box_=new vd(t.className||"ol-dragbox"),this.minArea_=t.minArea??64,t.onBoxEnd&&(this.onBoxEnd=t.onBoxEnd),this.startPixel_=null,this.condition_=t.condition??Js,this.boxEndCondition_=t.boxEndCondition??this.defaultBoxEndCondition}defaultBoxEndCondition(t,e,i){let r=i[0]-e[0],s=i[1]-e[1];return r*r+s*s>=this.minArea_}getGeometry(){return this.box_.getGeometry()}handleDragEvent(t){this.startPixel_&&(this.box_.setPixels(this.startPixel_,t.pixel),this.dispatchEvent(new an(zn.BOXDRAG,t.coordinate,t)))}handleUpEvent(t){if(!this.startPixel_)return!1;let e=this.boxEndCondition_(t,this.startPixel_,t.pixel);return e&&this.onBoxEnd(t),this.dispatchEvent(new an(e?zn.BOXEND:zn.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 an(zn.BOXSTART,t.coordinate,t)),!0):!1}onBoxEnd(t){}setActive(t){t||(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new an(zn.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setActive(t)}setMap(t){this.getMap()&&(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new an(zn.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setMap(t)}},Id=cl;var ul=class extends Id{constructor(t){t=t||{};let e=t.condition?t.condition:to;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){let i=this.getMap().getView(),r=this.getGeometry();if(this.out_){let s=i.rotatedExtentForGeometry(r),o=i.getResolutionForExtentInternal(s),a=i.getResolution()/o;r=r.clone(),r.scale(a*a)}i.fitInternal(r,{duration:this.duration_,easing:ce})}},Md=ul;var Gi={LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",DOWN:"ArrowDown"};var dl=class extends Ke{constructor(t){super(),t=t||{},this.defaultCondition_=function(e){return Qs(e)&&eo(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==L.KEYDOWN){let i=t.originalEvent,r=i.key;if(this.condition_(t)&&(r==Gi.DOWN||r==Gi.LEFT||r==Gi.RIGHT||r==Gi.UP)){let o=t.map.getView(),a=o.getResolution()*this.pixelDelta_,l=0,c=0;r==Gi.DOWN?c=-a:r==Gi.LEFT?l=-a:r==Gi.RIGHT?l=a:c=a;let h=[l,c];Sn(h,o.getRotation()),yd(o,h,this.duration_),i.preventDefault(),e=!0}}return!e}},bd=dl;var fl=class extends Ke{constructor(t){super(),t=t||{},this.condition_=t.condition?t.condition:function(e){return!Rd(e)&&eo(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==L.KEYDOWN||t.type==L.KEYPRESS){let i=t.originalEvent,r=i.key;if(this.condition_(t)&&(r==="+"||r==="-")){let s=t.map,o=r==="+"?this.delta_:-this.delta_,a=s.getView();Nn(a,o,void 0,this.duration_),i.preventDefault(),e=!0}}return!e}},Ld=fl;var _m=40,ym=300,gl=class extends Ke{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;let e=t.condition?t.condition:Cd;this.condition_=t.onFocusOnly?Lr($s,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;let 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!==L.WHEEL)return!0;let i=t.map,r=t.originalEvent;r.preventDefault(),this.useAnchor_&&(this.lastAnchor_=t.pixel);let s=r.deltaY;switch(r.deltaMode){case WheelEvent.DOM_DELTA_LINE:s*=_m;break;case WheelEvent.DOM_DELTA_PAGE:s*=ym;break;default:}if(s===0)return!1;this.lastDelta_=s;let o=Date.now();this.startTime_===void 0&&(this.startTime_=o),(!this.mode_||o-this.startTime_>this.trackpadEventGap_)&&(this.mode_=Math.abs(s)<4?"trackpad":"wheel");let 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(-s/this.deltaPerZoom_,this.lastAnchor_?i.getCoordinateFromPixel(this.lastAnchor_):null),this.startTime_=o,!1;this.totalDelta_+=s;let 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){let e=t.getView();e.getAnimating()&&e.cancelAnimations();let i=-Q(this.totalDelta_,-this.maxDelta_*this.deltaPerZoom_,this.maxDelta_*this.deltaPerZoom_)/this.deltaPerZoom_;(e.getConstrainResolution()||this.constrainResolution_)&&(i=i?i>0?1:-1:0),Nn(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)}},Ad=gl;var ml=class extends pe{constructor(t){t=t||{};let e=t;e.stopDown||(e.stopDown=ii),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,i=this.targetPointers[0],r=this.targetPointers[1],s=Math.atan2(r.clientY-i.clientY,r.clientX-i.clientX);if(this.lastAngle_!==void 0){let l=s-this.lastAngle_;this.rotationDelta_+=l,!this.rotating_&&Math.abs(this.rotationDelta_)>this.threshold_&&(this.rotating_=!0),e=l}this.lastAngle_=s;let o=t.map,a=o.getView();a.getConstraints().rotation!==On&&(this.anchor_=o.getCoordinateFromPixelInternal(o.getEventPixel(Gn(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){let 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}},Pd=ml;var pl=class extends pe{constructor(t){t=t||{};let e=t;e.stopDown||(e.stopDown=ii),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,i=this.targetPointers[0],r=this.targetPointers[1],s=i.clientX-r.clientX,o=i.clientY-r.clientY,a=Math.sqrt(s*s+o*o);this.lastDistance_!==void 0&&(e=this.lastDistance_/a),this.lastDistance_=a;let l=t.map,c=l.getView();e!=1&&(this.lastScaleDelta_=e),this.anchor_=l.getCoordinateFromPixelInternal(l.getEventPixel(Gn(this.targetPointers))),l.render(),c.adjustResolutionInternal(e,this.anchor_)}handleUpEvent(t){if(this.targetPointers.length<2){let i=t.map.getView(),r=this.lastScaleDelta_>1?1:-1;return i.endInteraction(this.duration_,r),!1}return!0}handleDownEvent(t){if(this.targetPointers.length>=2){let e=t.map;return this.anchor_=null,this.lastDistance_=void 0,this.lastScaleDelta_=1,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}},Od=pl;function jn(n){n=n||{};let t=new Mt,e=new _d(-.005,.05,100);return(n.altShiftDragRotate===void 0||n.altShiftDragRotate)&&t.push(new Td),(n.doubleClickZoom===void 0||n.doubleClickZoom)&&t.push(new xd({delta:n.zoomDelta,duration:n.zoomDuration})),(n.dragPan===void 0||n.dragPan)&&t.push(new Sd({onFocusOnly:n.onFocusOnly,kinetic:e})),(n.pinchRotate===void 0||n.pinchRotate)&&t.push(new Pd),(n.pinchZoom===void 0||n.pinchZoom)&&t.push(new Od({duration:n.zoomDuration})),(n.keyboard===void 0||n.keyboard)&&(t.push(new bd),t.push(new Ld({delta:n.zoomDelta,duration:n.zoomDuration}))),(n.mouseWheelZoom===void 0||n.mouseWheelZoom)&&t.push(new Ad({onFocusOnly:n.onFocusOnly,duration:n.zoomDuration})),(n.shiftDragZoom===void 0||n.shiftDragZoom)&&t.push(new Md({duration:n.zoomDuration})),t}var rt={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"};var _l=class extends pt{constructor(t){super(),this.on,this.once,this.un,this.background_=t.background;let e=Object.assign({},t);typeof t.properties=="object"&&(delete e.properties,Object.assign(e,t.properties)),e[rt.OPACITY]=t.opacity!==void 0?t.opacity:1,V(typeof e[rt.OPACITY]=="number","Layer opacity must be a number"),e[rt.VISIBLE]=t.visible!==void 0?t.visible:!0,e[rt.Z_INDEX]=t.zIndex,e[rt.MAX_RESOLUTION]=t.maxResolution!==void 0?t.maxResolution:1/0,e[rt.MIN_RESOLUTION]=t.minResolution!==void 0?t.minResolution:0,e[rt.MIN_ZOOM]=t.minZoom!==void 0?t.minZoom:-1/0,e[rt.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){let e=this.state_||{layer:this,managed:t===void 0?!0:t},i=this.getZIndex();return e.opacity=Q(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 F()}getLayerStatesArray(t){return F()}getExtent(){return this.get(rt.EXTENT)}getMaxResolution(){return this.get(rt.MAX_RESOLUTION)}getMinResolution(){return this.get(rt.MIN_RESOLUTION)}getMinZoom(){return this.get(rt.MIN_ZOOM)}getMaxZoom(){return this.get(rt.MAX_ZOOM)}getOpacity(){return this.get(rt.OPACITY)}getSourceState(){return F()}getVisible(){return this.get(rt.VISIBLE)}getZIndex(){return this.get(rt.Z_INDEX)}setBackground(t){this.background_=t,this.changed()}setExtent(t){this.set(rt.EXTENT,t)}setMaxResolution(t){this.set(rt.MAX_RESOLUTION,t)}setMinResolution(t){this.set(rt.MIN_RESOLUTION,t)}setMaxZoom(t){this.set(rt.MAX_ZOOM,t)}setMinZoom(t){this.set(rt.MIN_ZOOM,t)}setOpacity(t){V(typeof t=="number","Layer opacity must be a number"),this.set(rt.OPACITY,t)}setVisible(t){this.set(rt.VISIBLE,t)}setZIndex(t){this.set(rt.Z_INDEX,t)}disposeInternal(){this.state_&&(this.state_.layer=null,this.state_=null),super.disposeInternal()}},io=_l;var zi={ADDLAYER:"addlayer",REMOVELAYER:"removelayer"},be=class extends mt{constructor(t,e){super(t),this.layer=e}},yl={LAYERS:"layers"},xl=class n extends io{constructor(t){t=t||{};let 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(yl.LAYERS,this.handleLayersChanged_),i?Array.isArray(i)?i=new Mt(i.slice(),{unique:!0}):V(typeof i.getArray=="function","Expected `layers` to be an array or a `Collection`"):i=new Mt(void 0,{unique:!0}),this.setLayers(i)}handleLayerChange_(){this.changed()}handleLayersChanged_(){this.layersListenerKeys_.forEach(B),this.layersListenerKeys_.length=0;let t=this.getLayers();this.layersListenerKeys_.push(G(t,wt.ADD,this.handleLayersAdd_,this),G(t,wt.REMOVE,this.handleLayersRemove_,this));for(let i in this.listenerKeys_)this.listenerKeys_[i].forEach(B);ze(this.listenerKeys_);let e=t.getArray();for(let i=0,r=e.length;i<r;i++){let s=e[i];this.registerLayerListeners_(s),this.dispatchEvent(new be(zi.ADDLAYER,s))}this.changed()}registerLayerListeners_(t){let e=[G(t,Ee.PROPERTYCHANGE,this.handleLayerChange_,this),G(t,L.CHANGE,this.handleLayerChange_,this)];t instanceof n&&e.push(G(t,zi.ADDLAYER,this.handleLayerGroupAdd_,this),G(t,zi.REMOVELAYER,this.handleLayerGroupRemove_,this)),this.listenerKeys_[U(t)]=e}handleLayerGroupAdd_(t){this.dispatchEvent(new be(zi.ADDLAYER,t.layer))}handleLayerGroupRemove_(t){this.dispatchEvent(new be(zi.REMOVELAYER,t.layer))}handleLayersAdd_(t){let e=t.element;this.registerLayerListeners_(e),this.dispatchEvent(new be(zi.ADDLAYER,e)),this.changed()}handleLayersRemove_(t){let e=t.element,i=U(e);this.listenerKeys_[i].forEach(B),delete this.listenerKeys_[i],this.dispatchEvent(new be(zi.REMOVELAYER,e)),this.changed()}getLayers(){return this.get(yl.LAYERS)}setLayers(t){let e=this.getLayers();if(e){let i=e.getArray();for(let r=0,s=i.length;r<s;++r)this.dispatchEvent(new be(zi.REMOVELAYER,i[r]))}this.set(yl.LAYERS,t)}getLayersArray(t){return t=t!==void 0?t:[],this.getLayers().forEach(function(e){e.getLayersArray(t)}),t}getLayerStatesArray(t){let e=t!==void 0?t:[],i=e.length;this.getLayers().forEach(function(o){o.getLayerStatesArray(e)});let r=this.getLayerState(),s=r.zIndex;!t&&r.zIndex===void 0&&(s=0);for(let o=i,a=e.length;o<a;o++){let l=e[o];l.opacity*=r.opacity,l.visible=l.visible&&r.visible,l.maxResolution=Math.min(l.maxResolution,r.maxResolution),l.minResolution=Math.max(l.minResolution,r.minResolution),l.minZoom=Math.max(l.minZoom,r.minZoom),l.maxZoom=Math.min(l.maxZoom,r.maxZoom),r.extent!==void 0&&(l.extent!==void 0?l.extent=Ut(l.extent,r.extent):l.extent=r.extent),l.zIndex===void 0&&(l.zIndex=s)}return e}getSourceState(){return"ready"}},Ar=xl;var Lt={PRERENDER:"prerender",POSTRENDER:"postrender",PRECOMPOSE:"precompose",POSTCOMPOSE:"postcompose",RENDERCOMPLETE:"rendercomplete"};var El=class extends io{constructor(t){let 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(rt.SOURCE,this.handleSourcePropertyChange_);let 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(rt.SOURCE)||null}getRenderSource(){return this.getSource()}getSourceState(){let 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_&&(B(this.sourceChangeKey_),this.sourceChangeKey_=null),this.sourceReady_=!1;let t=this.getSource();t&&(this.sourceChangeKey_=G(t,L.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,i=this.getMapInternal();!t&&i&&(t=i.getView()),t instanceof Bt?e={viewState:t.getState(),extent:t.calculateExtent()}:e=t,!e.layerStatesArray&&i&&(e.layerStatesArray=i.getLayerGroup().getLayerStatesArray());let r;if(e.layerStatesArray){if(r=e.layerStatesArray.find(o=>o.layer===this),!r)return!1}else r=this.getLayerState();let s=this.getExtent();return Pr(r,e.viewState)&&(!s||lt(s,e.extent))}getAttributions(t){if(!this.isVisible(t))return[];let e=this.getSource()?.getAttributions();if(!e)return[];let i=t instanceof Bt?t.getViewStateAndExtent():t,r=e(i);return Array.isArray(r)||(r=[r]),r}render(t,e){let 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){let e=this.getRenderer();e&&e.renderDeferred(t)}setMapInternal(t){t||this.unrender(),this.set(rt.MAP,t)}getMapInternal(){return this.get(rt.MAP)}setMap(t){this.mapPrecomposeKey_&&(B(this.mapPrecomposeKey_),this.mapPrecomposeKey_=null),t||this.changed(),this.mapRenderKey_&&(B(this.mapRenderKey_),this.mapRenderKey_=null),t&&(this.mapPrecomposeKey_=G(t,Lt.PRECOMPOSE,this.handlePrecompose_,this),this.mapRenderKey_=G(this,L.CHANGE,t.render,t),this.changed())}handlePrecompose_(t){let e=t.frameState.layerStatesArray,i=this.getLayerState(!1);V(!e.some(r=>r.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(rt.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 Pr(n,t){if(!n.visible)return!1;let e=t.resolution;if(e<n.minResolution||e>=n.maxResolution)return!1;let i=t.zoom;return i>n.minZoom&&i<=n.maxZoom}var ci=El;function no(n,t,e=0,i=n.length-1,r=xm){for(;i>e;){if(i-e>600){let l=i-e+1,c=t-e+1,h=Math.log(l),u=.5*Math.exp(2*h/3),d=.5*Math.sqrt(h*u*(l-u)/l)*(c-l/2<0?-1:1),f=Math.max(e,Math.floor(t-c*u/l+d)),g=Math.min(i,Math.floor(t+(l-c)*u/l+d));no(n,t,f,g,r)}let s=n[t],o=e,a=i;for(Or(n,e,t),r(n[i],s)>0&&Or(n,e,i);o<a;){for(Or(n,o,a),o++,a--;r(n[o],s)<0;)o++;for(;r(n[a],s)>0;)a--}r(n[e],s)===0?Or(n,e,a):(a++,Or(n,a,i)),a<=t&&(e=a+1),t<=a&&(i=a-1)}}function Or(n,t,e){let i=n[t];n[t]=n[e],n[e]=i}function xm(n,t){return n<t?-1:n>t?1:0}var ln=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,i=[];if(!so(t,e))return i;let r=this.toBBox,s=[];for(;e;){for(let o=0;o<e.children.length;o++){let a=e.children[o],l=e.leaf?r(a):a;so(t,l)&&(e.leaf?i.push(a):Rl(t,l)?this._all(a,i):s.push(a))}e=s.pop()}return i}collides(t){let e=this.data;if(!so(t,e))return!1;let i=[];for(;e;){for(let r=0;r<e.children.length;r++){let s=e.children[r],o=e.leaf?this.toBBox(s):s;if(so(t,o)){if(e.leaf||Rl(t,o))return!0;i.push(s)}}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){let 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=Xn([]),this}remove(t,e){if(!t)return this;let i=this.data,r=this.toBBox(t),s=[],o=[],a,l,c;for(;i||s.length;){if(i||(i=s.pop(),l=s[s.length-1],a=o.pop(),c=!0),i.leaf){let h=Em(t,i.children,e);if(h!==-1)return i.children.splice(h,1),s.push(i),this._condense(s),this}!c&&!i.leaf&&Rl(i,r)?(s.push(i),o.push(a),a=0,l=i,i=i.children[0]):l?(a++,i=l.children[a],c=!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){let i=[];for(;t;)t.leaf?e.push(...t.children):i.push(...t.children),t=i.pop();return e}_build(t,e,i,r){let s=i-e+1,o=this._maxEntries,a;if(s<=o)return a=Xn(t.slice(e,i+1)),Wn(a,this.toBBox),a;r||(r=Math.ceil(Math.log(s)/Math.log(o)),o=Math.ceil(s/Math.pow(o,r-1))),a=Xn([]),a.leaf=!1,a.height=r;let l=Math.ceil(s/o),c=l*Math.ceil(Math.sqrt(o));Fd(t,e,i,c,this.compareMinX);for(let h=e;h<=i;h+=c){let u=Math.min(h+c-1,i);Fd(t,h,u,l,this.compareMinY);for(let d=h;d<=u;d+=l){let f=Math.min(d+l-1,u);a.children.push(this._build(t,d,f,r-1))}}return Wn(a,this.toBBox),a}_chooseSubtree(t,e,i,r){for(;r.push(e),!(e.leaf||r.length-1===i);){let s=1/0,o=1/0,a;for(let l=0;l<e.children.length;l++){let c=e.children[l],h=Cl(c),u=wm(t,c)-h;u<o?(o=u,s=h<s?h:s,a=c):u===o&&h<s&&(s=h,a=c)}e=a||e.children[0]}return e}_insert(t,e,i){let r=i?t:this.toBBox(t),s=[],o=this._chooseSubtree(r,this.data,e,s);for(o.children.push(t),Dr(o,r);e>=0&&s[e].children.length>this._maxEntries;)this._split(s,e),e--;this._adjustParentBBoxes(r,s,e)}_split(t,e){let i=t[e],r=i.children.length,s=this._minEntries;this._chooseSplitAxis(i,s,r);let o=this._chooseSplitIndex(i,s,r),a=Xn(i.children.splice(o,i.children.length-o));a.height=i.height,a.leaf=i.leaf,Wn(i,this.toBBox),Wn(a,this.toBBox),e?t[e-1].children.push(a):this._splitRoot(i,a)}_splitRoot(t,e){this.data=Xn([t,e]),this.data.height=t.height+1,this.data.leaf=!1,Wn(this.data,this.toBBox)}_chooseSplitIndex(t,e,i){let r,s=1/0,o=1/0;for(let a=e;a<=i-e;a++){let l=Fr(t,0,a,this.toBBox),c=Fr(t,a,i,this.toBBox),h=Sm(l,c),u=Cl(l)+Cl(c);h<s?(s=h,r=a,o=u<o?u:o):h===s&&u<o&&(o=u,r=a)}return r||i-e}_chooseSplitAxis(t,e,i){let r=t.leaf?this.compareMinX:Cm,s=t.leaf?this.compareMinY:Rm,o=this._allDistMargin(t,e,i,r),a=this._allDistMargin(t,e,i,s);o<a&&t.children.sort(r)}_allDistMargin(t,e,i,r){t.children.sort(r);let s=this.toBBox,o=Fr(t,0,e,s),a=Fr(t,i-e,i,s),l=ro(o)+ro(a);for(let c=e;c<i-e;c++){let h=t.children[c];Dr(o,t.leaf?s(h):h),l+=ro(o)}for(let c=i-e-1;c>=e;c--){let h=t.children[c];Dr(a,t.leaf?s(h):h),l+=ro(a)}return l}_adjustParentBBoxes(t,e,i){for(let r=i;r>=0;r--)Dr(e[r],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():Wn(t[e],this.toBBox)}};function Em(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 Wn(n,t){Fr(n,0,n.children.length,t,n)}function Fr(n,t,e,i,r){r||(r=Xn(null)),r.minX=1/0,r.minY=1/0,r.maxX=-1/0,r.maxY=-1/0;for(let s=t;s<e;s++){let o=n.children[s];Dr(r,n.leaf?i(o):o)}return r}function Dr(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 Cm(n,t){return n.minX-t.minX}function Rm(n,t){return n.minY-t.minY}function Cl(n){return(n.maxX-n.minX)*(n.maxY-n.minY)}function ro(n){return n.maxX-n.minX+(n.maxY-n.minY)}function wm(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 Sm(n,t){let e=Math.max(n.minX,t.minX),i=Math.max(n.minY,t.minY),r=Math.min(n.maxX,t.maxX),s=Math.min(n.maxY,t.maxY);return Math.max(0,r-e)*Math.max(0,s-i)}function Rl(n,t){return n.minX<=t.minX&&n.minY<=t.minY&&t.maxX<=n.maxX&&t.maxY<=n.maxY}function so(n,t){return t.minX<=n.maxX&&t.minY<=n.maxY&&t.maxX>=n.minX&&t.maxY>=n.minY}function Xn(n){return{children:n,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function Fd(n,t,e,i,r){let s=[t,e];for(;s.length;){if(e=s.pop(),t=s.pop(),e-t<=i)continue;let o=t+Math.ceil((e-t)/i/2)*i;no(n,o,t,e,r),s.push(t,o,o,e)}}var ao=[NaN,NaN,NaN,0],wl;function Tm(){return wl||(wl=nt(1,1,void 0,{willReadFrequently:!0,desynchronized:!0})),wl}var vm=/^rgba?\(\s*(\d+%?)\s+(\d+%?)\s+(\d+%?)(?:\s*\/\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,Im=/^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,Mm=/^rgba?\(\s*(\d+%)\s*,\s*(\d+%)\s*,\s*(\d+%)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,bm=/^#([\da-f]{3,4}|[\da-f]{6}|[\da-f]{8})$/i;function oo(n,t){return n.endsWith("%")?Number(n.substring(0,n.length-1))/t:Number(n)}function Nr(n){throw new Error('failed to parse "'+n+'" as color')}function Dd(n){if(n.toLowerCase().startsWith("rgb")){let s=n.match(Im)||n.match(vm)||n.match(Mm);if(s){let o=s[4],a=100/255;return[Q(oo(s[1],a)+.5|0,0,255),Q(oo(s[2],a)+.5|0,0,255),Q(oo(s[3],a)+.5|0,0,255),o!==void 0?Q(oo(o,100),0,1):1]}Nr(n)}if(n.startsWith("#")){if(bm.test(n)){let s=n.substring(1),o=s.length<=4?1:2,a=[0,0,0,255];for(let l=0,c=s.length;l<c;l+=o){let h=parseInt(s.substring(l,l+o),16);o===1&&(h+=h<<4),a[l/o]=h}return a[3]=a[3]/255,a}Nr(n)}let t=Tm();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&&Nr(n));let i=t.fillStyle;if(i.startsWith("#")||i.startsWith("rgba"))return Dd(i);t.clearRect(0,0,1,1),t.fillRect(0,0,1,1);let r=Array.from(t.getImageData(0,0,1,1).data);return r[3]=Ti(r[3]/255,3),r}function kd(n){return typeof n=="string"?n:zr(n)}var Lm=1024,kr={},Sl=0;function Nd(n){if(n.length===4)return n;let t=n.slice();return t[3]=1,t}function Tl(n){return n>.0031308?Math.pow(n,1/2.4)*269.025-14.025:n*3294.6}function vl(n){return n>.2068965?Math.pow(n,3):(n-4/29)*(108/841)}function Il(n){return n>10.314724?Math.pow((n+14.025)/269.025,2.4):n/3294.6}function Ml(n){return n>.0088564?Math.pow(n,1/3):n/(108/841)+4/29}function bl(n){let t=Il(n[0]),e=Il(n[1]),i=Il(n[2]),r=Ml(t*.222488403+e*.716873169+i*.06060791),s=500*(Ml(t*.452247074+e*.399439023+i*.148375274)-r),o=200*(r-Ml(t*.016863605+e*.117638439+i*.865350722)),a=Math.atan2(o,s)*(180/Math.PI);return[116*r-16,Math.sqrt(s*s+o*o),a<0?a+360:a,n[3]]}function Gd(n){let t=(n[0]+16)/116,e=n[1],i=n[2]*Math.PI/180,r=vl(t),s=vl(t+e/500*Math.cos(i)),o=vl(t-e/200*Math.sin(i)),a=Tl(s*3.021973625-r*1.617392459-o*.404875592),l=Tl(s*-.943766287+r*1.916279586+o*.027607165),c=Tl(s*.069407491-r*.22898585+o*1.159737864);return[Q(a+.5|0,0,255),Q(l+.5|0,0,255),Q(c+.5|0,0,255),n[3]]}function Gr(n){if(n==="none")return ao;if(kr.hasOwnProperty(n))return kr[n];if(Sl>=Lm){let e=0;for(let i in kr)(e++&3)===0&&(delete kr[i],--Sl)}let t=Dd(n);t.length!==4&&Nr(n);for(let e of t)isNaN(e)&&Nr(n);return kr[n]=t,++Sl,t}function _e(n){return Array.isArray(n)?n:Gr(n)}function zr(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);let r=n[3]===void 0?1:Math.round(n[3]*1e3)/1e3;return"rgba("+t+","+e+","+i+","+r+")"}function Ll(n){return n[0]>0&&n[1]>0}function zd(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 ft(n,t){return Array.isArray(n)?n:(t===void 0?t=[n,n]:(t[0]=n,t[1]=n),t)}var hn=0;var Ft=1<<hn++,J=1<<hn++,zt=1<<hn++,te=1<<hn++,Wi=1<<hn++,jr=1<<hn++,lo=Math.pow(2,hn)-1,Ol={[Ft]:"boolean",[J]:"number",[zt]:"string",[te]:"color",[Wi]:"number[]",[jr]:"size"},Am=Object.keys(Ol).map(Number).sort(jt);function Pm(n){return n in Ol}function Wr(n){let t=[];for(let e of Am)Xr(n,e)&&t.push(Ol[e]);return t.length===0?"untyped":t.length<3?t.join(" or "):t.slice(0,-1).join(", ")+", or "+t[t.length-1]}function Xr(n,t){return(n&t)===t}function ji(n,t){return n===t}var gt=class{constructor(t,e){if(!Pm(t))throw new Error(`literal expressions must have a specific type, got ${Wr(t)}`);this.type=t,this.value=e}},Pl=class{constructor(t,e,...i){this.type=t,this.operator=e,this.args=i}};function Fl(){return{variables:new Set,properties:new Set,featureId:!1,geometryType:!1,mapState:!1}}function vt(n,t,e){switch(typeof n){case"boolean":{if(ji(t,zt))return new gt(zt,n?"true":"false");if(!Xr(t,Ft))throw new Error(`got a boolean, but expected ${Wr(t)}`);return new gt(Ft,n)}case"number":{if(ji(t,jr))return new gt(jr,ft(n));if(ji(t,Ft))return new gt(Ft,!!n);if(ji(t,zt))return new gt(zt,n.toString());if(!Xr(t,J))throw new Error(`got a number, but expected ${Wr(t)}`);return new gt(J,n)}case"string":{if(ji(t,te))return new gt(te,Gr(n));if(ji(t,Ft))return new gt(Ft,!!n);if(!Xr(t,zt))throw new Error(`got a string, but expected ${Wr(t)}`);return new gt(zt,n)}default:}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 Um(n,t,e);for(let i of n)if(typeof i!="number")throw new Error("expected an array of numbers");if(ji(t,jr)){if(n.length!==2)throw new Error(`expected an array of two values for a size, got ${n.length}`);return new gt(jr,n)}if(ji(t,te)){if(n.length===3)return new gt(te,[...n,1]);if(n.length===4)return new gt(te,n);throw new Error(`expected an array of 3 or 4 values for a color, got ${n.length}`)}if(!Xr(t,Wi))throw new Error(`got an array of numbers, but expected ${Wr(t)}`);return new gt(Wi,n)}var R={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"},Om={[R.Get]:Y(Z(1,1/0),jd),[R.Var]:Y(Z(1,1),Fm),[R.Has]:Y(Z(1,1/0),jd),[R.Id]:Y(Dm,Un),[R.Concat]:Y(Z(2,1/0),st(zt)),[R.GeometryType]:Y(km,Un),[R.LineMetric]:Y(Un),[R.Resolution]:Y(Al,Un),[R.Zoom]:Y(Al,Un),[R.Time]:Y(Al,Un),[R.Any]:Y(Z(2,1/0),st(Ft)),[R.All]:Y(Z(2,1/0),st(Ft)),[R.Not]:Y(Z(1,1),st(Ft)),[R.Equal]:Y(Z(2,2),st(lo)),[R.NotEqual]:Y(Z(2,2),st(lo)),[R.GreaterThan]:Y(Z(2,2),st(J)),[R.GreaterThanOrEqualTo]:Y(Z(2,2),st(J)),[R.LessThan]:Y(Z(2,2),st(J)),[R.LessThanOrEqualTo]:Y(Z(2,2),st(J)),[R.Multiply]:Y(Z(2,1/0),Wd),[R.Coalesce]:Y(Z(2,1/0),Wd),[R.Divide]:Y(Z(2,2),st(J)),[R.Add]:Y(Z(2,1/0),st(J)),[R.Subtract]:Y(Z(2,2),st(J)),[R.Clamp]:Y(Z(3,3),st(J)),[R.Mod]:Y(Z(2,2),st(J)),[R.Pow]:Y(Z(2,2),st(J)),[R.Abs]:Y(Z(1,1),st(J)),[R.Floor]:Y(Z(1,1),st(J)),[R.Ceil]:Y(Z(1,1),st(J)),[R.Round]:Y(Z(1,1),st(J)),[R.Sin]:Y(Z(1,1),st(J)),[R.Cos]:Y(Z(1,1),st(J)),[R.Atan]:Y(Z(1,2),st(J)),[R.Sqrt]:Y(Z(1,1),st(J)),[R.Match]:Y(Z(4,1/0),Xd,Gm),[R.Between]:Y(Z(3,3),st(J)),[R.Interpolate]:Y(Z(6,1/0),Xd,zm),[R.Case]:Y(Z(3,1/0),Nm,jm),[R.In]:Y(Z(2,2),Wm),[R.Number]:Y(Z(1,1/0),st(lo)),[R.String]:Y(Z(1,1/0),st(lo)),[R.Array]:Y(Z(1,1/0),st(J)),[R.Color]:Y(Z(1,4),st(J)),[R.Band]:Y(Z(1,3),st(J)),[R.Palette]:Y(Z(2,2),Xm),[R.ToString]:Y(Z(1,1),st(Ft|J|zt|te))};function jd(n,t,e){let i=n.length-1,r=new Array(i);for(let s=0;s<i;++s){let o=n[s+1];switch(typeof o){case"number":{r[s]=new gt(J,o);break}case"string":{r[s]=new gt(zt,o);break}default:throw new Error(`expected a string key or numeric array index for a get operation, got ${o}`)}s===0&&e.properties.add(String(o))}return r}function Fm(n,t,e){let i=n[1];if(typeof i!="string")throw new Error("expected a string argument for var operation");return e.variables.add(i),[new gt(zt,i)]}function Dm(n,t,e){e.featureId=!0}function km(n,t,e){e.geometryType=!0}function Al(n,t,e){e.mapState=!0}function Un(n,t,e){let i=n[0];if(n.length!==1)throw new Error(`expected no arguments for ${i} operation`);return[]}function Z(n,t){return function(e,i,r){let s=e[0],o=e.length-1;if(n===t){if(o!==n){let a=n===1?"":"s";throw new Error(`expected ${n} argument${a} for ${s}, got ${o}`)}}else if(o<n||o>t){let a=t===1/0?`${n} or more`:`${n} to ${t}`;throw new Error(`expected ${a} arguments for ${s}, got ${o}`)}}}function Wd(n,t,e){let i=n.length-1,r=new Array(i);for(let s=0;s<i;++s){let o=vt(n[s+1],t,e);r[s]=o}return r}function st(n){return function(t,e,i){let r=t.length-1,s=new Array(r);for(let o=0;o<r;++o){let a=vt(t[o+1],n,i);s[o]=a}return s}}function Nm(n,t,e){let i=n[0],r=n.length-1;if(r%2===0)throw new Error(`expected an odd number of arguments for ${i}, got ${r} instead`)}function Xd(n,t,e){let i=n[0],r=n.length-1;if(r%2===1)throw new Error(`expected an even number of arguments for operation ${i}, got ${r} instead`)}function Gm(n,t,e){let i=n.length-1,r=zt|J|Ft,s=vt(n[1],r,e),o=vt(n[n.length-1],t,e),a=new Array(i-2);for(let l=0;l<i-2;l+=2){try{let c=vt(n[l+2],s.type,e);a[l]=c}catch(c){throw new Error(`failed to parse argument ${l+1} of match expression: ${c.message}`)}try{let c=vt(n[l+3],o.type,e);a[l+1]=c}catch(c){throw new Error(`failed to parse argument ${l+2} of match expression: ${c.message}`)}}return[s,...a,o]}function zm(n,t,e){let i=n[1],r;switch(i[0]){case"linear":r=1;break;case"exponential":let l=i[1];if(typeof l!="number"||l<=0)throw new Error(`expected a number base for exponential interpolation, got ${JSON.stringify(l)} instead`);r=l;break;default:throw new Error(`invalid interpolation type: ${JSON.stringify(i)}`)}let s=new gt(J,r),o;try{o=vt(n[2],J,e)}catch(l){throw new Error(`failed to parse argument 1 in interpolate expression: ${l.message}`)}let a=new Array(n.length-3);for(let l=0;l<a.length;l+=2){try{let c=vt(n[l+3],J,e);a[l]=c}catch(c){throw new Error(`failed to parse argument ${l+2} for interpolate expression: ${c.message}`)}try{let c=vt(n[l+4],t,e);a[l+1]=c}catch(c){throw new Error(`failed to parse argument ${l+3} for interpolate expression: ${c.message}`)}}return[s,o,...a]}function jm(n,t,e){let i=vt(n[n.length-1],t,e),r=new Array(n.length-1);for(let s=0;s<r.length-1;s+=2){try{let o=vt(n[s+1],Ft,e);r[s]=o}catch(o){throw new Error(`failed to parse argument ${s} of case expression: ${o.message}`)}try{let o=vt(n[s+2],i.type,e);r[s+1]=o}catch(o){throw new Error(`failed to parse argument ${s+1} of case expression: ${o.message}`)}}return r[r.length-1]=i,r}function Wm(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 r;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],r=zt}else r=J;let s=new Array(i.length);for(let a=0;a<s.length;a++)try{let l=vt(i[a],r,e);s[a]=l}catch(l){throw new Error(`failed to parse haystack item ${a} for "in" expression: ${l.message}`)}return[vt(n[1],r,e),...s]}function Xm(n,t,e){let i;try{i=vt(n[1],J,e)}catch(o){throw new Error(`failed to parse first argument in palette expression: ${o.message}`)}let r=n[2];if(!Array.isArray(r))throw new Error("the second argument of palette must be an array");let s=new Array(r.length);for(let o=0;o<s.length;o++){let a;try{a=vt(r[o],te,e)}catch(l){throw new Error(`failed to parse color at index ${o} in palette expression: ${l.message}`)}if(!(a instanceof gt))throw new Error(`the palette color at index ${o} must be a literal value`);s[o]=a}return[i,...s]}function Y(...n){return function(t,e,i){let r=t[0],s;for(let o=0;o<n.length;o++){let 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");s=a}}return new Pl(e,r,...s)}}function Um(n,t,e){let i=n[0],r=Om[i];if(!r)throw new Error(`unknown operator: ${i}`);return r(n,t,e)}function Dl(n){if(!n)return"";let 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 Dl(n.getGeometries()[0]);default:return""}}function kl(){return{variables:{},properties:{},resolution:NaN,featureId:null,geometryType:""}}function Ae(n,t,e){let i=vt(n,t,e);return Le(i,e)}function Le(n,t){if(n instanceof gt){if(n.type===te&&typeof n.value=="string"){let i=Gr(n.value);return function(){return i}}return function(){return n.value}}let e=n.operator;switch(e){case R.Number:case R.String:case R.Coalesce:return Ym(n,t);case R.Get:case R.Var:case R.Has:return Km(n,t);case R.Id:return i=>i.featureId;case R.GeometryType:return i=>i.geometryType;case R.Concat:{let i=n.args.map(r=>Le(r,t));return r=>"".concat(...i.map(s=>s(r).toString()))}case R.Resolution:return i=>i.resolution;case R.Any:case R.All:case R.Between:case R.In:case R.Not:return Bm(n,t);case R.Equal:case R.NotEqual:case R.LessThan:case R.LessThanOrEqualTo:case R.GreaterThan:case R.GreaterThanOrEqualTo:return Vm(n,t);case R.Multiply:case R.Divide:case R.Add:case R.Subtract:case R.Clamp:case R.Mod:case R.Pow:case R.Abs:case R.Floor:case R.Ceil:case R.Round:case R.Sin:case R.Cos:case R.Atan:case R.Sqrt:return Zm(n,t);case R.Case:return Hm(n,t);case R.Match:return qm(n,t);case R.Interpolate:return $m(n,t);case R.ToString:return Jm(n,t);default:throw new Error(`Unsupported operator ${e}`)}}function Ym(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);switch(e){case R.Coalesce:return s=>{for(let o=0;o<i;++o){let a=r[o](s);if(typeof a<"u"&&a!==null)return a}throw new Error("Expected one of the values to be non-null")};case R.Number:case R.String:return s=>{for(let o=0;o<i;++o){let a=r[o](s);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 Km(n,t){let i=n.args[0].value;switch(n.operator){case R.Get:return r=>{let s=n.args,o=r.properties[i];for(let a=1,l=s.length;a<l;++a){let h=s[a].value;o=o[h]}return o};case R.Var:return r=>r.variables[i];case R.Has:return r=>{let s=n.args;if(!(i in r.properties))return!1;let o=r.properties[i];for(let a=1,l=s.length;a<l;++a){let h=s[a].value;if(!o||!Object.hasOwn(o,h))return!1;o=o[h]}return!0};default:throw new Error(`Unsupported accessor operator ${n.operator}`)}}function Vm(n,t){let e=n.operator,i=Le(n.args[0],t),r=Le(n.args[1],t);switch(e){case R.Equal:return s=>i(s)===r(s);case R.NotEqual:return s=>i(s)!==r(s);case R.LessThan:return s=>i(s)<r(s);case R.LessThanOrEqualTo:return s=>i(s)<=r(s);case R.GreaterThan:return s=>i(s)>r(s);case R.GreaterThanOrEqualTo:return s=>i(s)>=r(s);default:throw new Error(`Unsupported comparison operator ${e}`)}}function Bm(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);switch(e){case R.Any:return s=>{for(let o=0;o<i;++o)if(r[o](s))return!0;return!1};case R.All:return s=>{for(let o=0;o<i;++o)if(!r[o](s))return!1;return!0};case R.Between:return s=>{let o=r[0](s),a=r[1](s),l=r[2](s);return o>=a&&o<=l};case R.In:return s=>{let o=r[0](s);for(let a=1;a<i;++a)if(o===r[a](s))return!0;return!1};case R.Not:return s=>!r[0](s);default:throw new Error(`Unsupported logical operator ${e}`)}}function Zm(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);switch(e){case R.Multiply:return s=>{let o=1;for(let a=0;a<i;++a)o*=r[a](s);return o};case R.Divide:return s=>r[0](s)/r[1](s);case R.Add:return s=>{let o=0;for(let a=0;a<i;++a)o+=r[a](s);return o};case R.Subtract:return s=>r[0](s)-r[1](s);case R.Clamp:return s=>{let o=r[0](s),a=r[1](s);if(o<a)return a;let l=r[2](s);return o>l?l:o};case R.Mod:return s=>r[0](s)%r[1](s);case R.Pow:return s=>Math.pow(r[0](s),r[1](s));case R.Abs:return s=>Math.abs(r[0](s));case R.Floor:return s=>Math.floor(r[0](s));case R.Ceil:return s=>Math.ceil(r[0](s));case R.Round:return s=>Math.round(r[0](s));case R.Sin:return s=>Math.sin(r[0](s));case R.Cos:return s=>Math.cos(r[0](s));case R.Atan:return i===2?s=>Math.atan2(r[0](s),r[1](s)):s=>Math.atan(r[0](s));case R.Sqrt:return s=>Math.sqrt(r[0](s));default:throw new Error(`Unsupported numeric operator ${e}`)}}function Hm(n,t){let e=n.args.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=Le(n.args[r],t);return r=>{for(let s=0;s<e-1;s+=2)if(i[s](r))return i[s+1](r);return i[e-1](r)}}function qm(n,t){let e=n.args.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=Le(n.args[r],t);return r=>{let s=i[0](r);for(let o=1;o<e-1;o+=2)if(s===i[o](r))return i[o+1](r);return i[e-1](r)}}function $m(n,t){let e=n.args.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=Le(n.args[r],t);return r=>{let s=i[0](r),o=i[1](r),a,l;for(let c=2;c<e;c+=2){let h=i[c](r),u=i[c+1](r),d=Array.isArray(u);if(d&&(u=Nd(u)),h>=o)return c===2?u:d?Qm(s,o,a,l,h,u):Ur(s,o,a,l,h,u);a=h,l=u}return l}}function Jm(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);if(e===R.ToString)return s=>{let o=r[0](s);return n.args[0].type===te?zr(o):o.toString()};throw new Error(`Unsupported convert operator ${e}`)}function Ur(n,t,e,i,r,s){let o=r-e;if(o===0)return i;let a=t-e,l=n===1?a/o:(Math.pow(n,a)-1)/(Math.pow(n,o)-1);return i+l*(s-i)}function Qm(n,t,e,i,r,s){if(r-e===0)return i;let a=bl(i),l=bl(s),c=l[2]-a[2];c>180?c-=360:c<-180&&(c+=360);let h=[Ur(n,t,e,a[0],r,l[0]),Ur(n,t,e,a[1],r,l[1]),a[2]+Ur(n,t,e,0,r,c),Ur(n,t,e,i[3],r,s[3])];return Gd(h)}var b={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4};var Nl=class extends je{constructor(t,e,i,r){super(),this.extent=t,this.pixelRatio_=i,this.resolution=e,this.state=typeof r=="function"?b.IDLE:r,this.image_=null,this.loader=typeof r=="function"?r:null}changed(){this.dispatchEvent(L.CHANGE)}getExtent(){return this.extent}getImage(){return this.image_}getPixelRatio(){return this.pixelRatio_}getResolution(){return this.resolution}getState(){return this.state}load(){if(this.state==b.IDLE&&this.loader){this.state=b.LOADING,this.changed();let t=this.getResolution(),e=Array.isArray(t)?t[0]:t;ps(()=>this.loader(this.getExtent(),e,this.getPixelRatio())).then(i=>{"image"in i&&(this.image_=i.image),"extent"in i&&(this.extent=i.extent),"resolution"in i&&(this.resolution=i.resolution),"pixelRatio"in i&&(this.pixelRatio_=i.pixelRatio),(i instanceof HTMLImageElement||la&&i instanceof ImageBitmap||i instanceof HTMLCanvasElement||i instanceof HTMLVideoElement)&&(this.image_=i),this.state=b.LOADED}).catch(i=>{this.state=b.ERROR,console.error(i)}).finally(()=>this.changed())}}setImage(t){this.image_=t}setResolution(t){this.resolution=t}};function Ud(n,t,e){let i=n,r=!0,s=!1,o=!1,a=[_n(i,L.LOAD,function(){o=!0,s||t()})];return i.src&&xs?(s=!0,i.decode().then(function(){r&&t()}).catch(function(l){r&&(o?t():e())})):a.push(_n(i,L.ERROR,e)),function(){r=!1,a.forEach(B)}}function tp(n,t){return new Promise((e,i)=>{function r(){o(),e(n)}function s(){o(),i(new Error("Image load error"))}function o(){n.removeEventListener("load",r),n.removeEventListener("error",s)}n.addEventListener("load",r),n.addEventListener("error",s),t&&(n.src=t)})}function Gl(n,t){return t&&(n.src=t),n.src&&xs?new Promise((e,i)=>n.decode().then(()=>e(n)).catch(r=>n.complete&&n.width?e(n):i(r))):tp(n)}function ho(n,t){return t&&(n.src=t),n.src&&xs&&la?n.decode().then(()=>createImageBitmap(n)).catch(e=>{if(n.complete&&n.width)return n;throw e}):Gl(n)}var co=Nl;var jl=class{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(let e in this.cache_){let i=this.cache_[e];(t++&3)===0&&!i.hasListener()&&(delete this.cache_[e],delete this.patternCache_[e],--this.cacheSize_)}}}get(t,e){let i=zl(t,e);return i in this.cache_?this.cache_[i]:null}getPattern(t,e){let i=zl(t,e);return i in this.patternCache_?this.patternCache_[i]:null}set(t,e,i,r){let s=zl(t,e),o=s in this.cache_;this.cache_[s]=i,r&&(i.getImageState()===b.IDLE&&i.load(),i.getImageState()===b.LOADING?i.ready().then(()=>{this.patternCache_[s]=Fn().createPattern(i.getImage(1),"repeat")}):this.patternCache_[s]=Fn().createPattern(i.getImage(1),"repeat")),o||++this.cacheSize_}setSize(t){this.maxCacheSize_=t,this.expire()}};function zl(n,t){let e=t?_e(t):"null";return n+":"+e}var Dt=new jl;var Yr=null,uo=class extends je{constructor(t,e,i,r,s){super(),this.hitDetectionImage_=null,this.image_=t,this.crossOrigin_=i?.crossOrigin,this.referrerPolicy_=i?.referrerPolicy,this.canvas_={},this.color_=s,this.imageState_=r===void 0?b.IDLE:r,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_),this.referrerPolicy_!==void 0&&(this.image_.referrerPolicy=this.referrerPolicy_)}isTainted_(){if(this.tainted_===void 0&&this.imageState_===b.LOADED){Yr||(Yr=nt(1,1,void 0,{willReadFrequently:!0})),Yr.drawImage(this.image_,0,0);try{Yr.getImageData(0,0,1,1),this.tainted_=!1}catch{Yr=null,this.tainted_=!0}}return this.tainted_===!0}dispatchChangeEvent_(){this.dispatchEvent(L.CHANGE)}handleImageError_(){this.imageState_=b.ERROR,this.dispatchChangeEvent_()}handleImageLoad_(){this.imageState_=b.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_}setImage(t){this.image_=t}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_()){let t=this.size_[0],e=this.size_[1],i=nt(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_===b.IDLE){this.image_||this.initializeImage_(),this.imageState_=b.LOADING;try{this.src_!==void 0&&(this.image_.src=this.src_)}catch{this.handleImageError_()}this.image_ instanceof HTMLImageElement&&Gl(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_!==b.LOADED)return;let e=this.image_,i=nt(Math.ceil(e.width*t),Math.ceil(e.height*t)),r=i.canvas;i.scale(t,t),i.drawImage(e,0,0),i.globalCompositeOperation="multiply",i.fillStyle=kd(this.color_),i.fillRect(0,0,r.width/t,r.height/t),i.globalCompositeOperation="destination-in",i.drawImage(e,0,0),this.canvas_[t]=r}ready(){return this.ready_||(this.ready_=new Promise(t=>{if(this.imageState_===b.LOADED||this.imageState_===b.ERROR)t();else{let e=()=>{(this.imageState_===b.LOADED||this.imageState_===b.ERROR)&&(this.removeEventListener(L.CHANGE,e),t())};this.addEventListener(L.CHANGE,e)}})),this.ready_}};function Xi(n,t,e,i,r,s){let o=t===void 0?void 0:Dt.get(t,r);return o||(o=new uo(n,n&&"src"in n?n.src||void 0:t,e,i,r),Dt.set(t,r,o,s)),s&&o&&!Dt.getPattern(t,r)&&Dt.set(t,r,o,s),o}var Yd=uo;function Zt(n){return n?Array.isArray(n)?zr(n):typeof n=="object"&&"src"in n?ep(n):n:null}function ep(n){if(!n.offset||!n.size)return Dt.getPattern(n.src,n.color);let t=n.src+":"+n.offset,e=Dt.getPattern(t,n.color);if(e)return e;let i=Dt.get(n.src,null);if(i.getImageState()!==b.LOADED)return null;let r=nt(n.size[0],n.size[1]);return r.drawImage(i.getImage(1),n.offset[0],n.offset[1],n.size[0],n.size[1],0,0,n.size[0],n.size[1]),Xi(r.canvas,t,void 0,b.LOADED,n.color,!0),Dt.getPattern(t,n.color)}var fo="10px sans-serif",Ct="#000",Ve="round",Ht=[],qt=0,Be="round",ui=10,Vd=0,di="#000",Ui="center",un="middle",fi=[0,0,0,0],gi=1,cn=new pt,Kr=null,Kd,Wl={},ip=new Set(["serif","sans-serif","monospace","cursive","fantasy","system-ui","ui-serif","ui-sans-serif","ui-monospace","ui-rounded","emoji","math","fangsong"]);function np(n,t,e){return`${n} ${t} 16px "${e}"`}var Bd=(function(){let t,e;async function i(s){await e.ready;let o=await e.load(s);if(o.length===0)return!1;let a=Hs(s),l=a.families[0].toLowerCase(),c=a.weight;return o.some(h=>{let u=h.family.replace(/^['"]|['"]$/g,"").toLowerCase(),d=Zs[h.weight]||h.weight;return u===l&&h.style===a.style&&d==c})}async function r(){await e.ready;let s=!0,o=cn.getProperties(),a=Object.keys(o).filter(l=>o[l]<100);for(let l=a.length-1;l>=0;--l){let c=a[l],h=o[c];h<100&&(await i(c)?(ze(Wl),cn.set(c,100)):(h+=10,cn.set(c,h,!0),h<100&&(s=!1)))}t=void 0,s||(t=setTimeout(r,100))}return async function(s){e||(e=xt?self.fonts:document.fonts);let o=Hs(s);if(!o)return;let a=o.families,l=!1;for(let c of a){if(ip.has(c))continue;let h=np(o.style,o.weight,c);cn.get(h)===void 0&&(cn.set(h,0,!0),l=!0)}l&&(clearTimeout(t),t=setTimeout(r,100))}})(),rp=(function(){let n;return function(t){let e=Wl[t];if(e==null){if(xt){let i=Hs(t),r=Zd(t,"\u017Dg");e=(isNaN(Number(i.lineHeight))?1.2:Number(i.lineHeight))*(r.actualBoundingBoxAscent+r.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);Wl[t]=e}return e}})();function Zd(n,t){return Kr||(Kr=nt(1,1)),n!=Kd&&(Kr.font=n,Kd=Kr.font),Kr.measureText(t)}function Hd(n,t){return Zd(n,t).width}function Xl(n,t,e){if(t in e)return e[t];let i=t.split(`
|
|
2
|
-
`).reduce((r,s)=>Math.max(r,Hd(n,s)),0);return e[t]=i,i}function qd(n,t){let e=[],i=[],r=[],s=0,o=0,a=0,l=0;for(let
|
|
3
|
-
`||c===h){s=Math.max(s,o),r.push(o),o=0,a+=l,l=0;continue}let d=t[c+1]||n.font,f=Hd(d,u);e.push(f),o+=f;let g=rp(d);i.push(g),l=Math.max(l,g)}return{width:s,height:a,widths:e,heights:i,lineWidths:r}}function $d(n,t,e,i,r,s,o,a,l,c,h){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,c),n.scale(h[0],h[1]),sp(i,n)):h[0]<0||h[1]<0?(n.translate(l,c),n.scale(h[0],h[1]),n.drawImage(i,r,s,o,a,0,0,o,a)):n.drawImage(i,r,s,o,a,l,c,o*h[0],a*h[1]),n.restore()}function sp(n,t){let e=n.contextInstructions;for(let i=0,r=e.length;i<r;i+=2)Array.isArray(e[i+1])?t[e[i]].apply(t,e[i+1]):t[e[i]]=e[i+1]}var Ul=class n{constructor(t){this.opacity_=t.opacity,this.rotateWithView_=t.rotateWithView,this.rotation_=t.rotation,this.scale_=t.scale,this.scaleArray_=ft(t.scale),this.displacement_=t.displacement,this.declutterMode_=t.declutterMode}clone(){let t=this.getScale();return new n({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 F()}getImage(t){return F()}getHitDetectionImage(){return F()}getPixelRatio(t){return 1}getImageState(){return F()}getImageSize(){return F()}getOrigin(){return F()}getSize(){return F()}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_=ft(t)}listenImageChange(t){F()}load(){F()}unlistenImageChange(t){F()}ready(){return Promise.resolve()}},go=Ul;var Yl=class n extends go{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()?b.LOADING:b.LOADED,this.imageState_===b.LOADING&&this.ready().then(()=>this.imageState_=b.LOADED),this.render()}clone(){let t=this.getScale(),e=new n({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(){let 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){let e=this.fill_?.getKey(),i=`${t},${this.angle_},${this.radius},${this.radius2_},${this.points_},${e}`+Object.values(this.renderOptions_).join(","),r=Dt.get(i,null)?.getImage(1);if(!r){let s=this.renderOptions_,o=Math.ceil(s.size*t),a=nt(o,o);this.draw_(s,a,t),r=a.canvas;let l=new Yd(r,void 0,null,b.LOADED,null);Dt.set(i,null,l),createImageBitmap(r).then(c=>{l.setImage(c)})}return r}getPixelRatio(t){return t}getImageSize(){return this.size_}getImageState(){return this.imageState_}getOrigin(){return this.origin_}getPoints(){return this.points_}getRadius(){return this.radius}setRadius(t){this.radius!==t&&(this.radius=t,this.render())}getRadius2(){return this.radius2_}setRadius2(t){this.radius2_!==t&&(this.radius2_=t,this.render())}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 r=this.radius,s=this.radius2_===void 0?r:this.radius2_;if(r<s){let T=r;r=s,s=T}let o=this.radius2_===void 0?this.points_:this.points_*2,a=2*Math.PI/o,l=s*Math.sin(a),c=Math.sqrt(s*s-l*l),h=r-c,u=Math.sqrt(l*l+h*h),d=u/l;if(t==="miter"&&d<=i)return d*e;let f=e/2/d,g=e/2*(h/u),m=Math.sqrt((r+f)*(r+f)+g*g)-r;if(this.radius2_===void 0||t==="bevel")return m*2;let _=r*Math.sin(a),y=Math.sqrt(r*r-_*_),E=s-y,C=Math.sqrt(_*_+E*E)/_;if(C<=i){let T=C*e/2-s-r;return 2*Math.max(m,T)}return m*2}createRenderOptions(){let t=Ve,e=Be,i=0,r=null,s=0,o,a=0;this.stroke_&&(o=Zt(this.stroke_.getColor()??di),a=this.stroke_.getWidth()??gi,r=this.stroke_.getLineDash(),s=this.stroke_.getLineDashOffset()??0,e=this.stroke_.getLineJoin()??Be,t=this.stroke_.getLineCap()??Ve,i=this.stroke_.getMiterLimit()??ui);let l=this.calculateLineJoinSize_(e,a,i),c=Math.max(this.radius,this.radius2_||0),h=Math.ceil(2*c+l);return{strokeStyle:o,strokeWidth:a,size:h,lineCap:t,lineDash:r,lineDashOffset:s,lineJoin:e,miterLimit:i}}render(){this.renderOptions_=this.createRenderOptions();let 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 r=this.fill_.getColor();r===null&&(r=Ct),e.fillStyle=Zt(r),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(),r=0;typeof i=="string"&&(i=_e(i)),i===null?r=1:Array.isArray(i)&&(r=i.length===4?i[3]:1),r===0&&(e=nt(t.size,t.size),this.drawHitDetectionCanvas_(t,e))}return e?e.canvas:this.getImage(1)}createPath_(t){let e=this.points_,i=this.radius;if(e===1/0)t.arc(0,0,i,0,2*Math.PI);else{let r=this.radius2_===void 0?i:this.radius2_;this.radius2_!==void 0&&(e*=2);let s=this.angle_-Math.PI/2,o=2*Math.PI/e;for(let a=0;a<e;a++){let l=s+a*o,c=a%2===0?i:r;t.lineTo(c*Math.cos(l),c*Math.sin(l))}t.closePath()}}drawHitDetectionCanvas_(t,e){e.translate(t.size/2,t.size/2),this.createPath_(e),e.fillStyle=Ct,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()}},mo=Yl;var Kl=class n extends mo{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(){let t=this.getScale(),e=new n({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}},Yi=Kl;var Vl=class n{constructor(t){t=t||{},this.patternImage_=null,this.color_=null,t.color!==void 0&&this.setColor(t.color)}clone(){let t=this.getColor();return new n({color:Array.isArray(t)?t.slice():t||void 0})}getColor(){return this.color_}setColor(t){if(t!==null&&typeof t=="object"&&"src"in t){let e=Xi(null,t.src,{crossOrigin:"anonymous"},void 0,t.offset?null:t.color?t.color:null,!(t.offset&&t.size));e.ready().then(()=>{this.patternImage_=null}),e.getImageState()===b.IDLE&&e.load(),e.getImageState()===b.LOADING&&(this.patternImage_=e)}this.color_=t}getKey(){let t=this.getColor();return t?t instanceof CanvasPattern||t instanceof CanvasGradient?U(t):typeof t=="object"&&"src"in t?t.src+":"+t.offset:_e(t).toString():""}loading(){return!!this.patternImage_}ready(){return this.patternImage_?this.patternImage_.ready():Promise.resolve()}},Pe=Vl;function Jd(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}var Bl=class n extends go{constructor(t){t=t||{};let e=t.opacity!==void 0?t.opacity:1,i=t.rotation!==void 0?t.rotation:0,r=t.scale!==void 0?t.scale:1,s=t.rotateWithView!==void 0?t.rotateWithView:!1;super({opacity:e,rotation:i,scale:r,displacement:t.displacement!==void 0?t.displacement:[0,0],rotateWithView:s,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,this.referrerPolicy_=t.referrerPolicy;let o=t.img!==void 0?t.img:null,a=t.src;V(!(a!==void 0&&o),"`image` and `src` cannot be provided at the same time"),(a===void 0||a.length===0)&&o&&(a=o.src||U(o)),V(a!==void 0&&a.length>0,"A defined and non-empty `src` or `image` must be provided"),V(!((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=b.IDLE:o!==void 0&&("complete"in o?o.complete?l=o.src?b.LOADED:b.IDLE:l=b.LOADING:l=b.LOADED),this.color_=t.color!==void 0?_e(t.color):null,this.iconImage_=Xi(o,a,{crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_},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 c,h;if(t.size)[c,h]=t.size;else{let u=this.getImage(1);if(u.width&&u.height)c=u.width,h=u.height;else if(u instanceof HTMLImageElement){this.initialOptions_=t;let d=()=>{if(this.unlistenImageChange(d),!this.initialOptions_)return;let f=this.iconImage_.getSize();this.setScale(Jd(f[0],f[1],t.width,t.height))};this.listenImageChange(d);return}}c!==void 0&&this.setScale(Jd(c,h,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 n({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_,referrerPolicy:this.referrerPolicy_,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_;let r=this.getSize();if(this.anchorXUnits_=="fraction"||this.anchorYUnits_=="fraction"){if(!r)return null;t=this.anchor_.slice(),this.anchorXUnits_=="fraction"&&(t[0]*=r[0]),this.anchorYUnits_=="fraction"&&(t[1]*=r[1])}if(this.anchorOrigin_!="top-left"){if(!r)return null;t===this.anchor_&&(t=this.anchor_.slice()),(this.anchorOrigin_=="top-right"||this.anchorOrigin_=="bottom-right")&&(t[0]=-t[0]+r[0]),(this.anchorOrigin_=="bottom-left"||this.anchorOrigin_=="bottom-right")&&(t[1]=-t[1]+r[1])}this.normalizedAnchor_=t}let 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_}setColor(t){let e=t?_e(t):null;if(this.color_===e||this.color_&&e&&this.color_.length===e.length&&this.color_.every((o,a)=>o===e[a]))return;this.color_=e;let i=this.getSrc(),r=i!==void 0?null:this.getHitDetectionImage(),s=i!==void 0?b.IDLE:this.iconImage_.getImageState();this.iconImage_=Xi(r,i,{crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_},s,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"){let 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_=Xi(null,t,{crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_},b.IDLE,this.color_)}getSize(){return this.size_?this.size_:this.iconImage_.getSize()}getWidth(){let t=this.getScaleArray();if(this.size_)return this.size_[0]*t[0];if(this.iconImage_.getImageState()==b.LOADED)return this.iconImage_.getSize()[0]*t[0]}getHeight(){let t=this.getScaleArray();if(this.size_)return this.size_[1]*t[1];if(this.iconImage_.getImageState()==b.LOADED)return this.iconImage_.getSize()[1]*t[1]}setScale(t){delete this.initialOptions_,super.setScale(t)}listenImageChange(t){this.iconImage_.addEventListener(L.CHANGE,t)}load(){this.iconImage_.load()}unlistenImageChange(t){this.iconImage_.removeEventListener(L.CHANGE,t)}ready(){return this.iconImage_.ready()}},Vr=Bl;var Zl=class n{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.offset_=t.offset,this.width_=t.width}clone(){let t=this.getColor();return new n({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(),offset:this.getOffset(),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_}getOffset(){return this.offset_}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}setOffset(t){this.offset_=t}setWidth(t){this.width_=t}},Ki=Zl;var po=class n{constructor(t){t=t||{},this.geometry_=null,this.geometryFunction_=Qd,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 n({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_=Qd,this.geometry_=t}setZIndex(t){this.zIndex_=t}};function tf(n){let t;if(typeof n=="function")t=n;else{let e;Array.isArray(n)?e=n:(V(typeof n.getZIndex=="function","Expected an `Style` or an array of `Style`"),e=[n]),t=function(){return e}}return t}var Hl=null;function ql(n,t){if(!Hl){let e=new Pe({color:"rgba(255,255,255,0.4)"}),i=new Ki({color:"#3399CC",width:1.25});Hl=[new po({image:new Yi({fill:e,stroke:i,radius:5}),fill:e,stroke:i})]}return Hl}function Qd(n){return n.getGeometry()}var Ze=po;var op="#333",$l=class n{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_=ft(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 Pe({color:op}),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(){let t=this.getScale();return new n({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 Pe?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_=ft(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}},ef=$l;function ap(n){return!0}function of(n){let t=Fl(),e=lp(n,t),i=kl();return function(r,s){if(i.properties=r.getPropertiesInternal(),i.resolution=s,t.featureId){let o=r.getId();o!==void 0?i.featureId=o:i.featureId=null}return t.geometryType&&(i.geometryType=Dl(r.getGeometry())),e(i)}}function th(n){let t=Fl(),e=n.length,i=new Array(e);for(let o=0;o<e;++o)i[o]=Jl(n[o],t);let r=kl(),s=new Array(e);return function(o,a){if(r.properties=o.getPropertiesInternal(),r.resolution=a,t.featureId){let c=o.getId();c!==void 0?r.featureId=c:r.featureId=null}let l=0;for(let c=0;c<e;++c){let h=i[c](r);h&&(s[l]=h,l+=1)}return s.length=l,s}}function lp(n,t){let e=n.length,i=new Array(e);for(let r=0;r<e;++r){let s=n[r],o="filter"in s?Ae(s.filter,Ft,t):ap,a;if(Array.isArray(s.style)){let l=s.style.length;a=new Array(l);for(let c=0;c<l;++c)a[c]=Jl(s.style[c],t)}else a=[Jl(s.style,t)];i[r]={filter:o,styles:a}}return function(r){let s=[],o=!1;for(let a=0;a<e;++a){let l=i[a].filter;if(l(r)&&!(n[a].else&&o)){o=!0;for(let c of i[a].styles){let h=c(r);h&&s.push(h)}}}return s}}function Jl(n,t){let e=Br(n,"",t),i=Zr(n,"",t),r=hp(n,t),s=cp(n,t),o=At(n,"z-index",t);if(!e&&!i&&!r&&!s&&!$t(n))throw new Error("No fill, stroke, point, or text symbolizer properties in style: "+JSON.stringify(n));let a=new Ze;return function(l){let c=!0;if(e){let h=e(l);h&&(c=!1),a.setFill(h)}if(i){let h=i(l);h&&(c=!1),a.setStroke(h)}if(r){let h=r(l);h&&(c=!1),a.setText(h)}if(s){let h=s(l);h&&(c=!1),a.setImage(h)}return o&&a.setZIndex(o(l)),c?null:a}}function Br(n,t,e){let i;if(t+"fill-pattern-src"in n)i=gp(n,t+"fill-",e);else{if(n[t+"fill-color"]==="none")return s=>null;i=yo(n,t+"fill-color",e)}if(!i)return null;let r=new Pe;return function(s){let o=i(s);return o===ao?null:(r.setColor(o),r)}}function Zr(n,t,e){let i=At(n,t+"stroke-width",e),r=yo(n,t+"stroke-color",e);if(!i&&!r)return null;let s=mi(n,t+"stroke-line-cap",e),o=mi(n,t+"stroke-line-join",e),a=af(n,t+"stroke-line-dash",e),l=At(n,t+"stroke-line-dash-offset",e),c=At(n,t+"stroke-miter-limit",e),h=At(n,t+"stroke-offset",e),u=new Ki;return function(d){if(r){let f=r(d);if(f===ao)return null;u.setColor(f)}if(i&&u.setWidth(i(d)),s){let f=s(d);if(f!=="butt"&&f!=="round"&&f!=="square")throw new Error("Expected butt, round, or square line cap");u.setLineCap(f)}if(o){let f=o(d);if(f!=="bevel"&&f!=="round"&&f!=="miter")throw new Error("Expected bevel, round, or miter line join");u.setLineJoin(f)}return a&&u.setLineDash(a(d)),l&&u.setLineDashOffset(l(d)),c&&u.setMiterLimit(c(d)),h&&u.setOffset(h(d)),u}}function hp(n,t){let e="text-",i=mi(n,e+"value",t);if(!i)return null;let r=Br(n,e,t),s=Br(n,e+"background-",t),o=Zr(n,e,t),a=Zr(n,e+"background-",t),l=mi(n,e+"font",t),c=At(n,e+"max-angle",t),h=At(n,e+"offset-x",t),u=At(n,e+"offset-y",t),d=Yn(n,e+"overflow",t),f=mi(n,e+"placement",t),g=At(n,e+"repeat",t),p=xo(n,e+"scale",t),m=Yn(n,e+"rotate-with-view",t),_=At(n,e+"rotation",t),y=mi(n,e+"align",t),E=mi(n,e+"justify",t),x=mi(n,e+"baseline",t),C=Yn(n,e+"keep-upright",t),T=af(n,e+"padding",t),I=Eo(n,e+"declutter-mode"),S=new ef({declutterMode:I});return function(w){if(S.setText(i(w)),r&&S.setFill(r(w)),s&&S.setBackgroundFill(s(w)),o&&S.setStroke(o(w)),a&&S.setBackgroundStroke(a(w)),l&&S.setFont(l(w)),c&&S.setMaxAngle(c(w)),h&&S.setOffsetX(h(w)),u&&S.setOffsetY(u(w)),d&&S.setOverflow(d(w)),f){let M=f(w);if(M!=="point"&&M!=="line")throw new Error("Expected point or line for text-placement");S.setPlacement(M)}if(g&&S.setRepeat(g(w)),p&&S.setScale(p(w)),m&&S.setRotateWithView(m(w)),_&&S.setRotation(_(w)),y){let M=y(w);if(M!=="left"&&M!=="center"&&M!=="right"&&M!=="end"&&M!=="start")throw new Error("Expected left, right, center, start, or end for text-align");S.setTextAlign(M)}if(E){let M=E(w);if(M!=="left"&&M!=="right"&&M!=="center")throw new Error("Expected left, right, or center for text-justify");S.setJustify(M)}if(x){let M=x(w);if(M!=="bottom"&&M!=="top"&&M!=="middle"&&M!=="alphabetic"&&M!=="hanging")throw new Error("Expected bottom, top, middle, alphabetic, or hanging for text-baseline");S.setTextBaseline(M)}return T&&S.setPadding(T(w)),C&&S.setKeepUpright(C(w)),S}}function cp(n,t){return"icon-src"in n?up(n,t):"shape-points"in n?dp(n,t):"circle-radius"in n?fp(n,t):null}function up(n,t){let e="icon-",i=e+"src",r=lf(n[i],i),s=_o(n,e+"anchor",t),o=xo(n,e+"scale",t),a=At(n,e+"opacity",t),l=_o(n,e+"displacement",t),c=At(n,e+"rotation",t),h=Yn(n,e+"rotate-with-view",t),u=rf(n,e+"anchor-origin"),d=sf(n,e+"anchor-x-units"),f=sf(n,e+"anchor-y-units"),g=pi(n,e+"color"),p,m=null;g!==void 0&&(Array.isArray(g)&&g.length>0&&typeof g[0]=="string"?m=yo(n,e+"color",t):p=hf(g,e+"color"));let _=pp(n,e+"cross-origin"),y=_p(n,e+"offset"),E=rf(n,e+"offset-origin"),x=Ql(n,e+"width"),C=Ql(n,e+"height"),T=mp(n,e+"size"),I=Eo(n,e+"declutter-mode"),S={src:r,anchorOrigin:u,anchorXUnits:d,anchorYUnits:f,crossOrigin:_,offset:y,offsetOrigin:E,height:C,width:x,size:T,declutterMode:I},w=null;return function(M){if(w)m&&w.setColor(m(M));else{let N=m?m(M):p;w=new Vr(N!==void 0?Object.assign({},S,{color:N}):Object.assign({},S))}return a&&w.setOpacity(a(M)),l&&w.setDisplacement(l(M)),c&&w.setRotation(c(M)),h&&w.setRotateWithView(h(M)),o&&w.setScale(o(M)),s&&w.setAnchor(s(M)),w}}function dp(n,t){let e="shape-",i=e+"points",r=e+"radius",s=eh(n[i],i);if(!(r in n))throw new Error(`Expected a number for ${r}`);let o=At(n,r,t),a=typeof n[r]=="number"?n[r]:5,l=e+"radius2",c=At(n,l,t),h=typeof n[l]=="number"?n[l]:void 0,u=Br(n,e,t),d=Zr(n,e,t),f=xo(n,e+"scale",t),g=_o(n,e+"displacement",t),p=At(n,e+"rotation",t),m=Yn(n,e+"rotate-with-view",t),_=Ql(n,e+"angle"),y=Eo(n,e+"declutter-mode"),E=new mo({points:s,radius:a,radius2:h,angle:_,declutterMode:y});return function(x){return o&&E.setRadius(o(x)),c&&E.setRadius2(c(x)),u&&E.setFill(u(x)),d&&E.setStroke(d(x)),g&&E.setDisplacement(g(x)),p&&E.setRotation(p(x)),m&&E.setRotateWithView(m(x)),f&&E.setScale(f(x)),E}}function fp(n,t){let e="circle-",i=Br(n,e,t),r=Zr(n,e,t),s=At(n,e+"radius",t),o=xo(n,e+"scale",t),a=_o(n,e+"displacement",t),l=At(n,e+"rotation",t),c=Yn(n,e+"rotate-with-view",t),h=Eo(n,e+"declutter-mode"),u=new Yi({radius:5,declutterMode:h});return function(d){return s&&u.setRadius(s(d)),i&&u.setFill(i(d)),r&&u.setStroke(r(d)),a&&u.setDisplacement(a(d)),l&&u.setRotation(l(d)),c&&u.setRotateWithView(c(d)),o&&u.setScale(o(d)),u}}function pi(n,t){if(!(t in n))return;let e=n[t];return e===void 0?void 0:e}function At(n,t,e){let i=pi(n,t);if(i===void 0)return;let r=Ae(i,J,e);return function(s){return eh(r(s),t)}}function mi(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,zt,e);return function(s){return lf(r(s),t)}}function gp(n,t,e){let i=mi(n,t+"pattern-src",e),r=nf(n,t+"pattern-offset",e),s=nf(n,t+"pattern-size",e),o=yo(n,t+"color",e);return function(a){return{src:i(a),offset:r&&r(a),size:s&&s(a),color:o&&o(a)}}}function Yn(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Ft,e);return function(s){let o=r(s);if(typeof o!="boolean")throw new Error(`Expected a boolean for ${t}`);return o}}function yo(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,te,e);return function(s){return hf(r(s),t)}}function af(n,t,e){let i=pi(n,t);if(i===void 0)return null;if(Array.isArray(i)&&(i.length===0||typeof i[0]!="string")){let s=i.map((o,a)=>{if(typeof o=="number")return()=>o;let l=Ae(o,J,e);return function(c){return eh(l(c),`${t}[${a}]`)}});return function(o){let a=new Array(s.length);for(let l=0;l<s.length;++l)a[l]=s[l](o);return a}}let r=Ae(i,Wi,e);return function(s){return Hr(r(s),t)}}function _o(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Wi,e);return function(s){let o=Hr(r(s),t);if(o.length!==2)throw new Error(`Expected two numbers for ${t}`);return o}}function nf(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Wi,e);return function(s){return cf(r(s),t)}}function xo(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Wi|J,e);return function(s){return yp(r(s),t)}}function Ql(n,t){let e=n[t];if(e!==void 0){if(typeof e!="number")throw new Error(`Expected a number for ${t}`);return e}}function mp(n,t){let e=n[t];if(e!==void 0){if(typeof e=="number")return ft(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 pp(n,t){let e=n[t];if(e!==void 0){if(typeof e!="string")throw new Error(`Expected a string for ${t}`);return e}}function rf(n,t){let 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 sf(n,t){let e=n[t];if(e!==void 0){if(e!=="pixels"&&e!=="fraction")throw new Error(`Expected pixels or fraction for ${t}`);return e}}function _p(n,t){let e=n[t];if(e!==void 0)return Hr(e,t)}function Eo(n,t){let 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 Hr(n,t){if(!Array.isArray(n))throw new Error(`Expected an array for ${t}`);let 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 lf(n,t){if(typeof n!="string")throw new Error(`Expected a string for ${t}`);return n}function eh(n,t){if(typeof n!="number")throw new Error(`Expected a number for ${t}`);return n}function hf(n,t){if(typeof n=="string")return n;let e=Hr(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 cf(n,t){let e=Hr(n,t);if(e.length!==2)throw new Error(`Expected an array of two numbers for ${t}`);return e}function yp(n,t){return typeof n=="number"?n:cf(n,t)}var uf={RENDER_ORDER:"renderOrder"},ih=class extends ci{constructor(t){t=t||{};let 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(uf.RENDER_ORDER)}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}getUpdateWhileAnimating(){return this.updateWhileAnimating_}getUpdateWhileInteracting(){return this.updateWhileInteracting_}renderDeclutter(t,e){let i=this.getDeclutter();i in t.declutter||(t.declutter[i]=new ln(9)),this.getRenderer().renderDeclutter(t,e)}setRenderOrder(t){this.set(uf.RENDER_ORDER,t)}setStyle(t){this.style_=t===void 0?ql:t;let e=xp(t);this.styleFunction_=t===null?void 0:tf(e),this.changed()}setDeclutter(t){this.declutter_=t?String(t):void 0,this.changed()}};function xp(n){if(n===void 0)return ql;if(!n)return null;if(typeof n=="function"||n instanceof Ze)return n;if(!Array.isArray(n))return th([n]);if(n.length===0)return[];let t=n.length,e=n[0];if(e instanceof Ze){let r=new Array(t);for(let s=0;s<t;++s){let o=n[s];if(!(o instanceof Ze))throw new Error("Expected a list of style instances");r[s]=o}return r}if("style"in e){let r=new Array(t);for(let s=0;s<t;++s){let o=n[s];if(!("style"in o))throw new Error("Expected a list of rules with a style property");r[s]=o}return of(r)}return th(n)}var Co=ih;var nh=class extends mt{constructor(t,e,i,r){super(t),this.inversePixelTransform=e,this.frameState=i,this.context=r}},Ro=nh;var rh=class extends Ci{constructor(t){super(),this.map_=t}dispatchRenderEvent(t,e){F()}calculateMatrices2D(t){let e=t.viewState,i=t.coordinateToPixelTransform,r=t.pixelToCoordinateTransform;Et(i,t.size[0]/2,t.size[1]/2,1/e.resolution,-1/e.resolution,-e.rotation,-e.center[0],-e.center[1]),Gs(r,i)}forEachFeatureAtCoordinate(t,e,i,r,s,o,a,l){let c,h=e.viewState;function u(x,C,T,I){return s.call(o,C,x?T:null,I)}let d=h.projection,f=Tn(t.slice(),d),g=[[0,0]];if(d.canWrapX()&&r){let x=d.getExtent(),C=W(x);g.push([-C,0],[C,0])}let p=e.layerStatesArray,m=p.length,_=[],y=[];for(let x=0;x<g.length;x++)for(let C=m-1;C>=0;--C){let T=p[C],I=T.layer;if(I.hasRenderer()&&Pr(T,h)&&a.call(l,I)){let S=I.getRenderer(),w=I.getSource();if(S&&w){let M=w.getWrapX()?f:t,N=u.bind(null,T.managed);y[0]=M[0]+g[x][0],y[1]=M[1]+g[x][1],c=S.forEachFeatureAtCoordinate(y,e,i,N,_)}if(c)return c}}if(_.length===0)return;let E=1/_.length;return _.forEach((x,C)=>x.distanceSq+=C*E),_.sort((x,C)=>x.distanceSq-C.distanceSq),_.some(x=>c=x.callback(x.feature,x.layer,x.geometry)),c}hasFeatureAtCoordinate(t,e,i,r,s,o){return this.forEachFeatureAtCoordinate(t,e,i,r,ei,this,s,o)!==void 0}getMap(){return this.map_}renderFrame(t){F()}scheduleExpireIconCache(t){Dt.canExpireCache()&&t.postRenderFunctions.push(Ep)}};function Ep(n,t){Dt.expire()}var df=rh;var sh=class extends df{constructor(t){super(t),this.fontChangeListenerKey_=G(cn,Ee.PROPERTYCHANGE,t.redrawText,t),this.element_=xt?qs():document.createElement("div");let e=this.element_.style;e.position="absolute",e.width="100%",e.height="100%",e.zIndex="0",this.element_.className=ge+" ol-layers";let i=t.getViewport();i&&i.insertBefore(this.element_,i.firstChild||null),this.children_=[],this.renderedVisible_=!0}dispatchRenderEvent(t,e){let i=this.getMap();if(i.hasListener(t)){let r=new Ro(t,void 0,e);i.dispatchEvent(r)}}disposeInternal(){B(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(Lt.PRECOMPOSE,t);let e=t.layerStatesArray.sort((c,h)=>c.zIndex-h.zIndex);e.some(c=>c.layer instanceof Co&&c.layer.getDeclutter())&&(t.declutter={});let r=t.viewState;this.children_.length=0;let s=[],o=null;for(let c=0,h=e.length;c<h;++c){let u=e[c];t.layerIndex=c;let d=u.layer,f=d.getSourceState();if(!Pr(u,r)||f!="ready"&&f!="undefined"){d.unrender();continue}let g=d.render(t,o);g&&(g!==o&&(this.children_.push(g),o=g),s.push(u))}this.declutter(t,s),pd(this.element_,this.children_);let l=this.getMap().getTargetElement();if(Me(l)){let c=l.getContext("2d");for(let h of this.children_){let u=h.firstElementChild||h,d=h.style.backgroundColor;if(d&&(!Me(u)||u.width>0)&&(c.fillStyle=d,c.fillRect(0,0,l.width,l.height)),Me(u)&&u.width>0){c.save();let f=h.style.opacity||u.style.opacity;c.globalAlpha=f===""?1:Number(f);let g=u.style.transform;if(g)c.transform(...Ns(g));else{let p=parseFloat(u.style.width)/u.width,m=parseFloat(u.style.height)/u.height;c.transform(p,0,0,m,0,0)}c.drawImage(u,0,0),c.restore()}}}this.dispatchRenderEvent(Lt.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){let r=e[i],s=r.layer;s.getDeclutter()&&s.renderDeclutter(t,r)}e.forEach(i=>i.layer.renderDeferred(t))}}},ff=sh;function gf(n){if(n instanceof ci){n.setMapInternal(null);return}n instanceof Ar&&n.getLayers().forEach(gf)}function mf(n,t){if(n instanceof ci){n.setMapInternal(t);return}if(n instanceof Ar){let e=n.getLayers().getArray();for(let i=0,r=e.length;i<r;++i)mf(e[i],t)}}var oh=class extends pt{constructor(t){super(),t=t||{},this.on,this.once,this.un;let e=Cp(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:iu,this.postRenderTimeoutHandle_,this.animationDelayKey_,this.animationDelay_=this.animationDelay_.bind(this),this.coordinateToPixelTransform_=Tt(),this.pixelToCoordinateTransform_=Tt(),this.frameIndex_=0,this.frameState_=null,this.previousExtent_=null,this.viewPropertyListenerKey_=null,this.viewChangeListenerKey_=null,this.layerGroupPropertyListenerKeys_=null,xt||(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,xt||(this.resizeObserver_=new ResizeObserver(()=>this.updateSize())),this.controls=e.controls||(xt?new Mt:kn()),this.interactions=e.interactions||(xt?new Mt:jn({onFocusOnly:!0})),this.overlays_=e.overlays,this.overlayIdIndex_={},this.renderer_=null,this.postRenderFunctions_=[],this.tileQueue_=new su(this.getTilePriority.bind(this),this.handleTileChange_.bind(this)),this.addChangeListener(_t.LAYERGROUP,this.handleLayerGroupChanged_),this.addChangeListener(_t.VIEW,this.handleViewChanged_),this.addChangeListener(_t.SIZE,this.handleSizeChanged_),this.addChangeListener(_t.TARGET,this.handleTargetChanged_),this.setProperties(e.values);let i=this;t.view&&!(t.view instanceof Bt)&&t.view.then(function(r){i.setView(new Bt(r))}),this.controls.addEventListener(wt.ADD,r=>{r.element.setMap(this)}),this.controls.addEventListener(wt.REMOVE,r=>{r.element.setMap(null)}),this.interactions.addEventListener(wt.ADD,r=>{r.element.setMap(this)}),this.interactions.addEventListener(wt.REMOVE,r=>{r.element.setMap(null)}),this.overlays_.addEventListener(wt.ADD,r=>{this.addOverlayInternal_(r.element)}),this.overlays_.addEventListener(wt.REMOVE,r=>{let s=r.element.getId();s!==void 0&&delete this.overlayIdIndex_[s.toString()],r.element.setMap(null)}),this.controls.forEach(r=>{r.setMap(this)}),this.interactions.forEach(r=>{r.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){mf(t.layer,this)}addOverlay(t){this.getOverlays().push(t)}addOverlayInternal_(t){let 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;let r=this.getCoordinateFromPixelInternal(t);i=i!==void 0?i:{};let s=i.hitTolerance!==void 0?i.hitTolerance:0,o=i.layerFilter!==void 0?i.layerFilter:ei,a=i.checkWrapped!==!1;return this.renderer_.forEachFeatureAtCoordinate(r,this.frameState_,s,a,e,null,o,null)}getFeaturesAtPixel(t,e){let i=[];return this.forEachFeatureAtPixel(t,function(r){i.push(r)},e),i}getAllLayers(){let t=[];function e(i){i.forEach(function(r){r instanceof Ar?e(r.getLayers()):t.push(r)})}return e(this.getLayers()),t}hasFeatureAtPixel(t,e){if(!this.frameState_||!this.renderer_)return!1;let i=this.getCoordinateFromPixelInternal(t);e=e!==void 0?e:{};let r=e.layerFilter!==void 0?e.layerFilter:ei,s=e.hitTolerance!==void 0?e.hitTolerance:0,o=e.checkWrapped!==!1;return this.renderer_.hasFeatureAtCoordinate(i,this.frameState_,s,o,r,null)}getEventCoordinate(t){return this.getCoordinateFromPixel(this.getEventPixel(t))}getEventCoordinateInternal(t){return this.getCoordinateFromPixelInternal(this.getEventPixel(t))}getEventPixel(t){let i=this.viewport_.getBoundingClientRect(),r=this.getSize(),s=i.width/r[0],o=i.height/r[1],a="changedTouches"in t?t.changedTouches[0]:t;return[(a.clientX-i.left)/s,(a.clientY-i.top)/o]}getTarget(){return this.get(_t.TARGET)}getTargetElement(){return this.targetElement_}getCoordinateFromPixel(t){return gr(this.getCoordinateFromPixelInternal(t),this.getView().getProjection())}getCoordinateFromPixelInternal(t){let e=this.frameState_;return e?ht(e.pixelToCoordinateTransform,t.slice()):null}getControls(){return this.controls}getOverlays(){return this.overlays_}getOverlayById(t){let e=this.overlayIdIndex_[t.toString()];return e!==void 0?e:null}getInteractions(){return this.interactions}getLayerGroup(){return this.get(_t.LAYERGROUP)}setLayers(t){let e=this.getLayerGroup();if(t instanceof Mt){e.setLayers(t);return}let i=e.getLayers();i.clear(),i.extend(t)}getLayers(){return this.getLayerGroup().getLayers()}getLoadingOrNotReady(){let t=this.getLayerGroup().getLayerStatesArray();for(let e=0,i=t.length;e<i;++e){let r=t[e];if(!r.visible)continue;let s=r.layer.getRenderer();if(s&&!s.ready)return!0;let o=r.layer.getSource();if(o&&o.loading)return!0}return!1}getPixelFromCoordinate(t){let e=Ie(t,this.getView().getProjection());return this.getPixelFromCoordinateInternal(e)}getPixelFromCoordinateInternal(t){let e=this.frameState_;return e?ht(e.coordinateToPixelTransform,t.slice(0,2)):null}getPixelRatio(){return this.pixelRatio_}setPixelRatio(t){this.pixelRatio_!==t&&(this.pixelRatio_=t,this.render())}getRenderer(){return this.renderer_}getSize(){return this.get(_t.SIZE)}getView(){return this.get(_t.VIEW)}getViewport(){return this.viewport_}getOverlayContainer(){return this.overlayContainer_}getOverlayContainerStopEvent(){return this.overlayContainerStopEvent_}getOwnerDocument(){let t=this.getTargetElement();return t?t.ownerDocument:document}getTilePriority(t,e,i,r){return ou(this.frameState_,t,e,i,r)}handleBrowserEvent(t,e){e=e||t.type;let i=new We(e,this,t);this.handleMapBrowserEvent(i)}handleMapBrowserEvent(t){if(!this.frameState_)return;let e=t.originalEvent,i=e.type;if(i===Si.POINTERDOWN||i===L.WHEEL||i===L.KEYDOWN){let r=this.getOwnerDocument(),s=this.viewport_.getRootNode?this.viewport_.getRootNode():r,o=e.target,a=s instanceof ShadowRoot?s.host===o?s.host.ownerDocument:s:s===r?r.documentElement:s;if(this.overlayContainerStopEvent_.contains(o)||!a.contains(o))return}if(t.frameState=this.frameState_,this.dispatchEvent(t)!==!1){let r=this.getInteractions().getArray().slice();for(let s=r.length-1;s>=0;s--){let o=r[s];if(o.getMap()!==this||!o.getActive()||!this.getTargetElement())continue;if(!o.handleEvent(t)||t.propagationStopped)break}}}handlePostRender(){let t=this.frameState_,e=this.tileQueue_;if(!e.isEmpty()){let r=this.maxTilesLoading_,s=r;if(t){let o=t.viewHints;if(o[dt.ANIMATING]||o[dt.INTERACTING]){let a=Date.now()-t.time>8;r=a?0:8,s=a?0:2}}e.getTilesLoading()<r&&(e.reprioritize(),e.loadMoreTiles(r,s))}t&&this.renderer_&&!t.animate&&(this.renderComplete_?(this.hasListener(Lt.RENDERCOMPLETE)&&this.renderer_.dispatchRenderEvent(Lt.RENDERCOMPLETE,t),this.loaded_===!1&&(this.loaded_=!0,this.dispatchEvent(new wi(Xe.LOADEND,this,t)))):this.loaded_===!0&&(this.loaded_=!1,this.dispatchEvent(new wi(Xe.LOADSTART,this,t))));let i=this.postRenderFunctions_;if(t)for(let r=0,s=i.length;r<s;++r)i[r](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,r=this.targetChangeHandlerKeys_.length;i<r;++i)B(this.targetChangeHandlerKeys_[i]);this.targetChangeHandlerKeys_=null,this.viewport_.removeEventListener(L.CONTEXTMENU,this.boundHandleBrowserEvent_),this.viewport_.removeEventListener(L.WHEEL,this.boundHandleBrowserEvent_),this.mapBrowserEventHandler_.dispose(),this.mapBrowserEventHandler_=null,this.viewport_.remove()}if(this.targetElement_&&!Me(this.targetElement_)){this.resizeObserver_?.unobserve(this.targetElement_);let i=this.targetElement_.getRootNode();i instanceof ShadowRoot&&this.resizeObserver_.unobserve(i.host),this.setSize(void 0)}let 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(Me(e)||e.appendChild(this.viewport_),this.renderer_||(this.renderer_=new ff(this)),!Me(e)){this.mapBrowserEventHandler_=new nu(this,this.moveTolerance_);for(let r in at)this.mapBrowserEventHandler_.addEventListener(at[r],this.handleMapBrowserEvent.bind(this));this.viewport_.addEventListener(L.CONTEXTMENU,this.boundHandleBrowserEvent_,!1),this.viewport_.addEventListener(L.WHEEL,this.boundHandleBrowserEvent_,Es?{passive:!1}:!1);let i;if(this.keyboardEventTarget_)i=this.keyboardEventTarget_;else{let r=e.getRootNode();i=r instanceof ShadowRoot?r.host:e}if(this.targetChangeHandlerKeys_=[G(i,L.KEYDOWN,this.handleBrowserEvent,this),G(i,L.KEYPRESS,this.handleBrowserEvent,this)],e instanceof HTMLElement){let r=e.getRootNode();r instanceof ShadowRoot&&this.resizeObserver_.observe(r.host),this.resizeObserver_?.observe(e)}}this.updateSize()}}handleTileChange_(){this.render()}handleViewPropertyChanged_(){this.render()}handleViewChanged_(){this.viewPropertyListenerKey_&&(B(this.viewPropertyListenerKey_),this.viewPropertyListenerKey_=null),this.viewChangeListenerKey_&&(B(this.viewChangeListenerKey_),this.viewChangeListenerKey_=null);let t=this.getView();t&&(this.updateViewportSize_(this.getSize()),this.viewPropertyListenerKey_=G(t,Ee.PROPERTYCHANGE,this.handleViewPropertyChanged_,this),this.viewChangeListenerKey_=G(t,L.CHANGE,this.handleViewPropertyChanged_,this),t.resolveConstraints(0)),this.render()}handleLayerGroupChanged_(){this.layerGroupPropertyListenerKeys_&&(this.layerGroupPropertyListenerKeys_.forEach(B),this.layerGroupPropertyListenerKeys_=null);let t=this.getLayerGroup();t&&(this.handleLayerAdd_(new be("addlayer",t)),this.layerGroupPropertyListenerKeys_=[G(t,Ee.PROPERTYCHANGE,this.render,this),G(t,L.CHANGE,this.render,this),G(t,"addlayer",this.handleLayerAdd_,this),G(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;let t=this.frameState_.layerStatesArray;for(let e=0,i=t.length;e<i;++e){let r=t[e].layer;r.hasRenderer()&&r.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){gf(t.layer)}removeOverlay(t){return this.getOverlays().remove(t)}renderFrame_(t){let e=this.getSize(),i=this.getView(),r=this.frameState_,s=null;if(e!==void 0&&Ll(e)&&i&&i.isDef()){let o=i.getHints(this.frameState_?this.frameState_.viewHints:void 0),a=i.getState();if(s={animate:!1,coordinateToPixelTransform:this.coordinateToPixelTransform_,declutter:null,extent:oi(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:U(this),renderTargets:{}},a.nextCenter&&a.nextResolution){let l=isNaN(a.nextRotation)?a.rotation:a.nextRotation;s.nextExtent=oi(a.nextCenter,a.nextResolution,l,e)}}this.frameState_=s,this.renderer_.renderFrame(s),s&&(s.animate&&this.render(),Array.prototype.push.apply(this.postRenderFunctions_,s.postRenderFunctions),r&&(!this.previousExtent_||!Yt(this.previousExtent_)&&!we(s.extent,this.previousExtent_))&&(this.dispatchEvent(new wi(Xe.MOVESTART,this,r)),this.previousExtent_=si(this.previousExtent_)),this.previousExtent_&&!s.viewHints[dt.ANIMATING]&&!s.viewHints[dt.INTERACTING]&&!we(s.extent,this.previousExtent_)&&(this.dispatchEvent(new wi(Xe.MOVEEND,this,s)),Ss(s.extent,this.previousExtent_))),this.dispatchEvent(new wi(Xe.POSTRENDER,this,s)),this.renderComplete_=(this.hasListener(Xe.LOADSTART)||this.hasListener(Xe.LOADEND)||this.hasListener(Lt.RENDERCOMPLETE))&&!this.tileQueue_.getTilesLoading()&&!this.tileQueue_.getCount()&&!this.getLoadingOrNotReady(),this.postRenderTimeoutHandle_||(this.postRenderTimeoutHandle_=setTimeout(()=>{this.postRenderTimeoutHandle_=void 0,this.handlePostRender()},0))}setLayerGroup(t){let e=this.getLayerGroup();e&&this.handleLayerRemove_(new be("removelayer",e)),this.set(_t.LAYERGROUP,t)}setSize(t){this.set(_t.SIZE,t)}setTarget(t){this.set(_t.TARGET,t)}setView(t){if(!t||t instanceof Bt){this.set(_t.VIEW,t);return}this.set(_t.VIEW,new Bt);let e=this;t.then(function(i){e.setView(new Bt(i))})}updateSize(){let t=this.getTargetElement(),e;if(t){let r,s;if(Me(t)){let o=t.getContext("2d").getTransform();r=t.width/o.a,s=t.height/o.d}else{let o=getComputedStyle(t);r=t.offsetWidth-parseFloat(o.borderLeftWidth)-parseFloat(o.paddingLeft)-parseFloat(o.paddingRight)-parseFloat(o.borderRightWidth),s=t.offsetHeight-parseFloat(o.borderTopWidth)-parseFloat(o.paddingTop)-parseFloat(o.paddingBottom)-parseFloat(o.borderBottomWidth)}!isNaN(r)&&!isNaN(s)&&(e=[Math.max(0,r),Math.max(0,s)],!Ll(e)&&(t.offsetWidth||t.offsetHeight||t.getClientRects().length)&&bs("No map visible because the map container's width or height are 0."))}let i=this.getSize();e&&(!i||!Ot(e,i))&&(this.setSize(e),this.updateViewportSize_(e))}updateViewportSize_(t){let e=this.getView();e&&e.setViewportSize(t)}};function Cp(n){let t=null;n.keyboardEventTarget!==void 0&&(t=typeof n.keyboardEventTarget=="string"?document.getElementById(n.keyboardEventTarget):n.keyboardEventTarget);let e={},i=n.layers&&typeof n.layers.getLayers=="function"?n.layers:new Ar({layers:n.layers});e[_t.LAYERGROUP]=i,e[_t.TARGET]=n.target,e[_t.VIEW]=n.view instanceof Bt?n.view:new Bt;let r;n.controls!==void 0&&(Array.isArray(n.controls)?r=new Mt(n.controls.slice()):(V(typeof n.controls.getArray=="function","Expected `controls` to be an array or an `ol/Collection.js`"),r=n.controls));let s;n.interactions!==void 0&&(Array.isArray(n.interactions)?s=new Mt(n.interactions.slice()):(V(typeof n.interactions.getArray=="function","Expected `interactions` to be an array or an `ol/Collection.js`"),s=n.interactions));let o;return n.overlays!==void 0?Array.isArray(n.overlays)?o=new Mt(n.overlays.slice()):(V(typeof n.overlays.getArray=="function","Expected `overlays` to be an array or an `ol/Collection.js`"),o=n.overlays):o=new Mt,{controls:r,interactions:s,keyboardEventTarget:t,overlays:o,values:e}}var ah=oh;var lh=class extends je{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(L.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(){F()}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;let r=e-i+1e3/60;return r>=this.transition_?1:ya(r/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()}},Kn=lh;function wo(n){return n instanceof Image||n instanceof HTMLCanvasElement||n instanceof HTMLVideoElement||n instanceof ImageBitmap?n:null}var Rp=new Error("disposed");var wp=[256,256],hh=class extends Kn{constructor(t){let 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_;let t=wo(this.data_);return t?[t.width,t.height]:wp}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();let 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(Rp),this.controller_=null),super.disposeInternal()}},ch=hh;var uh=class extends Kn{constructor(t,e,i,r,s,o){super(t,e,o),this.crossOrigin_=r?.crossOrigin,this.referrerPolicy_=r?.referrerPolicy,this.src_=i,this.key=i,this.image_,xt?this.image_=new OffscreenCanvas(1,1):(this.image_=new Image,this.crossOrigin_!==null&&(this.image_.crossOrigin=this.crossOrigin_),this.referrerPolicy_!==void 0&&(this.image_.referrerPolicy=this.referrerPolicy_)),this.unlisten_=null,this.tileLoadFunction_=s}getImage(){return this.image_}setImage(t){this.image_=t,this.state=O.LOADED,this.unlistenImage_(),this.changed()}getCrossOrigin(){return this.crossOrigin_}getReferrerPolicy(){return this.referrerPolicy_}handleImageError_(){this.state=O.ERROR,this.unlistenImage_(),this.image_=Sp(),this.changed()}handleImageLoad_(){if(xt)this.state=O.LOADED;else{let 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.referrerPolicy_!==void 0&&(this.image_.referrerPolicy=this.referrerPolicy_)),this.state==O.IDLE&&(this.state=O.LOADING,this.changed(),this.tileLoadFunction_(this,this.src_),this.unlisten_=Ud(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 Sp(){let n=nt(1,1);return n.fillStyle="rgba(0,0,0,0)",n.fillRect(0,0,1,1),n.canvas}var So=uh;var To=class{constructor(t,e,i,r){this.minX=t,this.maxX=e,this.minY=i,this.maxY=r}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 dn(n,t,e,i,r){return r!==void 0?(r.minX=n,r.maxX=t,r.minY=e,r.maxY=i,r):new To(n,t,e,i)}var vo=To;var dh,fn=[];function pf(n,t,e,i,r){n.beginPath(),n.moveTo(0,0),n.lineTo(t,e),n.lineTo(i,r),n.closePath(),n.save(),n.clip(),n.fillRect(0,0,Math.max(t,i)+1,Math.max(e,r)),n.restore()}function fh(n,t){return Math.abs(n[t*4]-210)>2||Math.abs(n[t*4+3]-.75*255)>2}function Tp(){if(dh===void 0){let n=nt(6,6,fn);n.globalCompositeOperation="lighter",n.fillStyle="rgba(210, 0, 0, 0.75)",pf(n,4,5,4,0),pf(n,4,5,0,5);let t=n.getImageData(0,0,3,3).data;dh=fh(t,0)||fh(t,4)||fh(t,8),on(n),fn.push(n.canvas)}return dh}function Vi(n,t,e,i){let r=de(e,t,n),s=An(t,i,e),o=t.getMetersPerUnit();o!==void 0&&(s*=o);let a=n.getMetersPerUnit();a!==void 0&&(s/=a);let l=n.getExtent();if(!l||Jt(l,r)){let c=An(n,s,r)/s;isFinite(c)&&c>0&&(s/=c)}return s}function _f(n,t,e,i){let r=St(e),s=Vi(n,t,r,i);return(!isFinite(s)||s<=0)&&Is(e,function(o){return s=Vi(n,t,o,i),isFinite(s)&&s>0}),s}function Io(n,t,e,i,r,s,o,a,l,c,h,u,d,f){let g=nt(Math.round(e*n),Math.round(e*t),fn);if(u||(g.imageSmoothingEnabled=!1),l.length===0)return g.canvas;g.scale(e,e);function p(C){return Math.round(C*e)/e}g.globalCompositeOperation="lighter";let m=ct();l.forEach(function(C,T,I){vs(m,C.extent)});let _,y=e/i,E=(u?1:1+Math.pow(2,-24))/y;if(!d||l.length!==1||c!==0){if(_=nt(Math.round(W(m)*y),Math.round(et(m)*y),fn),u||(_.imageSmoothingEnabled=!1),r&&f){let C=(r[0]-m[0])*y,T=-(r[3]-m[3])*y,I=W(r)*y,S=et(r)*y;_.rect(C,T,I,S),_.clip()}l.forEach(function(C,T,I){if(C.image.width>0&&C.image.height>0){if(C.clipExtent){_.save();let z=(C.clipExtent[0]-m[0])*y,A=-(C.clipExtent[3]-m[3])*y,H=W(C.clipExtent)*y,$=et(C.clipExtent)*y;_.rect(u?z:Math.round(z),u?A:Math.round(A),u?H:Math.round(z+H)-Math.round(z),u?$:Math.round(A+$)-Math.round(A)),_.clip()}let S=(C.extent[0]-m[0])*y,w=-(C.extent[3]-m[3])*y,M=W(C.extent)*y,N=et(C.extent)*y;_.drawImage(C.image,c,c,C.image.width-2*c,C.image.height-2*c,u?S:Math.round(S),u?w:Math.round(w),u?M:Math.round(S+M)-Math.round(S),u?N:Math.round(w+N)-Math.round(w)),C.clipExtent&&_.restore()}})}let x=he(o);return a.getTriangles().forEach(function(C,T,I){let S=C.source,w=C.target,M=S[0][0],N=S[0][1],z=S[1][0],A=S[1][1],H=S[2][0],$=S[2][1],P=p((w[0][0]-x[0])/s),j=p(-(w[0][1]-x[1])/s),k=p((w[1][0]-x[0])/s),K=p(-(w[1][1]-x[1])/s),X=p((w[2][0]-x[0])/s),tt=p(-(w[2][1]-x[1])/s),it=M,ot=N;M=0,N=0,z-=it,A-=ot,H-=it,$-=ot;let kt=[[z,A,0,0,k-P],[H,$,0,0,X-P],[0,0,z,A,K-j],[0,0,H,$,tt-j]],v=lu(kt);if(!v)return;if(g.save(),g.beginPath(),Tp()||!u){g.moveTo(k,K);let Rt=4,ye=P-k,De=j-K;for(let ne=0;ne<Rt;ne++)g.lineTo(k+p((ne+1)*ye/Rt),K+p(ne*De/(Rt-1))),ne!=Rt-1&&g.lineTo(k+p((ne+1)*ye/Rt),K+p((ne+1)*De/(Rt-1)));g.lineTo(X,tt)}else g.moveTo(k,K),g.lineTo(P,j),g.lineTo(X,tt);g.clip(),g.transform(v[0],v[2],v[1],v[3],P,j),g.translate(m[0]-it,m[3]-ot);let ie;if(_)ie=_.canvas,g.scale(E,-E);else{let Rt=l[0],ye=Rt.extent;ie=Rt.image,g.scale(W(ye)/ie.width,-et(ye)/ie.height)}g.drawImage(ie,0,0),g.restore()}),_&&(on(_),fn.push(_.canvas)),h&&(g.save(),g.globalCompositeOperation="source-over",g.strokeStyle="black",g.lineWidth=1,a.getTriangles().forEach(function(C,T,I){let S=C.target,w=(S[0][0]-x[0])/s,M=-(S[0][1]-x[1])/s,N=(S[1][0]-x[0])/s,z=-(S[1][1]-x[1])/s,A=(S[2][0]-x[0])/s,H=-(S[2][1]-x[1])/s;g.beginPath(),g.moveTo(N,z),g.lineTo(w,M),g.lineTo(A,H),g.closePath(),g.stroke()}),g.restore()),g.canvas}var vp=10,yf=.25,gh=class{constructor(t,e,i,r,s,o,a){this.sourceProj_=t,this.targetProj_=e;let l={},c=a?ju(E=>ht(a,de(E,this.targetProj_,this.sourceProj_))):li(this.targetProj_,this.sourceProj_);this.transformInv_=function(E){let x=E[0]+"/"+E[1];return l[x]||(l[x]=c(E)),l[x]},this.maxSourceExtent_=r,this.errorThresholdSquared_=s*s,this.triangles_=[],this.wrapsXInSource_=!1,this.canWrapXInSource_=this.sourceProj_.canWrapX()&&!!r&&!!this.sourceProj_.getExtent()&&W(r)>=W(this.sourceProj_.getExtent()),this.sourceWorldWidth_=this.sourceProj_.getExtent()?W(this.sourceProj_.getExtent()):null,this.targetWorldWidth_=this.targetProj_.getExtent()?W(this.targetProj_.getExtent()):null;let h=he(i),u=wn(i),d=Rn(i),f=Cn(i),g=this.transformInv_(h),p=this.transformInv_(u),m=this.transformInv_(d),_=this.transformInv_(f),y=vp+(o?Math.max(0,Math.ceil(Math.log2(cr(i)/(o*o*256*256)))):0);if(this.addQuad_(h,u,d,f,g,p,m,_,y),this.wrapsXInSource_){let E=1/0;this.triangles_.forEach(function(x,C,T){E=Math.min(E,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])-E>this.sourceWorldWidth_/2){let C=[[x.source[0][0],x.source[0][1]],[x.source[1][0],x.source[1][1]],[x.source[2][0],x.source[2][1]]];C[0][0]-E>this.sourceWorldWidth_/2&&(C[0][0]-=this.sourceWorldWidth_),C[1][0]-E>this.sourceWorldWidth_/2&&(C[1][0]-=this.sourceWorldWidth_),C[2][0]-E>this.sourceWorldWidth_/2&&(C[2][0]-=this.sourceWorldWidth_);let T=Math.min(C[0][0],C[1][0],C[2][0]);Math.max(C[0][0],C[1][0],C[2][0])-T<this.sourceWorldWidth_/2&&(x.source=C)}})}l={}}addTriangle_(t,e,i,r,s,o){this.triangles_.push({source:[r,s,o],target:[t,e,i]})}addQuad_(t,e,i,r,s,o,a,l,c){let h=ga([s,o,a,l]),u=this.sourceWorldWidth_?W(h)/this.sourceWorldWidth_:null,d=this.sourceWorldWidth_,f=this.sourceProj_.canWrapX()&&u>.5&&u<1,g=!1;if(c>0){if(this.targetProj_.isGlobal()&&this.targetWorldWidth_){let m=ga([t,e,i,r]);g=W(m)/this.targetWorldWidth_>yf||g}!f&&this.sourceProj_.isGlobal()&&u&&(g=u>yf||g)}if(!g&&this.maxSourceExtent_&&isFinite(h[0])&&isFinite(h[1])&&isFinite(h[2])&&isFinite(h[3])&&!lt(h,this.maxSourceExtent_))return;let p=0;if(!g&&(!isFinite(s[0])||!isFinite(s[1])||!isFinite(o[0])||!isFinite(o[1])||!isFinite(a[0])||!isFinite(a[1])||!isFinite(l[0])||!isFinite(l[1]))){if(c>0)g=!0;else if(p=(!isFinite(s[0])||!isFinite(s[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),p!=1&&p!=2&&p!=4&&p!=8)return}if(c>0){if(!g){let m=[(t[0]+i[0])/2,(t[1]+i[1])/2],_=this.transformInv_(m),y;f?y=(Wt(s[0],d)+Wt(a[0],d))/2-Wt(_[0],d):y=(s[0]+a[0])/2-_[0];let E=(s[1]+a[1])/2-_[1];g=y*y+E*E>this.errorThresholdSquared_}if(g){if(Math.abs(t[0]-i[0])<=Math.abs(t[1]-i[1])){let m=[(e[0]+i[0])/2,(e[1]+i[1])/2],_=this.transformInv_(m),y=[(r[0]+t[0])/2,(r[1]+t[1])/2],E=this.transformInv_(y);this.addQuad_(t,e,m,y,s,o,_,E,c-1),this.addQuad_(y,m,i,r,E,_,a,l,c-1)}else{let m=[(t[0]+e[0])/2,(t[1]+e[1])/2],_=this.transformInv_(m),y=[(i[0]+r[0])/2,(i[1]+r[1])/2],E=this.transformInv_(y);this.addQuad_(t,m,y,r,s,_,E,l,c-1),this.addQuad_(m,e,i,y,_,o,a,E,c-1)}return}}if(f){if(!this.canWrapXInSource_)return;this.wrapsXInSource_=!0}(p&11)==0&&this.addTriangle_(t,i,r,s,a,l),(p&14)==0&&this.addTriangle_(t,i,e,s,a,o),p&&((p&13)==0&&this.addTriangle_(e,r,t,o,l,s),(p&7)==0&&this.addTriangle_(e,r,i,o,l,a))}calculateSourceExtent(){let t=ct();return this.triangles_.forEach(function(e,i,r){let s=e.source;Qi(t,s[0]),Qi(t,s[1]),Qi(t,s[2])}),t}getTriangles(){return this.triangles_}},Mo=gh;var mh=class extends Kn{constructor(t,e,i,r,s,o,a,l,c,h,u,d){super(s,O.IDLE,d),this.renderEdges_=u!==void 0?u:!1,this.pixelRatio_=a,this.gutter_=l,this.canvas_=null,this.sourceTileGrid_=e,this.targetTileGrid_=r,this.wrappedTileCoord_=o||s,this.sourceTiles_=[],this.sourcesListenerKeys_=null,this.sourceZ_=0,this.clipExtent_=t.canWrapX()?t.getExtent():void 0;let f=r.getTileCoordExtent(this.wrappedTileCoord_),g=this.targetTileGrid_.getExtent(),p=this.sourceTileGrid_.getExtent(),m=g?Ut(f,g):f;if(cr(m)===0){this.state=O.EMPTY;return}let _=t.getExtent();_&&(p?p=Ut(p,_):p=_);let y=r.getResolution(this.wrappedTileCoord_[0]),E=_f(t,i,m,y);if(!isFinite(E)||E<=0){this.state=O.EMPTY;return}let x=h!==void 0?h:.5;if(this.triangulation_=new Mo(t,i,m,p,E*x,y),this.triangulation_.getTriangles().length===0){this.state=O.EMPTY;return}this.sourceZ_=e.getZForResolution(E);let C=this.triangulation_.calculateSourceExtent();if(p&&(t.canWrapX()?(C[1]=Q(C[1],p[1],p[3]),C[3]=Q(C[3],p[1],p[3])):C=Ut(C,p)),!cr(C))this.state=O.EMPTY;else{let T=0,I=0;t.canWrapX()&&(T=W(_),I=Math.floor((C[0]-_[0])/T)),Ms(C.slice(),t,!0).forEach(w=>{let M=e.getTileRangeForExtentAndZ(w,this.sourceZ_);for(let N=M.minX;N<=M.maxX;N++)for(let z=M.minY;z<=M.maxY;z++){let A=I*T;this.sourceTiles_.push({getTile:()=>c(this.sourceZ_,N,z,a),offset:A})}++I}),this.sourceTiles_.length===0&&(this.state=O.EMPTY)}}getImage(){return this.canvas_}reproject_(){let t=[];if(this.sourceTiles_.forEach(e=>{let i=e.tile;if(i&&i.getState()==O.LOADED){let r=this.sourceTileGrid_.getTileCoordExtent(i.tileCoord);r[0]+=e.offset,r[2]+=e.offset;let s=this.clipExtent_?.slice();s&&(s[0]+=e.offset,s[2]+=e.offset),t.push({extent:r,clipExtent:s,image:i.getImage()})}}),this.sourceTiles_.length=0,t.length===0)this.state=O.ERROR;else{let e=this.wrappedTileCoord_[0],i=this.targetTileGrid_.getTileSize(e),r=typeof i=="number"?i:i[0],s=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_=Io(r,s,this.pixelRatio_,a,this.sourceTileGrid_.getExtent(),o,l,this.triangulation_,t,this.gutter_,this.renderEdges_,this.interpolate),this.state=O.LOADED}this.changed()}load(){for(let t of this.sourceTiles_)t.tile=t.getTile();if(this.state==O.IDLE){this.state=O.LOADING,this.changed();let t=0;this.sourcesListenerKeys_=[],this.sourceTiles_.forEach(({tile:e})=>{let i=e.getState();if(i==O.IDLE||i==O.LOADING){t++;let r=G(e,L.CHANGE,s=>{let o=e.getState();(o==O.LOADED||o==O.ERROR||o==O.EMPTY)&&(B(r),t--,t===0&&(this.unlistenSources_(),this.reproject_()))});this.sourcesListenerKeys_.push(r)}}),t===0?setTimeout(this.reproject_.bind(this),0):this.sourceTiles_.forEach(function({tile:e},i,r){e.getState()==O.IDLE&&e.load()})}}unlistenSources_(){this.sourcesListenerKeys_.forEach(B),this.sourcesListenerKeys_=null}release(){this.canvas_&&(on(this.canvas_.getContext("2d")),fn.push(this.canvas_),this.canvas_=null),this.sourceTiles_.length=0,super.release()}},bo=mh;var ph=class{constructor(t){this.highWaterMark=t!==void 0?t:2048,this.count_=0,this.entries_={},this.oldest_=null,this.newest_=null}deleteOldest(){let t=this.pop();t instanceof Ci&&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){let i=this.entries_[t];return V(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){let e=this.entries_[t];return V(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(){let t=new Array(this.count_),e=0,i;for(i=this.newest_;i;i=i.older)t[e++]=i.key_;return t}getValues(){let t=new Array(this.count_),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(){let 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){V(!(t in this.entries_),"Tried to set a value for a key that is used already");let 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}},_h=ph;function Vn(n,t,e,i){return i!==void 0?(i[0]=n,i[1]=t,i[2]=e,i):[n,t,e]}function Mp(n,t,e){return n+"/"+t+"/"+e}function Bn(n,t,e,i,r){return`${U(n)},${t},${Mp(e,i,r)}`}function Lo(n){return bp(n[0],n[1],n[2])}function bp(n,t,e){return(t<<n)+e}function xf(n,t){let e=n[0],i=n[1],r=n[2];if(t.getMinZoom()>e||e>t.getMaxZoom())return!1;let s=t.getFullTileRange(e);return s?s.containsXY(i,r):!0}var yh=class{constructor(){this.instructions_=[],this.zIndex=0,this.offset_=0,this.context_=new Proxy(Fn(),{get:(t,e)=>{if(typeof Fn()[e]=="function")return this.push_(e),this.pushMethodArgs_},set:(t,e,i)=>(this.push_(e,i),!0)})}push_(...t){let 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,r=e.length;i<r;++i){let s=e[i];if(typeof s=="function"){s(t);continue}let o=e[++i];if(typeof t[s]=="function")t[s](...o);else{if(typeof o=="function"){t[s]=o(t);continue}t[s]=o}}})}clear(){this.instructions_.length=0,this.zIndex=0,this.offset_=0}offset(){this.offset_=this.instructions_.length,this.zIndex=0}},Ao=yh;var Lp=5,xh=class extends _s{constructor(t){super(),this.ready=!0,this.boundHandleImageChange_=this.handleImageChange_.bind(this),this.layer_=t,this.staleKeys_=new Array,this.maxStaleKeys=Lp}getStaleKeys(){return this.staleKeys_}prependStaleKey(t){this.staleKeys_.unshift(t),this.staleKeys_.length>this.maxStaleKeys&&(this.staleKeys_.length=this.maxStaleKeys)}getFeatures(t){return F()}getData(t){return null}prepareFrame(t){return F()}renderFrame(t,e){return F()}forEachFeatureAtCoordinate(t,e,i,r,s){}getLayer(){return this.layer_}handleFontsChanged(){}handleImageChange_(t){let e=t.target;(e.getState()===b.LOADED||e.getState()===b.ERROR)&&this.renderIfReadyAndVisible()}loadImage(t){let e=t.getState();return e!=b.LOADED&&e!=b.ERROR&&t.addEventListener(L.CHANGE,this.boundHandleImageChange_),e==b.IDLE&&(t.load(),e=t.getState()),e==b.LOADED}renderIfReadyAndVisible(){let t=this.getLayer();t&&t.getVisible()&&t.getSourceState()==="ready"&&t.changed()}renderDeferred(t){}disposeInternal(){delete this.layer_,super.disposeInternal()}},Ef=xh;var Ch=[],Zn=null;function Ap(){Zn=nt(1,1,void 0,{willReadFrequently:!0})}var Eh=class extends Ef{constructor(t){super(t),this.container=null,this.renderedResolution,this.tempTransform=Tt(),this.pixelTransform=Tt(),this.inversePixelTransform=Tt(),this.context=null,this.deferredContext_=null,this.containerReused=!1,this.frameState=null}getImageData(t,e,i){Zn||Ap(),Zn.clearRect(0,0,1,1);let r;try{Zn.drawImage(t,e,i,1,1,0,0,1,1),r=Zn.getImageData(0,0,1,1).data}catch{return Zn=null,null}return r}getBackground(t){let i=this.getLayer().getBackground();return typeof i=="function"&&(i=i(t.viewState.resolution)),i||void 0}useContainer(t,e,i){let r=this.getLayer().getClassName(),s,o;if(t&&t.className===r&&(!i||t&&t.style.backgroundColor&&Ot(_e(t.style.backgroundColor),_e(i)))){let a=t.firstElementChild;Me(a)&&(o=a.getContext("2d"))}if(o&&Ku(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){s=xt?qs():document.createElement("div"),s.className=r;let a=s.style;a.position="absolute",a.width="100%",a.height="100%",o=nt();let l=o.canvas;s.appendChild(l),a=l.style,a.position="absolute",a.left="0",a.transformOrigin="top left",this.container=s,this.context=o}!this.containerReused&&i&&!this.container.style.backgroundColor&&(this.container.style.backgroundColor=i)}clipUnrotated(t,e,i){let r=he(i),s=wn(i),o=Rn(i),a=Cn(i);ht(e.coordinateToPixelTransform,r),ht(e.coordinateToPixelTransform,s),ht(e.coordinateToPixelTransform,o),ht(e.coordinateToPixelTransform,a);let l=this.inversePixelTransform;ht(l,r),ht(l,s),ht(l,o),ht(l,a),t.save(),t.beginPath(),t.moveTo(Math.round(r[0]),Math.round(r[1])),t.lineTo(Math.round(s[0]),Math.round(s[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){let i=t.extent,r=t.viewState.resolution,s=t.viewState.rotation,o=t.pixelRatio,a=Math.round(W(i)/r*o),l=Math.round(et(i)/r*o);Et(this.pixelTransform,t.size[0]/2,t.size[1]/2,1/o,1/o,s,-a/2,-l/2),Gs(this.inversePixelTransform,this.pixelTransform);let c=Yu(this.pixelTransform);if(this.useContainer(e,c,this.getBackground(t)),!this.containerReused){let h=this.context.canvas;h.width!=a||h.height!=l?(h.width=a,h.height=l):this.context.clearRect(0,0,a,l),c!==h.style.transform&&(h.style.transform=c)}}dispatchRenderEvent_(t,e,i){let r=this.getLayer();if(r.hasListener(t)){let s=new Ro(t,this.inversePixelTransform,i,e);r.dispatchEvent(s)}}preRender(t,e){this.frameState=e,!e.declutter&&this.dispatchRenderEvent_(Lt.PRERENDER,t,e)}postRender(t,e){e.declutter||this.dispatchRenderEvent_(Lt.POSTRENDER,t,e)}renderDeferredInternal(t){}getRenderContext(t){return t.declutter&&!this.deferredContext_&&(this.deferredContext_=new Ao),t.declutter?this.deferredContext_.getContext():this.context}renderDeferred(t){t.declutter&&(this.dispatchRenderEvent_(Lt.PRERENDER,this.context,t),t.declutter&&this.deferredContext_&&(this.deferredContext_.draw(this.context),this.deferredContext_.clear()),this.renderDeferredInternal(t),this.dispatchRenderEvent_(Lt.POSTRENDER,this.context,t))}getRenderTransform(t,e,i,r,s,o,a){let l=s/2,c=o/2,h=r/e,u=-h,d=-t[0]+a,f=-t[1];return Et(this.tempTransform,l,c,h,u,-i,d,f)}disposeInternal(){delete this.frameState,super.disposeInternal()}},Hn=Eh;function Rh(n,t,e){if(!(e in n))return n[e]=new Set([t]),!0;let i=n[e],r=i.has(t);return r||i.add(t),!r}function Pp(n,t,e){let i=n[e];return i?i.delete(t):!1}function Cf(n,t){let e=n.layerStatesArray[n.layerIndex];e.extent&&(t=Ut(t,Gt(e.extent,n.viewState.projection)));let i=e.layer.getRenderSource();if(!i.getWrapX()){let r=i.getTileGridForProjection(n.viewState.projection).getExtent();r&&(t=Ut(t,r))}return t}var wh=class extends Hn{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=ct(),this.tempTileRange_=new vo(0,0,0,0),this.tempTileCoord_=Vn(0,0,0);let i=e.cacheSize!==void 0?e.cacheSize:512;this.tileCache_=new _h(i),this.sourceTileCache_=null,this.maxStaleKeys=i*.5}getTileCache(){return this.tileCache_}getSourceTileCache(){return this.sourceTileCache_||(this.sourceTileCache_=new _h(512)),this.sourceTileCache_}getOrCreateTile(t,e,i,r){let s=this.tileCache_,a=this.getLayer().getSource(),l=Bn(a,a.getKey(),t,e,i),c;if(s.containsKey(l))c=s.get(l);else{let h=r.viewState.projection,u=a.getProjection();if(c=a.getTile(t,e,i,r.pixelRatio,h,!u||ve(u,h)?void 0:this.getSourceTileCache()),!c)return null;s.set(l,c)}return c}getTile(t,e,i,r){let s=this.getOrCreateTile(t,e,i,r);return s||null}getData(t){let e=this.frameState;if(!e)return null;let i=this.getLayer(),r=ht(e.pixelToCoordinateTransform,t.slice()),s=i.getExtent();if(s&&!Jt(s,r))return null;let o=e.viewState,a=i.getRenderSource(),l=a.getTileGridForProjection(o.projection),c=a.getTilePixelRatio(e.pixelRatio);for(let h=l.getZForResolution(o.resolution);h>=l.getMinZoom();--h){let u=l.getTileCoordForCoordAndZ(r,h),d=this.getTile(h,u[1],u[2],e);if(!d||d.getState()!==O.LOADED)continue;let f=l.getOrigin(h),g=ft(l.getTileSize(h)),p=l.getResolution(h),m;if(d instanceof So||d instanceof bo)m=d.getImage();else if(d instanceof ch){if(m=wo(d.getData()),!m)continue}else continue;let _=Math.floor(c*((r[0]-f[0])/p-u[1]*g[0])),y=Math.floor(c*((f[1]-r[1])/p-u[2]*g[1])),E=Math.round(c*a.getGutterForProjection(o.projection));return this.getImageData(m,_+E,y+E)}return null}prepareFrame(t){this.renderedProjection?t.viewState.projection!==this.renderedProjection&&(this.tileCache_.clear(),this.renderedProjection=t.viewState.projection):this.renderedProjection=t.viewState.projection;let e=this.getLayer().getSource();if(!e)return!1;let 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,r,s){let o=t.viewState,a=this.getLayer(),l=a.getRenderSource(),c=l.getTileGridForProjection(o.projection),h=U(l);h in t.wantedTiles||(t.wantedTiles[h]={});let u=t.wantedTiles[h],d=a.getMapInternal(),f=Math.max(i-s,c.getMinZoom(),c.getZForResolution(Math.min(a.getMaxResolution(),d?d.getView().getResolutionForZoom(Math.max(a.getMinZoom(),0)):c.getResolution(0)),l.zDirection)),g=o.rotation,p=g?pa(o.center,o.resolution,g,t.size):void 0;for(let m=i;m>=f;--m){let _=c.getTileRangeForExtentAndZ(e,m,this.tempTileRange_),y=c.getResolution(m);for(let E=_.minX;E<=_.maxX;++E)for(let x=_.minY;x<=_.maxY;++x){if(g&&!c.tileCoordIntersectsViewport([m,E,x],p))continue;let C=this.getTile(m,E,x,t);if(!C||!Rh(r,C,m))continue;let I=C.getKey();if(u[I]=!0,C.getState()===O.IDLE&&!t.tileQueue.isKeyQueued(I)){let S=Vn(m,E,x,this.tempTileCoord_);t.tileQueue.enqueue([C,h,c.getTileCoordCenter(S),y])}}}}findStaleTile_(t,e){let i=this.tileCache_,r=t[0],s=t[1],o=t[2],a=this.getStaleKeys();for(let l=0;l<a.length;++l){let c=Bn(this.getLayer().getSource(),a[l],r,s,o);if(i.containsKey(c)){let h=i.peek(c);if(h.getState()===O.LOADED)return h.endTransition(U(this)),Rh(e,h,r),!0}}return!1}findAltTiles_(t,e,i,r){let s=t.getTileRangeForTileCoordAndZ(e,i,this.tempTileRange_);if(!s)return!1;let o=!0,a=this.tileCache_,l=this.getLayer().getRenderSource(),c=l.getKey();for(let h=s.minX;h<=s.maxX;++h)for(let u=s.minY;u<=s.maxY;++u){let d=Bn(l,c,i,h,u),f=!1;if(a.containsKey(d)){let g=a.peek(d);g.getState()===O.LOADED&&(Rh(r,g,i),f=!0)}f||(o=!1)}return o}renderFrame(t,e){this.renderComplete=!0;let i=t.layerStatesArray[t.layerIndex],r=t.viewState,s=r.projection,o=r.resolution,a=r.center,l=t.pixelRatio,c=this.getLayer(),h=c.getSource(),u=h.getTileGridForProjection(s),d=u.getZForResolution(o,h.zDirection),f=u.getResolution(d),g=h.getKey();this.renderedSourceKey_?this.renderedSourceKey_!==g&&(this.prependStaleKey(this.renderedSourceKey_),this.renderedSourceKey_=g):this.renderedSourceKey_=g;let p=t.extent,m=h.getTilePixelRatio(l);this.prepareContainer(t,e);let _=this.context.canvas.width,y=this.context.canvas.height,E=i.extent&&Gt(i.extent,s);E&&(p=Ut(p,Gt(i.extent,s)));let x=f*_/2/m,C=f*y/2/m,T=[a[0]-x,a[1]-C,a[0]+x,a[1]+C],I={};this.renderedTiles.length=0;let S=c.getPreload();if(t.nextExtent&&this.enqueueTilesForNextExtent()){let k=u.getZForResolution(r.nextResolution,h.zDirection),K=Cf(t,t.nextExtent);this.enqueueTiles(t,K,k,I,S)}let w=Cf(t,p);if(this.enqueueTiles(t,w,d,I,0),S>0&&setTimeout(()=>{this.enqueueTiles(t,w,d-1,I,S-1)},0),!(d in I))return this.container;let M=U(this),N=t.time;for(let k of I[d]){let K=k.getState();if(K===O.EMPTY)continue;let X=k.tileCoord;if(K===O.LOADED&&k.getAlpha(M,N)===1){k.endTransition(M);continue}if(K!==O.ERROR&&(this.renderComplete=!1),this.findStaleTile_(X,I)){Pp(I,k,d),t.animate=!0;continue}if(this.findAltTiles_(u,X,d+1,I))continue;let ot=u.getMinZoom();for(let kt=d-1;kt>=ot&&!this.findAltTiles_(u,X,kt,I);--kt);}let z=f/o*l/m,A=this.getRenderContext(t);Et(this.tempTransform,_/2,y/2,z,z,0,-_/2,-y/2),i.extent&&this.clipUnrotated(A,t,E),h.getInterpolate()||(A.imageSmoothingEnabled=!1),this.preRender(A,t);let H=Object.keys(I).map(Number);H.sort(jt);let $,P=[],j=[];for(let k=H.length-1;k>=0;--k){let K=H[k],X=h.getTilePixelSize(K,l,s),it=u.getResolution(K)/f,ot=X[0]*it*z,kt=X[1]*it*z,v=u.getTileCoordForCoordAndZ(he(T),K),ie=u.getTileCoordExtent(v),Rt=ht(this.tempTransform,[m*(ie[0]-T[0])/f,m*(T[3]-ie[3])/f]),ye=m*h.getGutterForProjection(s);for(let De of I[K]){if(De.getState()!==O.LOADED)continue;let ne=De.tileCoord,er=v[1]-ne[1],hs=Math.round(Rt[0]-(er-1)*ot),ir=v[2]-ne[2],Zo=Math.round(Rt[1]-(ir-1)*kt),ke=Math.round(Rt[0]-er*ot),xe=Math.round(Rt[1]-ir*kt),Ne=hs-ke,Ei=Zo-xe,cs=H.length===1,nr=!1;$=[ke,xe,ke+Ne,xe,ke+Ne,xe+Ei,ke,xe+Ei];for(let pn=0,us=P.length;pn<us;++pn)if(!cs&&K<j[pn]){let Pt=P[pn];lt([ke,xe,ke+Ne,xe+Ei],[Pt[0],Pt[3],Pt[4],Pt[7]])&&(nr||(A.save(),nr=!0),A.beginPath(),A.moveTo($[0],$[1]),A.lineTo($[2],$[3]),A.lineTo($[4],$[5]),A.lineTo($[6],$[7]),A.moveTo(Pt[6],Pt[7]),A.lineTo(Pt[4],Pt[5]),A.lineTo(Pt[2],Pt[3]),A.lineTo(Pt[0],Pt[1]),A.clip())}P.push($),j.push(K),this.drawTile(De,t,ke,xe,Ne,Ei,ye,cs),nr&&A.restore(),this.renderedTiles.unshift(De),this.updateUsedTiles(t.usedTiles,h,De)}}if(this.renderedResolution=f,this.extentChanged=!this.renderedExtent_||!we(this.renderedExtent_,T),this.renderedExtent_=T,this.renderedPixelRatio=l,this.postRender(this.context,t),i.extent&&A.restore(),A.imageSmoothingEnabled=!0,this.renderComplete){let k=(K,X)=>{let tt=U(h),it=X.wantedTiles[tt],ot=it?Object.keys(it).length:0;this.updateCacheSize(ot),this.tileCache_.expireCache(),this.sourceTileCache_?.expireCache()};t.postRenderFunctions.push(k)}return this.container}updateCacheSize(t){this.tileCache_.highWaterMark=Math.max(this.tileCache_.highWaterMark,t*2)}drawTile(t,e,i,r,s,o,a,l){let c;if(t instanceof ch){if(c=wo(t.getData()),!c)throw new Error("Rendering array data is not yet supported")}else c=this.getTileImage(t);if(!c)return;let h=this.getRenderContext(e),u=U(this),d=e.layerStatesArray[e.layerIndex],f=d.opacity*(l?t.getAlpha(u,e.time):1),g=f!==h.globalAlpha;g&&(h.save(),h.globalAlpha=f),h.drawImage(c,a,a,c.width-2*a,c.height-2*a,i,r,s,o),g&&h.restore(),f!==d.opacity?e.animate=!0:l&&t.endTransition(u)}getImage(){let t=this.context;return t?t.canvas:null}getTileImage(t){return t.getImage()}updateUsedTiles(t,e,i){let r=U(e);r in t||(t[r]={}),t[r][i.getKey()]=!0}},Rf=wh;var qr={PRELOAD:"preload",USE_INTERIM_TILES_ON_ERROR:"useInterimTilesOnError"};var Sh=class extends ci{constructor(t){t=t||{};let 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(qr.PRELOAD)}setPreload(t){this.set(qr.PRELOAD,t)}getUseInterimTilesOnError(){return this.get(qr.USE_INTERIM_TILES_ON_ERROR)}setUseInterimTilesOnError(t){this.set(qr.USE_INTERIM_TILES_ON_ERROR,t)}getData(t){return super.getData(t)}},wf=Sh;var Th=class extends wf{constructor(t){super(t)}createRenderer(){return new Rf(this,{cacheSize:this.getCacheSize()})}},Po=Th;var vh=class{drawCustom(t,e,i,r,s){}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){}},Oo=vh;var $r={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},Jr=[$r.FILL],He=[$r.STROKE],_i=[$r.BEGIN_PATH],Ih=[$r.CLOSE_PATH],D=$r;var Mh=class extends Oo{constructor(t,e,i,r){super(),this.tolerance=t,this.maxExtent=e,this.pixelRatio=r,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){let e=this.pixelRatio;return e==1?t:t.map(function(i){return i*e})}appendFlatPointCoordinates(t,e){let i=this.getBufferedMaxExtent(),r=this.tmpCoordinate_,s=this.coordinates,o=s.length;for(let a=0,l=t.length;a<l;a+=e)r[0]=t[a],r[1]=t[a+1],Jt(i,r)&&(s[o++]=r[0],s[o++]=r[1]);return o}appendFlatLineCoordinates(t,e,i,r,s,o){let a=this.coordinates,l=a.length,c=this.getBufferedMaxExtent();o&&(e+=r);let h=t[e],u=t[e+1],d=this.tmpCoordinate_,f=!0,g,p,m;for(g=e+r;g<i;g+=r)d[0]=t[g],d[1]=t[g+1],m=ws(c,d),m!==p?(f&&(a[l++]=h,a[l++]=u,f=!1),a[l++]=d[0],a[l++]=d[1]):m===yt.INTERSECTING?(a[l++]=d[0],a[l++]=d[1],f=!1):f=!0,h=d[0],u=d[1],p=m;return(s&&f||g===e+r)&&(a[l++]=h,a[l++]=u),l}drawCustomCoordinates_(t,e,i,r,s){for(let o=0,a=i.length;o<a;++o){let l=i[o],c=this.appendFlatLineCoordinates(t,e,l,r,!1,!1);s.push(c),e=l}return e}drawCustom(t,e,i,r,s){this.beginGeometry(t,e,s);let o=t.getType(),a=t.getStride(),l=this.coordinates.length,c,h,u,d,f;switch(o){case"MultiPolygon":c=t.getOrientedFlatCoordinates(),d=[];let g=t.getEndss();f=0;for(let p=0,m=g.length;p<m;++p){let _=[];f=this.drawCustomCoordinates_(c,f,g[p],a,_),d.push(_)}this.instructions.push([D.CUSTOM,l,d,t,i,xr,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,d,t,r||i,xr,s]);break;case"Polygon":case"MultiLineString":u=[],c=o=="Polygon"?t.getOrientedFlatCoordinates():t.getFlatCoordinates(),f=this.drawCustomCoordinates_(c,0,t.getEnds(),a,u),this.instructions.push([D.CUSTOM,l,u,t,i,Ai,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,u,t,r||i,Ai,s]);break;case"LineString":case"Circle":c=t.getFlatCoordinates(),h=this.appendFlatLineCoordinates(c,0,c.length,a,!1,!1),this.instructions.push([D.CUSTOM,l,h,t,i,fe,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,h,t,r||i,fe,s]);break;case"MultiPoint":c=t.getFlatCoordinates(),h=this.appendFlatPointCoordinates(c,a),h>l&&(this.instructions.push([D.CUSTOM,l,h,t,i,fe,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,h,t,r||i,fe,s]));break;case"Point":c=t.getFlatCoordinates(),this.coordinates.push(c[0],c[1]),h=this.coordinates.length,this.instructions.push([D.CUSTOM,l,h,t,i,void 0,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,h,t,r||i,void 0,s]);break;default:}this.endGeometry(e)}beginGeometry(t,e,i){this.beginGeometryInstruction1_=[D.BEGIN_GEOMETRY,e,0,t,i],this.instructions.push(this.beginGeometryInstruction1_),this.beginGeometryInstruction2_=[D.BEGIN_GEOMETRY,e,0,t,i],this.hitDetectionInstructions.push(this.beginGeometryInstruction2_)}finish(){return{instructions:this.instructions,hitDetectionInstructions:this.hitDetectionInstructions,coordinates:this.coordinates}}reverseHitDetectionInstructions(){let t=this.hitDetectionInstructions;t.reverse();let e,i=t.length,r,s,o=-1;for(e=0;e<i;++e)r=t[e],s=r[0],s==D.END_GEOMETRY?o=e:s==D.BEGIN_GEOMETRY&&(r[2]=e,Jc(this.hitDetectionInstructions,o,e),o=-1)}fillStyleToState(t,e={}){if(t){let i=t.getColor();e.fillPatternScale=i&&typeof i=="object"&&"src"in i?this.pixelRatio:1,e.fillStyle=Zt(i||Ct)}else e.fillStyle=void 0;return e}strokeStyleToState(t,e={}){if(t){let i=t.getColor();e.strokeStyle=Zt(i||di);let r=t.getLineCap();e.lineCap=r!==void 0?r:Ve;let s=t.getLineDash();e.lineDash=s?s.slice():Ht;let o=t.getLineDashOffset();e.lineDashOffset=o||qt;let a=t.getLineJoin();e.lineJoin=a!==void 0?a:Be;let l=t.getWidth();e.lineWidth=l!==void 0?l:gi;let c=t.getMiterLimit();e.miterLimit=c!==void 0?c:ui;let h=t.getOffset();e.strokeOffset=h??Vd,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,e.strokeOffset=void 0;return e}setFillStrokeStyle(t,e){let i=this.state;this.fillStyleToState(t,i),this.strokeStyleToState(e,i)}createFill(t){let e=t.fillStyle,i=[D.SET_FILL_STYLE,e];return typeof e!="string"&&i.push(t.fillPatternScale),i}applyStroke(t){this.instructions.push(this.createStroke(t))}createStroke(t){return[D.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){let i=t.fillStyle;(typeof i!="string"||t.currentFillStyle!=i)&&(this.instructions.push(e.call(this,t)),t.currentFillStyle=i)}updateStrokeStyle(t,e){let i=t.strokeStyle,r=t.lineCap,s=t.lineDash,o=t.lineDashOffset,a=t.lineJoin,l=t.lineWidth,c=t.miterLimit,h=t.strokeOffset;(t.currentStrokeStyle!=i||t.currentLineCap!=r||s!=t.currentLineDash&&!Ot(t.currentLineDash,s)||t.currentLineDashOffset!=o||t.currentLineJoin!=a||t.currentLineWidth!=l||t.currentMiterLimit!=c||t.currentStrokeOffset!=h)&&(e.call(this,t),t.currentStrokeStyle=i,t.currentLineCap=r,t.currentLineDash=s,t.currentLineDashOffset=o,t.currentLineJoin=a,t.currentLineWidth=l,t.currentMiterLimit=c,t.currentStrokeOffset=h)}endGeometry(t){this.beginGeometryInstruction1_[2]=this.instructions.length,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_[2]=this.hitDetectionInstructions.length,this.beginGeometryInstruction2_=null;let e=[D.END_GEOMETRY,t];this.instructions.push(e),this.hitDetectionInstructions.push(e)}getBufferedMaxExtent(){if(!this.bufferedMaxExtent_&&(this.bufferedMaxExtent_=Ss(this.maxExtent),this.maxLineWidth>0)){let t=this.resolution*(this.maxLineWidth+1)/2;ri(this.bufferedMaxExtent_,t,this.bufferedMaxExtent_)}return this.bufferedMaxExtent_}},qe=Mh;var bh=class extends qe{constructor(t,e,i,r){super(t,e,i,r),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&&!Jt(this.maxExtent,t.getFlatCoordinates()))return;this.beginGeometry(t,e,i);let r=t.getFlatCoordinates(),s=t.getStride(),o=this.coordinates.length,a=this.appendFlatPointCoordinates(r,s);this.instructions.push([D.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([D.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);let r=t.getFlatCoordinates(),s=[];for(let l=0,c=r.length;l<c;l+=t.getStride())(!this.maxExtent||Jt(this.maxExtent,r.slice(l,l+2)))&&s.push(r[l],r[l+1]);let o=this.coordinates.length,a=this.appendFlatPointCoordinates(s,2);this.instructions.push([D.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([D.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){let i=t.getAnchor(),r=t.getSize(),s=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_=r[1],this.opacity_=t.getOpacity(),this.originX_=s[0],this.originY_=s[1],this.rotateWithView_=t.getRotateWithView(),this.rotation_=t.getRotation(),this.scale_=t.getScaleArray(),this.width_=r[0],this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}},Sf=bh;var Lh=class extends qe{constructor(t,e,i,r){super(t,e,i,r)}drawFlatCoordinates_(t,e,i,r,s){let o=this.coordinates.length,a=this.appendFlatLineCoordinates(t,e,i,r,!1,!1);return this.instructions.push([D.MOVE_TO_LINE_TO,o,a,s*this.pixelRatio]),this.hitDetectionInstructions.push([D.MOVE_TO_LINE_TO,o,a,s]),i}drawLineString(t,e,i){let r=this.state,s=r.strokeStyle,o=r.lineWidth,a=r.strokeOffset;if(s===void 0||o===void 0)return;this.updateStrokeStyle(r,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt],_i);let l=t.getFlatCoordinates(),c=t.getStride();this.drawFlatCoordinates_(l,0,l.length,c,a),this.hitDetectionInstructions.push(He),this.endGeometry(e)}drawMultiLineString(t,e,i){let r=this.state,s=r.strokeStyle,o=r.lineWidth,a=r.strokeOffset;if(s===void 0||o===void 0)return;this.updateStrokeStyle(r,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt],_i);let l=t.getEnds(),c=t.getFlatCoordinates(),h=t.getStride(),u=0;for(let d=0,f=l.length;d<f;++d)u=this.drawFlatCoordinates_(c,u,l[d],h,a);this.hitDetectionInstructions.push(He),this.endGeometry(e)}finish(){let t=this.state;return t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&this.instructions.push(He),this.reverseHitDetectionInstructions(),this.state=null,super.finish()}applyStroke(t){t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&(this.instructions.push(He),t.lastStroke=this.coordinates.length),t.lastStroke=0,super.applyStroke(t),this.instructions.push(_i)}},Tf=Lh;var Ah=class extends qe{constructor(t,e,i,r){super(t,e,i,r)}drawFlatCoordinatess_(t,e,i,r,s){let o=this.state,a=o.fillStyle!==void 0,l=o.strokeStyle!==void 0,c=i.length;this.instructions.push(_i),this.hitDetectionInstructions.push(_i);for(let h=0;h<c;++h){let u=i[h],d=this.coordinates.length,f=this.appendFlatLineCoordinates(t,e,u,r,!0,!l);this.instructions.push([D.MOVE_TO_LINE_TO,d,f,s*this.pixelRatio,!0]),this.hitDetectionInstructions.push([D.MOVE_TO_LINE_TO,d,f,s,!0]),l&&(this.instructions.push(Ih),this.hitDetectionInstructions.push(Ih)),e=u}return a&&(this.instructions.push(Jr),this.hitDetectionInstructions.push(Jr)),l&&(this.instructions.push(He),this.hitDetectionInstructions.push(He)),e}drawCircle(t,e,i){let r=this.state,s=r.fillStyle,o=r.strokeStyle,a=r.strokeOffset;if(s===void 0&&o===void 0||this.handleStrokeOffset_(()=>this.drawCircle(t,e,i)))return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),r.fillStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_FILL_STYLE,Ct]),r.strokeStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt]);let l=t.getFlatCoordinates(),c=t.getStride(),h=this.coordinates.length;this.appendFlatLineCoordinates(l,0,l.length,c,!1,!1);let u=[D.CIRCLE,h,a];this.instructions.push(_i,u),this.hitDetectionInstructions.push(_i,u),r.fillStyle!==void 0&&(this.instructions.push(Jr),this.hitDetectionInstructions.push(Jr)),r.strokeStyle!==void 0&&(this.instructions.push(He),this.hitDetectionInstructions.push(He)),this.endGeometry(e)}drawPolygon(t,e,i){let r=this.state,s=r.fillStyle,o=r.strokeStyle,a=r.strokeOffset;if(s===void 0&&o===void 0||this.handleStrokeOffset_(()=>this.drawPolygon(t,e,i)))return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),r.fillStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_FILL_STYLE,Ct]),r.strokeStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt]);let l=t.getEnds(),c=t.getOrientedFlatCoordinates(),h=t.getStride();this.drawFlatCoordinatess_(c,0,l,h,a),this.endGeometry(e)}drawMultiPolygon(t,e,i){let r=this.state,s=r.fillStyle,o=r.strokeStyle,a=r.strokeOffset;if(s===void 0&&o===void 0||this.handleStrokeOffset_(()=>this.drawMultiPolygon(t,e,i)))return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),r.fillStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_FILL_STYLE,Ct]),r.strokeStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt]);let l=t.getEndss(),c=t.getOrientedFlatCoordinates(),h=t.getStride(),u=0;for(let d=0,f=l.length;d<f;++d)u=this.drawFlatCoordinatess_(c,u,l[d],h,a);this.endGeometry(e)}finish(){this.reverseHitDetectionInstructions(),this.state=null;let t=this.tolerance;if(t!==0){let e=this.coordinates;for(let i=0,r=e.length;i<r;++i)e[i]=Pi(e[i],t)}return super.finish()}setFillStrokeStyles_(){let t=this.state;this.updateFillStyle(t,this.createFill),this.updateStrokeStyle(t,this.applyStroke)}handleStrokeOffset_(t){let e=this.state,i=e.fillStyle,r=e.strokeStyle,s=e.strokeOffset;return Math.abs(s)>0&&i!==void 0&&r!==void 0?(e.strokeStyle=void 0,e.strokeOffset=0,t(),e.fillStyle=void 0,e.strokeStyle=r,e.strokeOffset=s,t(),e.fillStyle=i,!0):!1}},Ph=Ah;function vf(n,t,e,i,r){let s=[],o=e,a=0,l=t.slice(e,2);for(;a<n&&o+r<i;){let[c,h]=l.slice(-2),u=t[o+r],d=t[o+r+1],f=Math.sqrt((u-c)*(u-c)+(d-h)*(d-h));if(a+=f,a>=n){let g=(n-a+f)/f,p=bt(c,u,g),m=bt(h,d,g);l.push(p,m),s.push(l),l=[p,m],a==n&&(o+=r),a=0}else if(a<n)l.push(t[o+r],t[o+r+1]),o+=r;else{let g=f-a,p=bt(c,u,g/f),m=bt(h,d,g/f);l.push(p,m),s.push(l),l=[p,m],a=0,o+=r}}return a>0&&s.push(l),s}function If(n,t,e,i,r){let s=e,o=e,a=0,l=0,c=e,h,u,d,f,g,p,m,_,y,E;for(u=e;u<i;u+=r){let x=t[u],C=t[u+1];g!==void 0&&(y=x-g,E=C-p,f=Math.sqrt(y*y+E*E),m!==void 0&&(l+=d,h=Math.acos((m*y+_*E)/(d*f)),h>n&&(l>a&&(a=l,s=c,o=u),l=0,c=u-r)),d=f,m=y,_=E),g=x,p=C}return l+=f,l>a?[c,u]:[s,o]}var Qr={left:0,center:.5,right:1,top:0,middle:.5,hanging:.2,alphabetic:.8,ideographic:.8,bottom:1},Oh=class extends qe{constructor(t,e,i,r){super(t,e,i,r),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[Ct]={fillStyle:Ct},this.textStrokeState_=null,this.strokeStates={},this.textState_={},this.textStates={},this.textKey_="",this.fillKey_="",this.strokeKey_="",this.declutterMode_=void 0,this.declutterImageWithText_=void 0}finish(){let t=super.finish();return t.textStates=this.textStates,t.fillStates=this.fillStates,t.strokeStates=this.strokeStates,t}drawText(t,e,i){let r=this.textFillState_,s=this.textStrokeState_,o=this.textState_;if(this.text_===""||!o||!r&&!s)return;let a=this.coordinates,l=a.length,c=t.getType(),h=null,u=t.getStride();if(o.placement==="line"&&(c=="LineString"||c=="MultiLineString"||c=="Polygon"||c=="MultiPolygon")){if(!lt(this.maxExtent,t.getExtent()))return;let d;if(h=t.getFlatCoordinates(),c=="LineString")d=[h.length];else if(c=="MultiLineString")d=t.getEnds();else if(c=="Polygon")d=t.getEnds().slice(0,1);else if(c=="MultiPolygon"){let m=t.getEndss();d=[];for(let _=0,y=m.length;_<y;++_)d.push(m[_][0])}this.beginGeometry(t,e,i);let f=o.repeat,g=f?void 0:o.textAlign,p=0;for(let m=0,_=d.length;m<_;++m){let y;f?y=vf(f*this.resolution,h,p,d[m],u):y=[h.slice(p,d[m])];for(let E=0,x=y.length;E<x;++E){let C=y[E],T=0,I=C.length;if(g==null){let w=If(o.maxAngle,C,0,C.length,2);T=w[0],I=w[1]}for(let w=T;w<I;w+=u)a.push(C[w],C[w+1]);let S=a.length;p=d[m],this.drawChars_(l,S),l=S}}this.endGeometry(e)}else{let d=o.overflow?null:[];switch(c){case"Point":case"MultiPoint":h=t.getFlatCoordinates();break;case"LineString":h=t.getFlatMidpoint();break;case"Circle":h=t.getCenter();break;case"MultiLineString":h=t.getFlatMidpoints(),u=2;break;case"Polygon":h=t.getFlatInteriorPoint(),o.overflow||d.push(h[2]/this.resolution),u=3;break;case"MultiPolygon":let x=t.getFlatInteriorPoints();h=[];for(let C=0,T=x.length;C<T;C+=3)o.overflow||d.push(x[C+2]/this.resolution),h.push(x[C],x[C+1]);if(h.length===0)return;u=2;break;default:}let f=this.appendFlatPointCoordinates(h,u);if(f===l)return;if(d&&(f-l)/2!==h.length/u){let x=l/2;d=d.filter((C,T)=>{let I=a[(x+T)*2]===h[T*u]&&a[(x+T)*2+1]===h[T*u+1];return I||--x,I})}this.saveTextStates_();let g=o.backgroundFill?this.createFill(this.fillStyleToState(o.backgroundFill)):null,p=o.backgroundStroke?this.createStroke(this.strokeStyleToState(o.backgroundStroke)):null;this.beginGeometry(t,e,i);let m=o.padding;if(m!=fi&&(o.scale[0]<0||o.scale[1]<0)){let x=o.padding[0],C=o.padding[1],T=o.padding[2],I=o.padding[3];o.scale[0]<0&&(C=-C,I=-I),o.scale[1]<0&&(x=-x,T=-T),m=[x,C,T,I]}let _=this.pixelRatio;this.instructions.push([D.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[1,1],NaN,this.declutterMode_,this.declutterImageWithText_,m==fi?fi:m.map(function(x){return x*_}),g,p,this.text_,this.textKey_,this.strokeKey_,this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]);let y=1/_,E=g?g.slice(0):null;E&&(E[1]=Ct),this.hitDetectionInstructions.push([D.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[y,y],NaN,this.declutterMode_,this.declutterImageWithText_,m,E,p,this.text_,this.textKey_,this.strokeKey_,this.fillKey_?Ct:this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]),this.endGeometry(e)}}saveTextStates_(){let t=this.textStrokeState_,e=this.textState_,i=this.textFillState_,r=this.strokeKey_;t&&(r in this.strokeStates||(this.strokeStates[r]={strokeStyle:t.strokeStyle,lineCap:t.lineCap,lineDashOffset:t.lineDashOffset,lineWidth:t.lineWidth,lineJoin:t.lineJoin,miterLimit:t.miterLimit,lineDash:t.lineDash}));let s=this.textKey_;s in this.textStates||(this.textStates[s]={font:e.font,textAlign:e.textAlign||Ui,justify:e.justify,textBaseline:e.textBaseline||un,scale:e.scale});let o=this.fillKey_;i&&(o in this.fillStates||(this.fillStates[o]={fillStyle:i.fillStyle}))}drawChars_(t,e){let i=this.textStrokeState_,r=this.textState_,s=this.strokeKey_,o=this.textKey_,a=this.fillKey_;this.saveTextStates_();let l=this.pixelRatio,c=Qr[r.textBaseline],h=this.textOffsetY_*l,u=this.text_,d=i?i.lineWidth*Math.abs(r.scale[0])/2:0;this.instructions.push([D.DRAW_CHARS,t,e,c,r.overflow,a,r.maxAngle,l,h,s,d*l,u,o,1,this.declutterMode_,this.textKeepUpright_]),this.hitDetectionInstructions.push([D.DRAW_CHARS,t,e,c,r.overflow,a&&Ct,r.maxAngle,l,h,s,d*l,u,o,1/l,this.declutterMode_,this.textKeepUpright_])}setTextStyle(t,e){let i,r,s;if(!t)this.text_="";else{let o=t.getFill();o?(r=this.textFillState_,r||(r={},this.textFillState_=r),r.fillStyle=Zt(o.getColor()||Ct)):(r=null,this.textFillState_=r);let a=t.getStroke();if(!a)s=null,this.textStrokeState_=s;else{s=this.textStrokeState_,s||(s={},this.textStrokeState_=s);let p=a.getLineDash(),m=a.getLineDashOffset(),_=a.getWidth(),y=a.getMiterLimit();s.lineCap=a.getLineCap()||Ve,s.lineDash=p?p.slice():Ht,s.lineDashOffset=m===void 0?qt:m,s.lineJoin=a.getLineJoin()||Be,s.lineWidth=_===void 0?gi:_,s.miterLimit=y===void 0?ui:y,s.strokeStyle=Zt(a.getColor()||di)}i=this.textState_;let l=t.getFont()||fo;Bd(l);let c=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()||un,i.backgroundFill=t.getBackgroundFill(),i.backgroundStroke=t.getBackgroundStroke(),i.padding=t.getPadding()||fi,i.scale=c===void 0?[1,1]:c;let h=t.getOffsetX(),u=t.getOffsetY(),d=t.getRotateWithView(),f=t.getKeepUpright(),g=t.getRotation();this.text_=t.getText()||"",this.textOffsetX_=h===void 0?0:h,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_=s?(typeof s.strokeStyle=="string"?s.strokeStyle:U(s.strokeStyle))+s.lineCap+s.lineDashOffset+"|"+s.lineWidth+s.lineJoin+s.miterLimit+"["+s.lineDash.join()+"]":"",this.textKey_=i.font+i.scale+(i.textAlign||"?")+(i.repeat||"?")+(i.justify||"?")+(i.textBaseline||"?"),this.fillKey_=r&&r.fillStyle?typeof r.fillStyle=="string"?r.fillStyle:"|"+U(r.fillStyle):""}this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}},Mf=Oh;var Op={Circle:Ph,Default:qe,Image:Sf,LineString:Tf,Polygon:Ph,Text:Mf},Fh=class{constructor(t,e,i,r){this.tolerance_=t,this.maxExtent_=e,this.pixelRatio_=r,this.resolution_=i,this.buildersByZIndex_={}}finish(){let t={};for(let e in this.buildersByZIndex_){t[e]=t[e]||{};let i=this.buildersByZIndex_[e];for(let r in i){let s=i[r].finish();t[e][r]=s}}return t}getBuilder(t,e){let i=t!==void 0?t.toString():"0",r=this.buildersByZIndex_[i];r===void 0&&(r={},this.buildersByZIndex_[i]=r);let s=r[e];if(s===void 0){let o=Op[e];s=new o(this.tolerance_,this.maxExtent_,this.resolution_,this.pixelRatio_),r[e]=s}return s}},bf=Fh;function qn(n,t,e,i){let r=n[t],s=n[t+1],o=0;for(let a=t+i;a<e;a+=i){let l=n[a],c=n[a+1];o+=Math.sqrt((l-r)*(l-r)+(c-s)*(c-s)),r=l,s=c}return o}function Lf(n,t,e,i,r,s){r=r??[],s=s??t;let o=n[0],a=n[1],l=n[n.length-4],c=n[n.length-3],h,u,d,f,g,p,m,_,y=0;for(let E=0;E<n.length;E+=t){d=h,f=u,g=void 0,p=void 0,E+t<n.length&&(g=n[E+t],p=n[E+t+1]),i&&E===0&&(d=l,f=c),i&&E===n.length-2&&(g=o,p=a),h=n[E],u=n[E+1],[m,_]=ts(h,u,d,f,g,p,e),r[y++]=m,r[y++]=_;for(let x=2;x<s;x++)r[y++]=n[E+x]}return r.length!=y&&(r.length=y),r}function ts(n,t,e,i,r,s,o){let a,l;e!==void 0&&i!==void 0?(a=n-e,l=t-i):r!==void 0&&s!==void 0?(a=r-n,l=s-t):(a=1,l=0);let c=Math.hypot(a,l),h=a/c,u=l/c;if(a=-u,l=h,e===void 0||i===void 0)return[n+a*o,t+l*o];if(r===void 0||s===void 0)return[n+a*o,t+l*o];let d=yu([n,t],[e,i],[r,s]);if(Math.cos(d)>.998)return[n+h*o,t+u*o];let f=Math.cos(d/2),g=Math.sin(d/2),p=g*a+f*l,m=-f*a+g*l,_=p*(1/g),y=m*(1/g);return[n+_*o,t+y*o]}function Af(n,t,e,i,r,s,o,a,l,c,h,u,d=!0){let f=n[t],g=n[t+1],p=0,m=0,_=0,y=0;function E(){p=f,m=g,t+=i,f=n[t],g=n[t+1],y+=_,_=Math.sqrt((f-p)*(f-p)+(g-m)*(g-m))}do E();while(t<e-i&&y+_<s);let x=_===0?0:(s-y)/_,C=bt(p,f,x),T=bt(m,g,x),I=t-i,S=y,w=s+a*l(c,r,h);for(;t<e-i&&y+_<w;)E();x=_===0?0:(w-y)/_;let M=bt(p,f,x),N=bt(m,g,x),z=!1;if(d)if(u){let j=[C,T,M,N];zs(j,0,4,2,u,j,j),z=j[0]>j[2]}else z=C>M;let A=Math.PI,H=[],$=I+i===t;t=I,_=0,y=S,f=n[t],g=n[t+1];let P;if($){E(),P=Math.atan2(g-m,f-p),z&&(P+=P>0?-A:A);let j=(M+C)/2,k=(N+T)/2;return H[0]=[j,k,(w-s)/2,P,r],H}r=r.replace(/\n/g," ");for(let j=0,k=r.length;j<k;){E();let K=Math.atan2(g-m,f-p);if(z&&(K+=K>0?-A:A),P!==void 0){let v=K-P;if(v+=v>A?-2*A:v<-A?2*A:0,Math.abs(v)>o)return null}P=K;let X=j,tt=0;for(;j<k;++j){let v=z?k-j-1:j,ie=a*l(c,r[v],h);if(t+i<e&&y+_<s+tt+ie/2)break;tt+=ie}if(j===X)continue;let it=z?r.substring(k-X,k-j):r.substring(X,j);x=_===0?0:(s+tt/2-y)/_;let ot=bt(p,f,x),kt=bt(m,g,x);H.push([ot,kt,tt/2,K,it]),s+=tt}return H}var $n=ct(),Bi=[],yi=[],xi=[],Zi=[];function Pf(n){return n[3].declutterBox}var Of=new RegExp("[\u0591-\u08FF\uFB1D-\uFDFF\uFE70-\uFEFC\u0800-\u0FFF\uE800-\uEFFF]");function Dh(n,t){return t==="start"?t=Of.test(n)?"right":"left":t==="end"&&(t=Of.test(n)?"left":"right"),Qr[t]}function Fp(n,t,e){return e>0&&n.push(`
|
|
4
|
-
`,""),n.push(t,""),n}function Dp(n,t,e){return e%2===0&&(n+=t),n}var kh=class{constructor(t,e,i,r,s){this.overlaps=i,this.pixelRatio=e,this.resolution=t,this.alignAndScaleFill_,this.instructions=r.instructions,this.coordinates=r.coordinates,this.coordinateCache_={},this.renderedTransform_=Tt(),this.hitDetectionInstructions=r.hitDetectionInstructions,this.pixelCoordinates_=null,this.viewRotation_=0,this.fillStates=r.fillStates||{},this.strokeStates=r.strokeStates||{},this.textStates=r.textStates||{},this.widths_={},this.labels_={},this.zIndexContext_=s?new Ao:null}getZIndexContext(){return this.zIndexContext_}createLabel(t,e,i,r){let s=t+e+i+r;if(this.labels_[s])return this.labels_[s];let o=r?this.strokeStates[r]:null,a=i?this.fillStates[i]:null,l=this.textStates[e],
|
|
5
|
-
`).reduce(Fp,[]),{width:g,height:p,widths:m,heights:_,lineWidths:y}=qd(l,f),E=g+d,x=[],C=(E+2)*
|
|
6
|
-
`){A+=z,z=0,w=u*E+S*d,++$;continue}let X=f[j+1]||l.font;X!==P&&(r&&M.push("font",X),i&&N.push("font",X),P=X),z=Math.max(z,_[H]);let tt=[K,w+S*m[H]+u*(m[H]-y[$]),.5*(d+z)+A];w+=m[H],r&&M.push("strokeText",tt),i&&N.push("fillText",tt),++H}return Array.prototype.push.apply(x,M),Array.prototype.push.apply(x,N),this.labels_[s]=I,I}replayTextBackground_(t,e,i,r,s,o,a){t.beginPath(),t.moveTo.apply(t,e),t.lineTo.apply(t,i),t.lineTo.apply(t,r),t.lineTo.apply(t,s),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,r,s,o,a,l,c,h,u,d,f,g,p,m){a*=d[0],l*=d[1];let _=i-a,y=r-l,E=s+c>t?t-c:s,x=o+h>e?e-h:o,C=g[3]+E*d[0]+g[1],T=g[0]+x*d[1]+g[2],I=_-g[3],S=y-g[0];(p||u!==0)&&(Bi[0]=I,Zi[0]=I,Bi[1]=S,yi[1]=S,yi[0]=I+C,xi[0]=yi[0],xi[1]=S+T,Zi[1]=xi[1]);let w;return u!==0?(w=Et(Tt(),i,r,1,1,u,-i,-r),ht(w,Bi),ht(w,yi),ht(w,xi),ht(w,Zi),Qt(Math.min(Bi[0],yi[0],xi[0],Zi[0]),Math.min(Bi[1],yi[1],xi[1],Zi[1]),Math.max(Bi[0],yi[0],xi[0],Zi[0]),Math.max(Bi[1],yi[1],xi[1],Zi[1]),$n)):Qt(Math.min(I,I+C),Math.min(S,S+T),Math.max(I,I+C),Math.max(S,S+T),$n),f&&(_=Math.round(_),y=Math.round(y)),{drawImageX:_,drawImageY:y,drawImageW:E,drawImageH:x,originX:c,originY:h,declutterBox:{minX:$n[0],minY:$n[1],maxX:$n[2],maxY:$n[3],value:m},canvasTransform:w,scale:d}}replayImageOrLabel_(t,e,i,r,s,o,a){let l=!!(o||a),c=r.declutterBox,h=a?a[2]*r.scale[0]/2:0;return c.minX-h<=e[0]&&c.maxX+h>=0&&c.minY-h<=e[1]&&c.maxY+h>=0&&(l&&this.replayTextBackground_(t,Bi,yi,xi,Zi,o,a),$d(t,r.canvasTransform,s,i,r.originX,r.originY,r.drawImageW,r.drawImageH,r.drawImageX,r.drawImageY,r.scale)),!0}fill_(t){let e=this.alignAndScaleFill_;if(e){let i=ht(this.renderedTransform_,[0,0]),r=512*this.pixelRatio;t.save(),t.translate(i[0]%r,i[1]%r),e!==1&&t.scale(e,e)}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,r){let s=this.textStates[e],o=this.createLabel(t,e,r,i),a=this.strokeStates[i],l=this.pixelRatio,c=Dh(Array.isArray(t)?t[0]:t,s.textAlign||Ui),h=Qr[s.textBaseline||un],u=a&&a.lineWidth?a.lineWidth:0,d=o.width/l-2*s.scale[0],f=c*d+2*(.5-c)*u,g=h*o.height/l+2*(.5-h)*u;return{label:o,anchorX:f,anchorY:g}}execute_(t,e,i,r,s,o,a,l){let c=this.zIndexContext_,h;this.pixelCoordinates_&&Ot(i,this.renderedTransform_)?h=this.pixelCoordinates_:(this.pixelCoordinates_||(this.pixelCoordinates_=[]),h=Kt(this.coordinates,0,this.coordinates.length,2,i,this.pixelCoordinates_),Uu(this.renderedTransform_,i));let u=0,d=r.length,f=0,g,p,m,_,y,E,x,C,T,I,S,w,M,N,z,A,H=0,$=0,P=this.coordinateCache_,j=this.viewRotation_,k=Math.round(Math.atan2(-i[1],i[0])*1e12)/1e12,K={context:t,pixelRatio:this.pixelRatio,resolution:this.resolution,rotation:j},X=this.instructions!=r||this.overlaps?0:200,tt,it,ot,kt;for(;u<d;){let v=r[u];switch(v[0]){case D.BEGIN_GEOMETRY:tt=v[1],kt=v[3],tt.getGeometry()?a!==void 0&&!lt(a,kt.getExtent())?u=v[2]+1:++u:u=v[2],c&&(c.zIndex=v[4]);break;case D.BEGIN_PATH:H>X&&(this.fill_(t),H=0),$>X&&(t.stroke(),$=0),!H&&!$&&(t.beginPath(),C=NaN,T=NaN),++u;break;case D.CIRCLE:f=v[1],_=v[2]??0;let Rt=h[f],ye=h[f+1],De=h[f+2]-_,ne=h[f+3]-_,er=De-Rt,hs=ne-ye,ir=Math.sqrt(er*er+hs*hs);t.moveTo(Rt+ir,ye),t.arc(Rt,ye,ir,0,2*Math.PI,!0),++u;break;case D.CLOSE_PATH:t.closePath(),++u;break;case D.CUSTOM:f=v[1],g=v[2];let Zo=v[3],ke=v[4],xe=v[5];K.geometry=Zo,K.feature=tt,u in P||(P[u]=[]);let Ne=P[u];xe?xe(h,f,g,2,Ne):(Ne[0]=h[f],Ne[1]=h[f+1],Ne.length=2),c&&(c.zIndex=v[6]),ke(Ne,K),++u;break;case D.DRAW_IMAGE:f=v[1],g=v[2],w=v[3],p=v[4],m=v[5];let Ei=v[6],cs=v[7],nr=v[8],pn=v[9],us=v[10],Pt=v[11],Tg=v[12],ds=v[13];x=v[14]||"declutter";let rr=v[15];if(!w&&v.length>=20){M=v[19],N=v[20],z=v[21],A=v[22];let re=this.drawLabelWithPointPlacement_(M,N,z,A);w=re.label,v[3]=w;let $i=v[23];p=(re.anchorX-$i)*this.pixelRatio,v[4]=p;let se=v[24];m=(re.anchorY-se)*this.pixelRatio,v[5]=m,Ei=w.height,v[6]=Ei,ds=w.width,v[13]=ds}let Ho;v.length>25&&(Ho=v[25]);let qo,fs,gs;v.length>17?(qo=v[16],fs=v[17],gs=v[18]):(qo=fi,fs=null,gs=null),us&&k?Pt+=j:!us&&!k&&(Pt-=j);let vg=0;for(;f<g;f+=2){if(Ho&&Ho[vg++]<ds/this.pixelRatio)continue;let re=this.calculateImageOrLabelDimensions_(w.width,w.height,h[f],h[f+1],ds,Ei,p,m,nr,pn,Pt,Tg,s,qo,!!fs||!!gs,tt),$i=[t,e,w,re,cs,fs,gs];if(l){let se,Ge,oe;if(rr){let ut=g-f;if(!rr[ut]){rr[ut]={args:$i,declutterMode:x};continue}let Nt=rr[ut];se=Nt.args,Ge=Nt.declutterMode,delete rr[ut],oe=Pf(se)}let Je,Qe;if(se&&(Ge!=="declutter"||!l.collides(oe))&&(Je=!0),(x!=="declutter"||!l.collides(re.declutterBox))&&(Qe=!0),Ge==="declutter"&&x==="declutter"){let ut=Je&&Qe;Je=ut,Qe=ut}Je&&(Ge!=="none"&&l.insert(oe),this.replayImageOrLabel_.apply(this,se)),Qe&&(x!=="none"&&l.insert(re.declutterBox),this.replayImageOrLabel_.apply(this,$i))}else this.replayImageOrLabel_.apply(this,$i)}++u;break;case D.DRAW_CHARS:let Uc=v[1],Yc=v[2],$o=v[3],Ig=v[4];A=v[5];let Mg=v[6],Kc=v[7],Vc=v[8];z=v[9];let Jo=v[10];M=v[11],Array.isArray(M)&&(M=M.reduce(Dp,"")),N=v[12];let Bc=[v[13],v[13]];x=v[14]||"declutter";let bg=v[15],Qo=this.textStates[N],sr=Qo.font,or=[Qo.scale[0]*Kc,Qo.scale[1]*Kc],ar;sr in this.widths_?ar=this.widths_[sr]:(ar={},this.widths_[sr]=ar);let Zc=qn(h,Uc,Yc,2),Hc=Math.abs(or[0])*Xl(sr,M,ar);if(Ig||Hc<=Zc){let re=this.textStates[N].textAlign,$i=(Zc-Hc)*Dh(M,re),se=Af(h,Uc,Yc,2,M,$i,Mg,Math.abs(or[0]),Xl,sr,ar,k?0:this.viewRotation_,bg);t:if(se){let Ge=[],oe,Je,Qe,ut,Nt;if(z)for(oe=0,Je=se.length;oe<Je;++oe){Nt=se[oe],Qe=Nt[4],ut=this.createLabel(Qe,N,"",z),p=Nt[2]+(or[0]<0?-Jo:Jo),m=$o*ut.height+(.5-$o)*2*Jo*or[1]/or[0]-Vc;let ti=this.calculateImageOrLabelDimensions_(ut.width,ut.height,Nt[0],Nt[1],ut.width,ut.height,p,m,0,0,Nt[3],Bc,!1,fi,!1,tt);if(l&&x==="declutter"&&l.collides(ti.declutterBox))break t;Ge.push([t,e,ut,ti,1,null,null])}if(A)for(oe=0,Je=se.length;oe<Je;++oe){Nt=se[oe],Qe=Nt[4],ut=this.createLabel(Qe,N,A,""),p=Nt[2],m=$o*ut.height-Vc;let ti=this.calculateImageOrLabelDimensions_(ut.width,ut.height,Nt[0],Nt[1],ut.width,ut.height,p,m,0,0,Nt[3],Bc,!1,fi,!1,tt);if(l&&x==="declutter"&&l.collides(ti.declutterBox))break t;Ge.push([t,e,ut,ti,1,null,null])}l&&x!=="none"&&l.load(Ge.map(Pf));for(let ti=0,Lg=Ge.length;ti<Lg;++ti)this.replayImageOrLabel_.apply(this,Ge[ti])}}++u;break;case D.END_GEOMETRY:if(o!==void 0){tt=v[1];let re=o(tt,kt,x);if(re)return re}++u;break;case D.FILL:X?H++:this.fill_(t),++u;break;case D.MOVE_TO_LINE_TO:for(f=v[1],g=v[2],_=v[3],y=v[4]??!1,it=h[f],ot=h[f+1],_&&(E=f,[it,ot]=ts(it,ot,y?h[g-4]:void 0,y?h[g-3]:void 0,h[f+2],h[f+3],_)),t.moveTo(it,ot),C=it+.5|0,T=ot+.5|0,f+=2;f<g;f+=2)it=h[f],ot=h[f+1],I=it+.5|0,S=ot+.5|0,(f==g-2||I!==C||S!==T)&&(_&&(f==g-2?[it,ot]=ts(it,ot,h[f-2],h[f-1],y?h[E+2]:void 0,y?h[E+3]:void 0,_):[it,ot]=ts(it,ot,h[f-2],h[f-1],h[f+2],h[f+3],_)),t.lineTo(it,ot),C=I,T=S);++u;break;case D.SET_FILL_STYLE:this.alignAndScaleFill_=v[2],H&&(this.fill_(t),H=0,$&&(t.stroke(),$=0)),t.fillStyle=v[1],++u;break;case D.SET_STROKE_STYLE:$&&(t.stroke(),$=0),this.setStrokeStyle_(t,v),++u;break;case D.STROKE:X?$++:t.stroke(),++u;break;default:++u;break}}H&&this.fill_(t),$&&t.stroke()}execute(t,e,i,r,s,o){this.viewRotation_=r,this.execute_(t,e,i,this.instructions,s,void 0,void 0,o)}executeHitDetection(t,e,i,r,s){return this.viewRotation_=i,this.execute_(t,[t.canvas.width,t.canvas.height],e,this.hitDetectionInstructions,!0,r,s)}},Ff=kh;var Hi=["Polygon","Circle","LineString","Image","Text","Default"],zh=["Image","Text"],Df=Hi.filter(n=>!zh.includes(n)),kf=!1,Nf=!1;function kp(){let n=0,t=i=>{let r=nt(1,1,null,{willReadFrequently:i}),s=0,o=performance.now();for(;performance.now()-o<50;++s)r.fillStyle=`rgba(255,0,${s%256},1)`,r.fillRect(0,0,1,1),r.getImageData(0,0,1,1);return n=s>n?s:n,s};kf={[t(!0)]:!0,[t(!1)]:!1,[t(void 0)]:void 0}[n],Nf=!0}var Gh=class{constructor(t,e,i,r,s,o,a){this.maxExtent_=t,this.overlaps_=r,this.pixelRatio_=i,this.resolution_=e,this.renderBuffer_=o,this.executorsByZIndex_={},this.hitDetectionContext_=null,this.hitDetectionTransform_=Tt(),this.renderedContext_=null,this.deferredZIndexContexts_={},this.createExecutors_(s,a)}clip(t,e){let 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(let i in t){let r=this.executorsByZIndex_[i];r===void 0&&(r={},this.executorsByZIndex_[i]=r);let s=t[i];for(let o in s){let a=s[o];r[o]=new Ff(this.resolution_,this.pixelRatio_,this.overlaps_,a,e)}}}hasExecutors(t){for(let e in this.executorsByZIndex_){let i=this.executorsByZIndex_[e];for(let r=0,s=t.length;r<s;++r)if(t[r]in i)return!0}return!1}forEachFeatureAtCoordinate(t,e,i,r,s,o){Nf===!1&&kp(),r=Math.round(r);let a=r*2+1,l=Et(this.hitDetectionTransform_,r+.5,r+.5,1/e,-1/e,-i,-t[0],-t[1]),c=!this.hitDetectionContext_;c&&(this.hitDetectionContext_=nt(a,a,null,{willReadFrequently:kf}));let h=this.hitDetectionContext_;h.canvas.width!==a||h.canvas.height!==a?(h.canvas.width=a,h.canvas.height=a):c||h.clearRect(0,0,a,a);let u;this.renderBuffer_!==void 0&&(u=ct(),Qi(u,t),ri(u,e*(this.renderBuffer_+r),u));let d=Np(r),f;function g(C,T,I){let S=h.getImageData(0,0,a,a).data;for(let w=0,M=d.length;w<M;w++)if(S[d[w]]>0){if(!o||I==="none"||f!=="Image"&&f!=="Text"||o.includes(C)){let N=(d[w]-3)/4,z=r-N%a,A=r-(N/a|0),H=s(C,T,z*z+A*A);if(H)return H}h.clearRect(0,0,a,a);break}}let p=Object.keys(this.executorsByZIndex_).map(Number);p.sort(jt);let m,_,y,E,x;for(m=p.length-1;m>=0;--m){let C=p[m].toString();for(y=this.executorsByZIndex_[C],_=Hi.length-1;_>=0;--_)if(f=Hi[_],E=y[f],E!==void 0&&(x=E.executeHitDetection(h,l,i,g,u),x))return x}}getClipCoords(t){let e=this.maxExtent_;if(!e)return null;let i=e[0],r=e[1],s=e[2],o=e[3],a=[i,r,i,o,s,o,s,r];return Kt(a,0,8,2,t,a),a}isEmpty(){return $t(this.executorsByZIndex_)}execute(t,e,i,r,s,o,a){let l=Object.keys(this.executorsByZIndex_).map(Number);l.sort(a?$c:jt),o=o||Hi;let c=Hi.length;for(let h=0,u=l.length;h<u;++h){let d=l[h].toString(),f=this.executorsByZIndex_[d];for(let g=0,p=o.length;g<p;++g){let m=o[g],_=f[m];if(_!==void 0){let y=a===null?void 0:_.getZIndexContext(),E=y?y.getContext():t,x=this.maxExtent_&&m!=="Image"&&m!=="Text";if(x&&(E.save(),this.clip(E,i)),!y||m==="Text"||m==="Image"?_.execute(E,e,i,r,s,a):y.pushFunction(C=>_.execute(C,e,i,r,s,a)),x&&E.restore(),y){y.offset();let C=l[h]*c+Hi.indexOf(m);this.deferredZIndexContexts_[C]||(this.deferredZIndexContexts_[C]=[]),this.deferredZIndexContexts_[C].push(y)}}}}this.renderedContext_=t}getDeferredZIndexContexts(){return this.deferredZIndexContexts_}getRenderedContext(){return this.renderedContext_}renderDeferred(){let t=this.deferredZIndexContexts_,e=Object.keys(t).map(Number).sort(jt);for(let i=0,r=e.length;i<r;++i)t[e[i]].forEach(s=>{s.draw(this.renderedContext_),s.clear()}),t[e[i]].length=0}},Nh={};function Np(n){if(Nh[n]!==void 0)return Nh[n];let t=n*2+1,e=n*n,i=new Array(e+1);for(let s=0;s<=n;++s)for(let o=0;o<=n;++o){let a=s*s+o*o;if(a>e)break;let l=i[a];l||(l=[],i[a]=l),l.push(((n+s)*t+(n+o))*4+3),s>0&&l.push(((n-s)*t+(n+o))*4+3),o>0&&(l.push(((n+s)*t+(n-o))*4+3),s>0&&l.push(((n-s)*t+(n-o))*4+3))}let r=[];for(let s=0,o=i.length;s<o;++s)i[s]&&r.push(...i[s]);return Nh[n]=r,r}var Gf=Gh;var jh=class extends Oo{constructor(t,e,i,r,s,o,a){super(),this.context_=t,this.pixelRatio_=e,this.extent_=i,this.transform_=r,this.transformRotation_=r?Ti(Math.atan2(r[1],r[0]),10):0,this.viewRotation_=s,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_=Tt()}drawImages_(t,e,i,r){if(!this.image_)return;let s=Kt(t,e,i,r,this.transform_,this.pixelCoordinates_),o=this.context_,a=this.tmpLocalTransform_,l=o.globalAlpha;this.imageOpacity_!=1&&(o.globalAlpha=l*this.imageOpacity_);let c=this.imageRotation_;this.transformRotation_===0&&(c-=this.viewRotation_),this.imageRotateWithView_&&(c+=this.viewRotation_);for(let h=0,u=s.length;h<u;h+=2){let d=s[h]-this.imageAnchorX_,f=s[h+1]-this.imageAnchorY_;if(c!==0||this.imageScale_[0]!=1||this.imageScale_[1]!=1){let g=d+this.imageAnchorX_,p=f+this.imageAnchorY_;Et(a,g,p,1,1,c,-g,-p),o.save(),o.transform.apply(o,a),o.translate(g,p),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,r){if(!this.textState_||this.text_==="")return;this.textFillState_&&this.setContextFillState_(this.textFillState_),this.textStrokeState_&&this.setContextStrokeState_(this.textStrokeState_),this.setContextTextState_(this.textState_);let s=Kt(t,e,i,r,this.transform_,this.pixelCoordinates_),o=this.context_,a=this.textRotation_;for(this.transformRotation_===0&&(a-=this.viewRotation_),this.textRotateWithView_&&(a+=this.viewRotation_);e<i;e+=r){let l=s[e]+this.textOffsetX_,c=s[e+1]+this.textOffsetY_;a!==0||this.textScale_[0]!=1||this.textScale_[1]!=1?(o.save(),o.translate(l-this.textOffsetX_,c-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,c),this.textFillState_&&o.fillText(this.text_,l,c))}}moveToLineTo_(t,e,i,r,s,o){let a=this.context_,l=Kt(t,e,i,r,this.transform_,this.pixelCoordinates_);Math.abs(o)>0&&(l=Lf(l,r,o,s,l)),a.moveTo(l[0],l[1]);let c=l.length;s&&(c-=2);for(let h=2;h<c;h+=2)a.lineTo(l[h],l[h+1]);return s&&a.closePath(),i}drawRings_(t,e,i,r,s){for(let o=0,a=i.length;o<a;++o)e=this.moveToLineTo_(t,e,i[o],r,!0,s);return e}drawCircle(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!lt(this.extent_,t.getExtent())){if(this.fillState_||this.strokeState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);let e=qu(t,this.transform_,this.pixelCoordinates_),i=e[2]-e[0],r=e[3]-e[1],s=Math.sqrt(i*i+r*r),o=this.context_;o.beginPath(),o.arc(e[0],e[1],s,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;default:}}drawFeature(t,e){let i=e.getGeometryFunction()(t);i&&(this.setStyle(e),this.drawGeometry(i))}drawGeometryCollection(t){let e=t.getGeometriesArray();for(let i=0,r=e.length;i<r;++i)this.drawGeometry(e[i])}drawPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));let 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_));let 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_)),!!lt(this.extent_,t.getExtent())){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);let e=this.context_,i=t.getFlatCoordinates();e.beginPath(),this.moveToLineTo_(i,0,i.length,t.getStride(),!1,this.strokeState_.strokeOffset),e.stroke()}if(this.text_!==""){let e=t.getFlatMidpoint();this.drawText_(e,0,2,2)}}}drawMultiLineString(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));let e=t.getExtent();if(lt(this.extent_,e)){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);let i=this.context_,r=t.getFlatCoordinates(),s=0,o=t.getEnds(),a=t.getStride();i.beginPath();for(let l=0,c=o.length;l<c;++l)s=this.moveToLineTo_(r,s,o[l],a,!1,this.strokeState_.strokeOffset);i.stroke()}if(this.text_!==""){let i=t.getFlatMidpoints();this.drawText_(i,0,i.length,2)}}}drawPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!lt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);let e=this.context_;e.beginPath(),this.drawRings_(t.getOrientedFlatCoordinates(),0,t.getEnds(),t.getStride(),this.strokeState_?.strokeOffset),this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){let e=t.getFlatInteriorPoint();this.drawText_(e,0,2,2)}}}drawMultiPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!lt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);let e=this.context_,i=t.getOrientedFlatCoordinates(),r=0,s=t.getEndss(),o=t.getStride();e.beginPath();for(let a=0,l=s.length;a<l;++a){let c=s[a];r=this.drawRings_(i,r,c,o,this.strokeState_?.strokeOffset)}this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){let e=t.getFlatInteriorPoints();this.drawText_(e,0,e.length,2)}}}setContextFillState_(t){let 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){let e=this.context_,i=this.contextStrokeState_;i?(i.lineCap!=t.lineCap&&(i.lineCap=t.lineCap,e.lineCap=t.lineCap),Ot(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){let e=this.context_,i=this.contextTextState_,r=t.textAlign?t.textAlign:Ui;i?(i.font!=t.font&&(i.font=t.font,e.font=t.font),i.textAlign!=r&&(i.textAlign=r,e.textAlign=r),i.textBaseline!=t.textBaseline&&(i.textBaseline=t.textBaseline,e.textBaseline=t.textBaseline)):(e.font=t.font,e.textAlign=r,e.textBaseline=t.textBaseline,this.contextTextState_={font:t.font,textAlign:r,textBaseline:t.textBaseline})}setFillStrokeStyle(t,e){if(!t)this.fillState_=null;else{let i=t.getColor();this.fillState_={fillStyle:Zt(i||Ct)}}if(!e)this.strokeState_=null;else{let i=e.getColor(),r=e.getLineCap(),s=e.getLineDash(),o=e.getLineDashOffset(),a=e.getLineJoin(),l=e.getWidth(),c=e.getMiterLimit(),h=s||Ht,u=e.getOffset();this.strokeState_={lineCap:r!==void 0?r:Ve,lineDash:this.pixelRatio_===1?h:h.map(d=>d*this.pixelRatio_),lineDashOffset:(o||qt)*this.pixelRatio_,lineJoin:a!==void 0?a:Be,lineWidth:(l!==void 0?l:gi)*this.pixelRatio_,miterLimit:c!==void 0?c:ui,strokeStyle:Zt(i||di),strokeOffset:(u??0)*this.pixelRatio_}}}setImageStyle(t){let e;if(!t||!(e=t.getSize())){this.image_=null;return}let i=t.getPixelRatio(this.pixelRatio_),r=t.getAnchor(),s=t.getOrigin();this.image_=t.getImage(this.pixelRatio_),this.imageAnchorX_=r[0]*i,this.imageAnchorY_=r[1]*i,this.imageHeight_=e[1]*i,this.imageOpacity_=t.getOpacity(),this.imageOriginX_=s[0],this.imageOriginY_=s[1],this.imageRotateWithView_=t.getRotateWithView(),this.imageRotation_=t.getRotation();let 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{let e=t.getFill();if(!e)this.textFillState_=null;else{let f=e.getColor();this.textFillState_={fillStyle:Zt(f||Ct)}}let i=t.getStroke();if(!i)this.textStrokeState_=null;else{let f=i.getColor(),g=i.getLineCap(),p=i.getLineDash(),m=i.getLineDashOffset(),_=i.getLineJoin(),y=i.getWidth(),E=i.getMiterLimit();this.textStrokeState_={lineCap:g!==void 0?g:Ve,lineDash:p||Ht,lineDashOffset:m||qt,lineJoin:_!==void 0?_:Be,lineWidth:y!==void 0?y:gi,miterLimit:E!==void 0?E:ui,strokeStyle:Zt(f||di)}}let r=t.getFont(),s=t.getOffsetX(),o=t.getOffsetY(),a=t.getRotateWithView(),l=t.getRotation(),c=t.getScaleArray(),h=t.getText(),u=t.getTextAlign(),d=t.getTextBaseline();this.textState_={font:r!==void 0?r:fo,textAlign:u!==void 0?u:Ui,textBaseline:d!==void 0?d:un},this.text_=h!==void 0?Array.isArray(h)?h.reduce((f,g,p)=>f+=p%2?" ":g,""):h:"",this.textOffsetX_=s!==void 0?this.pixelRatio_*s: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_*c[0],this.pixelRatio_*c[1]]}}},zf=jh;var Oe=.5;function jf(n,t,e,i,r,s,o,a,l){let c=l?Mi(r,l):r,h=n[0]*Oe,u=n[1]*Oe,d=nt(h,u);d.imageSmoothingEnabled=!1;let f=d.canvas,g=new zf(d,Oe,r,null,o,a,l?Ye(hi(),l):null),p=e.length,m=Math.floor((256*256*256-1)/p),_={};for(let E=1;E<=p;++E){let x=e[E-1],C=x.getStyleFunction()||i;if(!C)continue;let T=C(x,s);if(!T)continue;Array.isArray(T)||(T=[T]);let S=(E*m).toString(16).padStart(7,"#00000");for(let w=0,M=T.length;w<M;++w){let N=T[w],z=N.getGeometryFunction()(x);if(!z||!lt(c,z.getExtent()))continue;let A=N.clone(),H=A.getFill();H&&H.setColor(S);let $=A.getStroke();$&&($.setColor(S),$.setLineDash(null)),A.setText(void 0);let P=N.getImage();if(P){let X=P.getImageSize();if(!X)continue;let tt=nt(X[0],X[1],void 0,{alpha:!1}),it=tt.canvas;tt.fillStyle=S,tt.fillRect(0,0,it.width,it.height),A.setImage(new Vr({img:it,anchor:P.getAnchor(),anchorXUnits:"pixels",anchorYUnits:"pixels",offset:P.getOrigin(),opacity:1,size:P.getSize(),scale:P.getScale(),rotation:P.getRotation(),rotateWithView:P.getRotateWithView()}))}let j=A.getZIndex()||0,k=_[j];k||(k={},_[j]=k,k.Polygon=[],k.Circle=[],k.LineString=[],k.Point=[]);let K=z.getType();if(K==="GeometryCollection"){let X=z.getGeometriesArrayRecursive();for(let tt=0,it=X.length;tt<it;++tt){let ot=X[tt];k[ot.getType().replace("Multi","")].push(ot,A)}}else k[K.replace("Multi","")].push(z,A)}}let y=Object.keys(_).map(Number).sort(jt);for(let E=0,x=y.length;E<x;++E){let C=_[y[E]];for(let T in C){let I=C[T];for(let S=0,w=I.length;S<w;S+=2){g.setStyle(I[S+1]);for(let M=0,N=t.length;M<N;++M)g.setTransform(t[M]),g.drawGeometry(I[S])}}}return d.getImageData(0,0,f.width,f.height)}function Wf(n,t,e){let i=[];if(e){let r=Math.floor(Math.round(n[0])*Oe),s=Math.floor(Math.round(n[1])*Oe),o=(Q(r,0,e.width-1)+Q(s,0,e.height-1)*e.width)*4,a=e.data[o],l=e.data[o+1],h=e.data[o+2]+256*(l+256*a),u=Math.floor((256*256*256-1)/t.length);h&&h%u===0&&i.push(t[h/u-1])}return i}var Gp=.5,Xf={Point:Kp,LineString:Xp,Polygon:Bp,MultiPoint:Vp,MultiLineString:Up,MultiPolygon:Yp,GeometryCollection:Wp,Circle:zp};function Uf(n,t){return parseInt(U(n),10)-parseInt(U(t),10)}function Wh(n,t){let e=Xh(n,t);return e*e}function Xh(n,t){return Gp*n/t}function zp(n,t,e,i,r){let s=e.getFill(),o=e.getStroke();if(s||o){let l=n.getBuilder(e.getZIndex(),"Circle");l.setFillStrokeStyle(s,o),l.drawCircle(t,i,r)}let a=e.getText();if(a&&a.getText()){let l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i)}}function Uh(n,t,e,i,r,s,o,a){let l=[],c=e.getImage();if(c){let d=!0,f=c.getImageState();f==b.LOADED||f==b.ERROR?d=!1:f==b.IDLE&&c.load(),d&&l.push(c.ready())}let h=e.getFill();h&&h.loading()&&l.push(h.ready());let u=l.length>0;return u&&Promise.all(l).then(()=>r(null)),jp(n,t,e,i,s,o,a),u}function jp(n,t,e,i,r,s,o){let a=e.getGeometryFunction()(t);if(!a)return;let l=a.simplifyTransformed(i,r);if(e.getRenderer())Yf(n,l,e,t,o);else{let h=Xf[l.getType()];h(n,l,e,t,o,s)}}function Yf(n,t,e,i,r){if(t.getType()=="GeometryCollection"){let o=t.getGeometries();for(let a=0,l=o.length;a<l;++a)Yf(n,o[a],e,i,r);return}n.getBuilder(e.getZIndex(),"Default").drawCustom(t,i,e.getRenderer(),e.getHitDetectionRenderer(),r)}function Wp(n,t,e,i,r,s){let o=t.getGeometriesArray(),a,l;for(a=0,l=o.length;a<l;++a){let c=Xf[o[a].getType()];c(n,o[a],e,i,r,s)}}function Xp(n,t,e,i,r){let s=e.getStroke();if(s){let a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,s),a.drawLineString(t,i,r)}let o=e.getText();if(o&&o.getText()){let a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,r)}}function Up(n,t,e,i,r){let s=e.getStroke();if(s){let a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,s),a.drawMultiLineString(t,i,r)}let o=e.getText();if(o&&o.getText()){let a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,r)}}function Yp(n,t,e,i,r){let s=e.getFill(),o=e.getStroke();if(o||s){let l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(s,o),l.drawMultiPolygon(t,i,r)}let a=e.getText();if(a&&a.getText()){let l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,r)}}function Kp(n,t,e,i,r,s){let o=e.getImage(),a=e.getText(),l=a&&a.getText(),c=s&&o&&l?{}:void 0;if(o){if(o.getImageState()!=b.LOADED)return;let h=n.getBuilder(e.getZIndex(),"Image");h.setImageStyle(o,c),h.drawPoint(t,i,r)}if(l){let h=n.getBuilder(e.getZIndex(),"Text");h.setTextStyle(a,c),h.drawText(t,i,r)}}function Vp(n,t,e,i,r,s){let o=e.getImage(),a=o&&o.getOpacity()!==0,l=e.getText(),c=l&&l.getText(),h=s&&a&&c?{}:void 0;if(a){if(o.getImageState()!=b.LOADED)return;let u=n.getBuilder(e.getZIndex(),"Image");u.setImageStyle(o,h),u.drawMultiPoint(t,i,r)}if(c){let u=n.getBuilder(e.getZIndex(),"Text");u.setTextStyle(l,h),u.drawText(t,i,r)}}function Bp(n,t,e,i,r){let s=e.getFill(),o=e.getStroke();if(s||o){let l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(s,o),l.drawPolygon(t,i,r)}let a=e.getText();if(a&&a.getText()){let l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,r)}}var Yh=class extends Hn{constructor(t){super(t),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.animatingOrInteracting_,this.hitDetectionImageData_=null,this.clipExtent_=null,this.extendX_=!1,this.renderedFeatures_=null,this.renderedRevision_=-1,this.renderedResolution_=NaN,this.renderedExtent_=ct(),this.wrappedRenderedExtent_=ct(),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){let r=e.extent,s=e.viewState,o=s.center,a=s.resolution,l=s.projection,c=s.rotation,h=l.getExtent(),u=this.getLayer().getSource(),d=this.getLayer().getDeclutter(),f=e.pixelRatio,g=e.viewHints,p=!(g[dt.ANIMATING]||g[dt.INTERACTING]),m=this.context,_=Math.round(W(r)/a*f),y=Math.round(et(r)/a*f),E=u.getWrapX()&&l.canWrapX(),x=E?W(h):null,C=E?Math.ceil((r[2]-h[2])/x)+(this.extendX_?2:1):1,T=E?Math.floor((r[0]-h[0])/x)-(this.extendX_?1:0):0;do{let I=this.getRenderTransform(o,a,0,f,_,y,T*x);e.declutter&&(I=I.slice(0)),t.execute(m,[m.canvas.width,m.canvas.height],I,c,p,i===void 0?Hi:i?zh:Df,i?d&&e.declutter[d]:void 0)}while(++T<C)}setDrawContext_(){this.opacity_!==1&&(this.targetContext_=this.context,this.context=nt(this.context.canvas.width,this.context.canvas.height,Ch))}resetDrawContext_(){if(this.opacity_!==1&&this.targetContext_){let t=this.targetContext_.globalAlpha;this.targetContext_.globalAlpha=this.opacity_,this.targetContext_.drawImage(this.context.canvas,0,0),this.targetContext_.globalAlpha=t,on(this.context),Ch.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.clipExtent_&&this.clipUnrotated(this.context,t,this.clipExtent_),this.replayGroup_.renderDeferred(),this.clipExtent_&&(this.context.restore(),this.clipExtent_=null),this.resetDrawContext_())}renderFrame(t,e){let i=t.layerStatesArray[t.layerIndex];this.opacity_=i.opacity;let r=t.viewState;this.prepareContainer(t,e);let s=this.context,o=this.replayGroup_,a=o&&!o.isEmpty();if(!a&&!(this.getLayer().hasListener(Lt.PRERENDER)||this.getLayer().hasListener(Lt.POSTRENDER)))return this.container;this.setDrawContext_(),this.preRender(s,t);let l=r.projection;this.clipExtent_=null;let c=!1;if(a&&i.extent&&this.clipping){let h=Gt(i.extent,l);a=lt(h,t.extent),a&&!le(h,t.extent)&&(t.declutter?this.clipExtent_=h:(this.clipUnrotated(s,t,h),c=!0))}return a&&this.renderWorlds(o,t,this.getLayer().getDeclutter()?!1:void 0),c&&s.restore(),this.postRender(s,t),this.renderedRotation_!==r.rotation&&(this.renderedRotation_=r.rotation,this.hitDetectionImageData_=null),t.declutter||this.resetDrawContext_(),this.container}getFeatures(t){return new Promise(e=>{if(this.frameState&&!this.hitDetectionImageData_&&!this.animatingOrInteracting_){let i=this.frameState.size.slice(),r=this.renderedCenter_,s=this.renderedResolution_,o=this.renderedRotation_,a=this.renderedProjection_,l=this.wrappedRenderedExtent_,c=this.getLayer(),h=[],u=i[0]*Oe,d=i[1]*Oe;h.push(this.getRenderTransform(r,s,o,Oe,u,d,0).slice());let f=c.getSource(),g=a.getExtent();if(f.getWrapX()&&a.canWrapX()&&!le(g,l)){let m=l[0],_=W(g),y=0,E;for(;m<g[0];)--y,E=_*y,h.push(this.getRenderTransform(r,s,o,Oe,u,d,E).slice()),m+=_;for(y=0,m=l[2];m>g[2];)++y,E=_*y,h.push(this.getRenderTransform(r,s,o,Oe,u,d,E).slice()),m-=_}let p=hi();this.hitDetectionImageData_=jf(i,h,this.renderedFeatures_,c.getStyleFunction(),l,s,o,Wh(s,this.renderedPixelRatio_),p?a:null)}e(Wf(t,this.renderedFeatures_,this.hitDetectionImageData_))})}forEachFeatureAtCoordinate(t,e,i,r,s){if(!this.replayGroup_)return;let o=e.viewState.resolution,a=e.viewState.rotation,l=this.getLayer(),c={},h=function(d,f,g){let p=U(d),m=c[p];if(m){if(m!==!0&&g<m.distanceSq){if(g===0)return c[p]=!0,s.splice(s.lastIndexOf(m),1),r(d,l,f);m.geometry=f,m.distanceSq=g}}else{if(g===0)return c[p]=!0,r(d,l,f);s.push(c[p]={feature:d,layer:l,geometry:f,distanceSq:g,callback:r})}},u=this.getLayer().getDeclutter();return this.replayGroup_.forEachFeatureAtCoordinate(t,o,a,i,h,u?e.declutter?.[u]?.all().map(d=>d.value):null)}handleFontsChanged(){let t=this.getLayer();t.getVisible()&&this.replayGroup_&&t.changed()}handleStyleImageChange_(t){this.renderIfReadyAndVisible()}prepareFrame(t){let e=this.getLayer(),i=e.getSource();if(!i)return!1;let r=t.viewHints[dt.ANIMATING],s=t.viewHints[dt.INTERACTING],o=e.getUpdateWhileAnimating(),a=e.getUpdateWhileInteracting();if(this.ready&&!o&&r||!a&&s)return this.animatingOrInteracting_=!0,!0;this.animatingOrInteracting_=!1;let l=t.extent,c=t.viewState,h=c.projection,u=c.resolution,d=t.pixelRatio,f=e.getRevision(),g=e.getRenderBuffer(),p=e.getRenderOrder();p===void 0&&(p=Uf);let m=c.center.slice(),_=ri(l,g*u),y=_.slice(),E=[_.slice()],x=h.getExtent(),C=i.getWrapX()&&h.canWrapX();if(this.extendX_=!1,C){let P=i.getExtent();P&&!Yt(P)&&(this.extendX_=P[0]<x[0]||P[2]>x[2])}if(C&&(!le(x,t.extent)||this.extendX_)){let P=W(x),j=Math.max(W(_)/2,P),k=x[0],K=x[2];this.extendX_&&(k-=P,K+=P),_[0]=k-j,_[2]=K+j,Tn(m,h);let X=_a(E[0],h);X[0]<x[0]&&X[2]<x[2]?E.push([X[0]+P,X[1],X[2]+P,X[3]]):X[0]>x[0]&&X[2]>x[2]&&E.push([X[0]-P,X[1],X[2]-P,X[3]])}if(this.ready&&this.renderedResolution_==u&&this.renderedPixelRatio_===d&&this.renderedRevision_==f&&this.renderedRenderOrder_==p&&this.renderedFrameDeclutter_===!!t.declutter&&le(this.wrappedRenderedExtent_,_))return Ot(this.renderedExtent_,y)||(this.hitDetectionImageData_=null,this.renderedExtent_=y),this.renderedCenter_=m,this.replayGroupChanged=!1,!0;this.replayGroup_=null;let T=new bf(Xh(u,d),_,u,d),I=hi(),S;if(I){for(let P=0,j=E.length;P<j;++P){let k=E[P],K=Mi(k,h);i.loadFeatures(K,Xu(u,h),I)}S=Ye(I,h)}else for(let P=0,j=E.length;P<j;++P)i.loadFeatures(E[P],u,h);let w=Wh(u,d),M=!0,N=(P,j)=>{let k,K=P.getStyleFunction()||e.getStyleFunction();if(K&&(k=K(P,u)),k){let X=this.renderFeature(P,w,k,T,S,this.getLayer().getDeclutter(),j);M=M&&!X}},z=Mi(_,h),A=i.getFeaturesInExtent(z);p&&A.sort(p);for(let P=0,j=A.length;P<j;++P)N(A[P],P);this.renderedFeatures_=A,this.ready=M;let H=T.finish(),$=new Gf(_,u,d,i.getOverlaps(),H,e.getRenderBuffer(),!!t.declutter);return this.renderedResolution_=u,this.renderedRevision_=f,this.renderedRenderOrder_=p,this.renderedFrameDeclutter_=!!t.declutter,this.renderedExtent_=y,this.wrappedRenderedExtent_=_,this.renderedCenter_=m,this.renderedProjection_=h,this.renderedPixelRatio_=d,this.replayGroup_=$,this.hitDetectionImageData_=null,this.replayGroupChanged=!0,!0}renderFeature(t,e,i,r,s,o,a){if(!i)return!1;let l=!1;if(Array.isArray(i))for(let c=0,h=i.length;c<h;++c)l=Uh(r,t,i[c],e,this.boundHandleStyleImageChange_,s,o,a)||l;else l=Uh(r,t,i,e,this.boundHandleStyleImageChange_,s,o,a);return l}},Kf=Yh;var Kh=class extends Co{constructor(t){super(t)}createRenderer(){return new Kf(this)}},Vh=Kh;var Bh=class extends Hn{constructor(t){super(t),this.image=null,this.renderedSourceRevision_=0}getImage(){return this.image?this.image.getImage():null}prepareFrame(t){let e=t.layerStatesArray[t.layerIndex],i=t.pixelRatio,r=t.viewState,s=r.resolution,o=this.getLayer().getSource(),a=t.viewHints,l=t.extent;if(e.extent!==void 0&&(l=Ut(l,Gt(e.extent,r.projection))),!a[dt.ANIMATING]&&!a[dt.INTERACTING]&&!Yt(l))if(o){!this.getLayer().rendered&&this.renderedSourceRevision_!==o.getRevision()&&(this.image=null),this.renderedSourceRevision_=o.getRevision();let c=r.projection,h=o.getImage(l,s,i,c);h&&(this.loadImage(h)?this.image=h:h.getState()===b.EMPTY&&(this.image=null))}else this.image=null;return!!this.image}getData(t){let e=this.frameState;if(!e)return null;let i=this.getLayer(),r=ht(e.pixelToCoordinateTransform,t.slice()),s=i.getExtent();if(s&&!Jt(s,r))return null;let o=this.image.getExtent(),a=this.image.getImage(),l=W(o),c=Math.floor(a.width*((r[0]-o[0])/l));if(c<0||c>=a.width)return null;let h=et(o),u=Math.floor(a.height*((o[3]-r[1])/h));return u<0||u>=a.height?null:this.getImageData(a,c,u)}renderFrame(t,e){let i=this.image,r=i.getExtent(),s=i.getResolution(),[o,a]=Array.isArray(s)?s:[s,s],l=i.getPixelRatio(),c=t.layerStatesArray[t.layerIndex],h=t.pixelRatio,u=t.viewState,d=u.center,f=u.resolution,g=h*o/(f*l),p=h*a/(f*l);this.prepareContainer(t,e);let m=this.context.canvas.width,_=this.context.canvas.height,y=this.getRenderContext(t),E=!1,x=!0;if(c.extent){let w=Gt(c.extent,u.projection);x=lt(w,t.extent),E=x&&!le(w,t.extent),E&&this.clipUnrotated(y,t,w)}let C=i.getImage(),T=Et(this.tempTransform,m/2,_/2,g,p,0,l*(r[0]-d[0])/o,l*(d[1]-r[3])/a);this.renderedResolution=a*h/l;let I=C.width*T[0],S=C.height*T[3];if(this.getLayer().getSource().getInterpolate()||(y.imageSmoothingEnabled=!1),this.preRender(y,t),x&&I>=.5&&S>=.5){let w=T[4],M=T[5],N=c.opacity;N!==1&&(y.save(),y.globalAlpha=N),y.drawImage(C,0,0,+C.width,+C.height,w,M,I,S),N!==1&&y.restore()}return this.postRender(this.context,t),E&&y.restore(),y.imageSmoothingEnabled=!0,this.container}},Vf=Bh;var Zh=class extends ci{constructor(t){t=t||{},super(t)}},Bf=Zh;var Hh=class extends Bf{constructor(t){super(t)}createRenderer(){return new Vf(this)}getData(t){return super.getData(t)}},Zf=Hh;var Jn=[0,0,0],qi=5,qh=class{constructor(t){this.minZoom=t.minZoom!==void 0?t.minZoom:0,this.resolutions_=t.resolutions,V(Qc(this.resolutions_,(r,s)=>s-r,!0),"`resolutions` must be sorted in descending order");let e;if(!t.origins){for(let r=0,s=this.resolutions_.length-1;r<s;++r)if(!e)e=this.resolutions_[r]/this.resolutions_[r+1];else if(this.resolutions_[r]/this.resolutions_[r+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,V(this.origins_.length==this.resolutions_.length,"Number of `origins` and `resolutions` must be equal"));let i=t.extent;i!==void 0&&!this.origin_&&!this.origins_&&(this.origin_=he(i)),V(!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,V(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:256,V(!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((r,s)=>{let o=new vo(Math.min(0,r[0]),Math.max(r[0]-1,-1),Math.min(0,r[1]),Math.max(r[1]-1,-1));if(i){let a=this.getTileRangeForExtentAndZ(i,s);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){let r=this.getTileRangeForExtentAndZ(t,e);for(let s=r.minX,o=r.maxX;s<=o;++s)for(let a=r.minY,l=r.maxY;a<=l;++a)i([e,s,a])}forEachTileCoordParentTileRange(t,e,i,r){let s,o,a,l=null,c=t[0]-1;for(this.zoomFactor_===2?(o=t[1],a=t[2]):l=this.getTileCoordExtent(t,r);c>=this.minZoom;){if(o!==void 0&&a!==void 0?(o=Math.floor(o/2),a=Math.floor(a/2),s=dn(o,o,a,a,i)):s=this.getTileRangeForExtentAndZ(l,c,i),e(c,s))return!0;--c}return!1}getExtent(){return this.extent_}getMaxZoom(){return this.maxZoom}getMinZoom(){return this.minZoom}getOrigin(t){return this.origin_?this.origin_:this.origins_[t]}getOrigins(){return this.origins_}getResolution(t){return this.resolutions_[t]}getResolutions(){return this.resolutions_}getTileCoordChildTileRange(t,e,i){if(t[0]<this.maxZoom){if(this.zoomFactor_===2){let s=t[1]*2,o=t[2]*2;return dn(s,s+1,o,o+1,e)}let r=this.getTileCoordExtent(t,i||this.tmpExtent_);return this.getTileRangeForExtentAndZ(r,t[0]+1,e)}return null}getTileRangeForTileCoordAndZ(t,e,i){if(e>this.maxZoom||e<this.minZoom)return null;let r=t[0],s=t[1],o=t[2];if(e===r)return dn(s,o,s,o,i);if(this.zoomFactor_){let l=Math.pow(this.zoomFactor_,e-r),c=Math.floor(s*l),h=Math.floor(o*l);if(e<r)return dn(c,c,h,h,i);let u=Math.floor(l*(s+1))-1,d=Math.floor(l*(o+1))-1;return dn(c,u,h,d,i)}let a=this.getTileCoordExtent(t,this.tmpExtent_);return this.getTileRangeForExtentAndZ(a,e,i)}getTileRangeForExtentAndZ(t,e,i){this.getTileCoordForXYAndZ_(t[0],t[3],e,!1,Jn);let r=Jn[1],s=Jn[2];this.getTileCoordForXYAndZ_(t[2],t[1],e,!0,Jn);let o=Jn[1],a=Jn[2];return dn(r,o,s,a,i)}getTileCoordCenter(t){let e=this.getOrigin(t[0]),i=this.getResolution(t[0]),r=ft(this.getTileSize(t[0]),this.tmpSize_);return[e[0]+(t[1]+.5)*r[0]*i,e[1]-(t[2]+.5)*r[1]*i]}getTileCoordExtent(t,e){let i=this.getOrigin(t[0]),r=this.getResolution(t[0]),s=ft(this.getTileSize(t[0]),this.tmpSize_),o=i[0]+t[1]*s[0]*r,a=i[1]-(t[2]+1)*s[1]*r,l=o+s[0]*r,c=a+s[1]*r;return Qt(o,a,l,c,e)}getTileCoordForCoordAndResolution(t,e,i){return this.getTileCoordForXYAndResolution_(t[0],t[1],e,!1,i)}getTileCoordForXYAndResolution_(t,e,i,r,s){let o=this.getZForResolution(i),a=i/this.getResolution(o),l=this.getOrigin(o),c=ft(this.getTileSize(o),this.tmpSize_),h=a*(t-l[0])/i/c[0],u=a*(l[1]-e)/i/c[1];return r?(h=Ue(h,qi)-1,u=Ue(u,qi)-1):(h=vi(h,qi),u=vi(u,qi)),Vn(o,h,u,s)}getTileCoordForXYAndZ_(t,e,i,r,s){let o=this.getOrigin(i),a=this.getResolution(i),l=ft(this.getTileSize(i),this.tmpSize_),c=(t-o[0])/a/l[0],h=(o[1]-e)/a/l[1];return r?(c=Ue(c,qi)-1,h=Ue(h,qi)-1):(c=vi(c,qi),h=vi(h,qi)),Vn(i,c,h,s)}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){let i=Ri(this.resolutions_,t,e||0);return Q(i,this.minZoom,this.maxZoom)}tileCoordIntersectsViewport(t,e){return Ga(e,0,e.length,2,this.getTileCoordExtent(t))}calculateTileRanges_(t){let e=this.resolutions_.length,i=new Array(e);for(let r=this.minZoom;r<e;++r)i[r]=this.getTileRangeForExtentAndZ(t,r);this.fullTileRanges_=i}},$h=qh;function Fo(n){let t=n.getDefaultTileGrid();return t||(t=Hp(n),n.setDefaultTileGrid(t)),t}function Hf(n,t,e){let i=t[0],r=n.getTileCoordCenter(t),s=Do(e);if(!Jt(s,r)){let o=W(s),a=Math.ceil((s[0]-r[0])/o);return r[0]+=o*a,n.getTileCoordForCoordAndZ(r,i)}return t}function Zp(n,t,e,i){i=i!==void 0?i:"top-left";let r=$f(n,t,e);return new $h({extent:n,origin:cu(n,i),resolutions:r,tileSize:e})}function qf(n){let t=n||{},e=t.extent||q("EPSG:3857").getExtent(),i={extent:e,minZoom:t.minZoom,tileSize:t.tileSize,resolutions:$f(e,t.maxZoom,t.tileSize,t.maxResolution)};return new $h(i)}function $f(n,t,e,i){t=t!==void 0?t:42,e=ft(e!==void 0?e:256);let r=et(n),s=W(n);i=i>0?i:Math.max(s/e[0],r/e[1]);let o=t+1,a=new Array(o);for(let l=0;l<o;++l)a[l]=i/Math.pow(2,l);return a}function Hp(n,t,e,i){let r=Do(n);return Zp(r,t,e,i)}function Do(n){n=q(n);let t=n.getExtent();if(!t){let e=180*Se.degrees/n.getMetersPerUnit();t=Qt(-e,-e,e,e)}return t}function es(n,t){let e=[];Object.keys(t).forEach(function(r){t[r]!==null&&t[r]!==void 0&&e.push(r+"="+encodeURIComponent(t[r]))});let i=e.join("&");return n=n.replace(/[?&]$/,""),n+=n.includes("?")?"&":"?",n+i}var qp=/\{z\}/g,$p=/\{x\}/g,Jp=/\{y\}/g,Qp=/\{-y\}/g;function Jf(n,t,e,i,r){return n.replace(qp,t.toString()).replace($p,e.toString()).replace(Jp,i.toString()).replace(Qp,function(){if(r===void 0)throw new Error("If the URL template has a {-y} placeholder, the grid extent must be known");return(r-i).toString()})}function Qf(n){let t=[],e=/\{([a-z])-([a-z])\}/.exec(n);if(e){let i=e[1].charCodeAt(0),r=e[2].charCodeAt(0),s;for(s=i;s<=r;++s)t.push(n.replace(e[0],String.fromCharCode(s)));return t}if(e=/\{(\d+)-(\d+)\}/.exec(n),e){let i=parseInt(e[2],10);for(let r=parseInt(e[1],10);r<=i;r++)t.push(n.replace(e[0],r.toString()));return t}return t.push(n),t}function t_(n,t){return(function(e,i,r){if(!e)return;let s,o=e[0];if(t){let a=t.getFullTileRange(o);a&&(s=a.getHeight()-1)}return Jf(n,o,e[1],e[2],s)})}function tg(n,t){let e=n.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=t_(n[r],t);return e_(i)}function e_(n){return n.length===1?n[0]:(function(t,e,i){if(!t)return;let r=Lo(t),s=Wt(r,n.length);return n[s](t,e,i)})}var Jh=class extends pt{constructor(t){super(),this.projection=q(t.projection),this.attributions_=eg(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;let e=this;this.viewPromise_=new Promise(function(i,r){e.viewResolver=i,e.viewRejector=r})}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_=eg(t),this.changed()}setState(t){this.state_=t,this.changed()}};function eg(n){return n?typeof n=="function"?n:(Array.isArray(n)||(n=[n]),t=>n):null}var Qn=Jh;var Qh=class extends Qn{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;let e=[256,256];this.tileGrid&&ft(this.tileGrid.getTileSize(this.tileGrid.getMinZoom()),e),this.tmpSize=[0,0],this.key_=t.key||U(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){let e=t?this.getTileGridForProjection(t):this.tileGrid;return e?e.getResolutions():null}getTile(t,e,i,r,s,o){return F()}getTileGrid(){return this.tileGrid}getTileGridForProjection(t){return this.tileGrid?this.tileGrid:Fo(t)}getTilePixelRatio(t){return this.tilePixelRatio_}getTilePixelSize(t,e,i){let r=this.getTileGridForProjection(i),s=this.getTilePixelRatio(e),o=ft(r.getTileSize(t),this.tmpSize);return s==1?o:zd(o,s,this.tmpSize)}getTileCoordForTileUrlFunction(t,e){let i=e!==void 0?e:this.getProjection(),r=e!==void 0?this.getTileGridForProjection(i):this.tileGrid||this.getTileGridForProjection(i);return this.getWrapX()&&i.isGlobal()&&(t=Hf(r,t,i)),xf(t,r)?t:null}clear(){}refresh(){this.clear(),super.refresh()}},ko=class extends mt{constructor(t,e){super(t),this.tile=e}},ig=Qh;var No={TILELOADSTART:"tileloadstart",TILELOADEND:"tileloadend",TILELOADERROR:"tileloaderror"};var tc=class n extends ig{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===n.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){let e=t.target,i=U(e),r=e.getState(),s;r==O.LOADING?(this.tileLoadingKeys_[i]=!0,s=No.TILELOADSTART):i in this.tileLoadingKeys_&&(delete this.tileLoadingKeys_[i],s=r==O.ERROR?No.TILELOADERROR:r==O.LOADED?No.TILELOADEND:void 0),s!=null&&this.dispatchEvent(new ko(s,e))}setTileLoadFunction(t){this.tileLoadFunction=t,this.changed()}setTileUrlFunction(t,e){this.tileUrlFunction=t,typeof e<"u"?this.setKey(e):this.changed()}setUrl(t){let e=Qf(t);this.urls=e,this.setUrls(e)}setUrls(t){this.urls=t;let e=t.join(`
|
|
7
|
-
`);this.generateTileUrlFunction_?this.setTileUrlFunction(tg(t,this.tileGrid),e):this.setKey(e)}tileUrlFunction(t,e,i){}},ng=tc;var ec=class extends ng{constructor(t){super({attributions:t.attributions,cacheSize:t.cacheSize,projection:t.projection,state:t.state,tileGrid:t.tileGrid,tileLoadFunction:t.tileLoadFunction?t.tileLoadFunction:i_,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.referrerPolicy=t.referrerPolicy,this.tileClass=t.tileClass!==void 0?t.tileClass:So,this.tileGridForProjection={},this.reprojectionErrorThreshold_=t.reprojectionErrorThreshold,this.renderReprojectionEdges_=!1}getGutterForProjection(t){return this.getProjection()&&t&&!ve(this.getProjection(),t)?0:this.getGutter()}getGutter(){return 0}getKey(){let t=super.getKey();return this.getInterpolate()||(t+=":disable-interpolation"),t}getTileGridForProjection(t){let e=this.getProjection();if(this.tileGrid&&(!e||ve(e,t)))return this.tileGrid;let i=U(t);return i in this.tileGridForProjection||(this.tileGridForProjection[i]=Fo(t)),this.tileGridForProjection[i]}createTile_(t,e,i,r,s,o){let a=[t,e,i],l=this.getTileCoordForTileUrlFunction(a,s),c=l?this.tileUrlFunction(l,r,s):void 0,h=new this.tileClass(a,c!==void 0?O.IDLE:O.EMPTY,c!==void 0?c:"",{crossOrigin:this.crossOrigin,referrerPolicy:this.referrerPolicy},this.tileLoadFunction,this.tileOptions);return h.key=o,h.addEventListener(L.CHANGE,this.handleTileChange.bind(this)),h}getTile(t,e,i,r,s,o){let a=this.getProjection();if(!a||!s||ve(a,s))return this.getTileInternal(t,e,i,r,a||s);let l=[t,e,i],c=this.getKey(),h=this.getTileGridForProjection(a),u=this.getTileGridForProjection(s),d=this.getTileCoordForTileUrlFunction(l,s),f=new bo(a,h,s,u,l,d,this.getTilePixelRatio(r),this.getGutter(),(g,p,m,_)=>this.getTileInternal(g,p,m,_,a,o),this.reprojectionErrorThreshold_,this.renderReprojectionEdges_,this.tileOptions);return f.key=c,f}getTileInternal(t,e,i,r,s,o){let a=this.getKey(),l=Bn(this,a,t,e,i);if(o&&o.containsKey(l))return o.get(l);let c=this.createTile_(t,e,i,r,s,a);return o?.set(l,c),c}setRenderReprojectionEdges(t){this.renderReprojectionEdges_!=t&&(this.renderReprojectionEdges_=t,this.changed())}setTileGridForProjection(t,e){let i=q(t);if(i){let r=U(i);r in this.tileGridForProjection||(this.tileGridForProjection[r]=e)}}};function i_(n,t){if(xt){let e=n.getCrossOrigin(),i="same-origin",r="same-origin";e==="anonymous"||e===""?(i="cors",r="omit"):e==="use-credentials"&&(i="cors",r="include");let s={mode:i,credentials:r,referrerPolicy:n.getReferrerPolicy()};fetch(t,s).then(o=>{if(!o.ok)throw new Error(`HTTP ${o.status}`);return o.blob()}).then(o=>createImageBitmap(o)).then(o=>{let a=n.getImage();a.width=o.width,a.height=o.height,a.getContext("2d").drawImage(o,0,0),o.close?.(),a.dispatchEvent(new Event("load"))}).catch(()=>{n.getImage().dispatchEvent(new Event("error"))});return}n.getImage().src=t}var Go=ec;var ic=class extends Go{constructor(t){t=t||{};let e=t.projection!==void 0?t.projection:"EPSG:3857",i=t.tileGrid!==void 0?t.tileGrid:qf({extent:Do(e),maxResolution:t.maxResolution,maxZoom:t.maxZoom,minZoom:t.minZoom,tileSize:t.tileSize});super({attributions:t.attributions,cacheSize:t.cacheSize,crossOrigin:t.crossOrigin,referrerPolicy:t.referrerPolicy,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_}},nc=ic;function is(n){return Array.isArray(n)?Math.min(...n):n}var rc=class extends co{constructor(t,e,i,r,s,o,a){let l=t.getExtent();l&&t.canWrapX()&&(l=l.slice(),l[0]=-1/0,l[2]=1/0);let c=e.getExtent();c&&e.canWrapX()&&(c=c.slice(),c[0]=-1/0,c[2]=1/0);let h=c?Ut(i,c):i,u=St(h),d=Vi(t,e,u,r),f=.5,g=new Mo(t,e,h,l,d*f,r),p=g.calculateSourceExtent(),m=Yt(p)?null:o(p,d,s),_=m?b.IDLE:b.EMPTY,y=m?m.getPixelRatio():1;super(i,r,y,_),this.targetProj_=e,this.maxSourceExtent_=l,this.triangulation_=g,this.targetResolution_=r,this.targetExtent_=i,this.sourceImage_=m,this.sourcePixelRatio_=y,this.interpolate_=a,this.canvas_=null,this.sourceListenerKey_=null}disposeInternal(){this.state==b.LOADING&&this.unlistenSource_(),super.disposeInternal()}getImage(){return this.canvas_}getProjection(){return this.targetProj_}reproject_(){let t=this.sourceImage_.getState();if(t==b.LOADED){let e=W(this.targetExtent_)/this.targetResolution_,i=et(this.targetExtent_)/this.targetResolution_;this.canvas_=Io(e,i,this.sourcePixelRatio_,is(this.sourceImage_.getResolution()),this.maxSourceExtent_,this.targetResolution_,this.targetExtent_,this.triangulation_,[{extent:this.sourceImage_.getExtent(),image:this.sourceImage_.getImage()}],0,void 0,this.interpolate_,!0)}this.state=t,this.changed()}load(){if(this.state==b.IDLE){this.state=b.LOADING,this.changed();let t=this.sourceImage_.getState();t==b.LOADED||t==b.ERROR?this.reproject_():(this.sourceListenerKey_=G(this.sourceImage_,L.CHANGE,e=>{let i=this.sourceImage_.getState();(i==b.LOADED||i==b.ERROR)&&(this.unlistenSource_(),this.reproject_())}),this.sourceImage_.load())}}unlistenSource_(){B(this.sourceListenerKey_),this.sourceListenerKey_=null}},rg=rc;var sc={IMAGELOADSTART:"imageloadstart",IMAGELOADEND:"imageloadend",IMAGELOADERROR:"imageloaderror"},oc=class extends mt{constructor(t,e){super(t),this.image=e}},ac=class extends Qn{constructor(t){super({attributions:t.attributions,projection:t.projection,state:t.state,interpolate:t.interpolate!==void 0?t.interpolate:!0}),this.on,this.once,this.un,this.loader=t.loader||null,this.resolutions_=t.resolutions!==void 0?t.resolutions:null,this.reprojectedImage_=null,this.reprojectedRevision_=0,this.image=null,this.wantedExtent_,this.wantedResolution_,this.static_=t.loader?t.loader.length===0:!1,this.wantedProjection_=null}getResolutions(){return this.resolutions_}setResolutions(t){this.resolutions_=t}findNearestResolution(t){let e=this.getResolutions();if(e){let i=Ri(e,t,0);t=e[i]}return t}getImage(t,e,i,r){let s=this.getProjection();if(!s||!r||ve(s,r))return s&&(r=s),this.getImageInternal(t,e,i,r);if(this.reprojectedImage_){if(this.reprojectedRevision_==this.getRevision()&&ve(this.reprojectedImage_.getProjection(),r)&&this.reprojectedImage_.getResolution()==e&&we(this.reprojectedImage_.getExtent(),t))return this.reprojectedImage_;this.reprojectedImage_.dispose(),this.reprojectedImage_=null}return this.reprojectedImage_=new rg(s,r,t,e,i,(o,a,l)=>this.getImageInternal(o,a,l,s),this.getInterpolate()),this.reprojectedRevision_=this.getRevision(),this.reprojectedImage_}getImageInternal(t,e,i,r){if(this.loader){let s=lc(t,e,i,1),o=this.findNearestResolution(e);if(this.image&&(this.static_||this.wantedProjection_===r&&(this.wantedExtent_&&le(this.wantedExtent_,s)||le(this.image.getExtent(),s))&&(this.wantedResolution_&&is(this.wantedResolution_)===o||is(this.image.getResolution())===o)))return this.image;this.wantedProjection_=r,this.wantedExtent_=s,this.wantedResolution_=o,this.image=new co(s,o,i,this.loader),this.image.addEventListener(L.CHANGE,this.handleImageChange.bind(this))}return this.image}handleImageChange(t){let e=t.target,i;switch(e.getState()){case b.LOADING:this.loading=!0,i=sc.IMAGELOADSTART;break;case b.LOADED:this.loading=!1,i=sc.IMAGELOADEND;break;case b.ERROR:this.loading=!1,i=sc.IMAGELOADERROR;break;default:return}this.hasListener(i)&&this.dispatchEvent(new oc(i,e))}};function sg(n,t){n.getImage().src=t}function lc(n,t,e,i){let r=t/e,s=St(n),o=Ue(W(n)/r,4),a=Ue(et(n)/r,4),l=Ue((i-1)*o/2,4),c=o+2*l,h=Ue((i-1)*a/2,4),u=a+2*h;return oi(s,r,0,[c,u])}var og=ac;var ns="1.3.0",ag=[101,101];function lg(n,t,e,i,r){r.WIDTH=e[0],r.HEIGHT=e[1];let s=i.getAxisOrientation(),o=ur(r.VERSION,"1.3")>=0;r[o?"CRS":"SRS"]=i.getCode();let a=o&&s.startsWith("ne")?[t[1],t[0],t[3],t[2]]:t;return r.BBOX=a.join(","),es(n,r)}function hc(n,t,e,i,r,s,o){s=Object.assign({REQUEST:"GetMap"},s);let a=t/e,l=[da(W(n)/a,4),da(et(n)/a,4)];if(e!=1)switch(o){case"geoserver":let h=90*e+.5|0;"FORMAT_OPTIONS"in s?s.FORMAT_OPTIONS+=";dpi:"+h:s.FORMAT_OPTIONS="dpi:"+h;break;case"mapserver":s.MAP_RESOLUTION=90*e;break;case"carmentaserver":case"qgis":s.DPI=90*e;break;default:throw new Error("Unknown `serverType` configured")}return lg(r,n,l,i,s)}function rs(n,t){return Object.assign({REQUEST:t,SERVICE:"WMS",VERSION:ns,FORMAT:"image/png",STYLES:"",TRANSPARENT:"TRUE"},n)}function hg(n){let t=n.hidpi===void 0?!0:n.hidpi,e=q(n.projection||"EPSG:3857"),i=n.ratio||1.5,r=n.load||ho,s=n.crossOrigin??null,o=n.referrerPolicy;return(a,l,c)=>{a=lc(a,l,c,i),c!=1&&(!t||n.serverType===void 0)&&(c=1);let h=hc(a,l,c,e,n.url,rs(n.params,"GetMap"),n.serverType),u=new Image;return u.crossOrigin=s,o!==void 0&&(u.referrerPolicy=o),r(u,h).then(d=>({image:d,extent:a,pixelRatio:c}))}}function cg(n,t,e){if(n.url===void 0)return;let i=q(n.projection||"EPSG:3857"),r=oi(t,e,0,ag),s={QUERY_LAYERS:n.params.LAYERS,INFO_FORMAT:"application/json"};Object.assign(s,rs(n.params,"GetFeatureInfo"),n.params);let o=vi((t[0]-r[0])/e,4),a=vi((r[3]-t[1])/e,4),l=ur(s.VERSION,"1.3")>=0;return s[l?"I":"X"]=o,s[l?"J":"Y"]=a,lg(n.url,r,ag,i,s)}function ug(n,t){if(n.url===void 0)return;let e={SERVICE:"WMS",VERSION:ns,REQUEST:"GetLegendGraphic",FORMAT:"image/png"};if(t!==void 0){let i=q(n.projection||"EPSG:3857").getMetersPerUnit()||1,r=28e-5;e.SCALE=t*i/r}if(Object.assign(e,n.params),n.params!==void 0&&e.LAYER===void 0){let i=e.LAYERS;if(!(!Array.isArray(i)||i.length!==1))return;e.LAYER=i}return es(n.url,e)}var cc=class extends Go{constructor(t){t=t||{};let e=Object.assign({},t.params);super({attributions:t.attributions,attributionsCollapsible:t.attributionsCollapsible,cacheSize:t.cacheSize,crossOrigin:t.crossOrigin,interpolate:t.interpolate,projection:t.projection,reprojectionErrorThreshold:t.reprojectionErrorThreshold,tileClass:t.tileClass,tileGrid:t.tileGrid,tileLoadFunction:t.tileLoadFunction,url:t.url,urls:t.urls,wrapX:t.wrapX!==void 0?t.wrapX:!0,transition:t.transition,zDirection:t.zDirection}),this.gutter_=t.gutter!==void 0?t.gutter:0,this.params_=e,this.v13_=!0,this.serverType_=t.serverType,this.hidpi_=t.hidpi!==void 0?t.hidpi:!0,this.tmpExtent_=ct(),this.updateV13_(),this.setKey(this.getKeyForParams_())}getFeatureInfoUrl(t,e,i,r){let s=q(i),o=this.getProjection()||s,a=this.getTileGrid();a||(a=this.getTileGridForProjection(o));let l=de(t,s,o),c=Vi(o,s,t,e),h=a.getZForResolution(c,this.zDirection),u=a.getResolution(h),d=a.getTileCoordForCoordAndZ(l,h);if(a.getResolutions().length<=d[0])return;let f=a.getTileCoordExtent(d,this.tmpExtent_),g=this.gutter_;g!==0&&(f=ri(f,u*g,f));let p={QUERY_LAYERS:this.params_.LAYERS};Object.assign(p,rs(this.params_,"GetFeatureInfo"),r);let m=Math.floor((l[0]-f[0])/u),_=Math.floor((f[3]-l[1])/u);return p[this.v13_?"I":"X"]=m,p[this.v13_?"J":"Y"]=_,this.getRequestUrl_(d,f,1,o||s,p)}getLegendUrl(t,e){if(this.urls[0]===void 0)return;let i={SERVICE:"WMS",VERSION:ns,REQUEST:"GetLegendGraphic",FORMAT:"image/png"};if(e===void 0||e.LAYER===void 0){let r=this.params_.LAYERS;if(!(!Array.isArray(r)||r.length===1))return;i.LAYER=r}if(t!==void 0){let r=this.getProjection()?this.getProjection().getMetersPerUnit():1,s=28e-5;i.SCALE=t*r/s}return Object.assign(i,e),es(this.urls[0],i)}getGutter(){return this.gutter_}getParams(){return this.params_}getRequestUrl_(t,e,i,r,s){let o=this.urls;if(!o)return;let a;if(o.length==1)a=o[0];else{let l=Wt(Lo(t),o.length);a=o[l]}return hc(e,(this.tileGrid||this.getTileGridForProjection(r)).getResolution(t[0]),i,r,a,s,this.serverType_)}getTilePixelRatio(t){return!this.hidpi_||this.serverType_===void 0?1:t}getKeyForParams_(){let t=0,e=[];for(let i in this.params_)e[t++]=i+"-"+this.params_[i];return e.join("/")}setParams_(t){this.params_=t,this.updateV13_(),this.setKey(this.getKeyForParams_())}setParams(t){this.setParams_(Object.assign({},t))}updateParams(t){this.setParams_(Object.assign(this.params_,t))}updateV13_(){let t=this.params_.VERSION||ns;this.v13_=ur(t,"1.3")>=0}tileUrlFunction(t,e,i){let r=this.getTileGrid();if(r||(r=this.getTileGridForProjection(i)),r.getResolutions().length<=t[0])return;e!=1&&(!this.hidpi_||this.serverType_===void 0)&&(e=1);let s=r.getResolution(t[0]),o=r.getTileCoordExtent(t,this.tmpExtent_),a=this.gutter_;a!==0&&(o=ri(o,s*a,o));let l=Object.assign({},rs(this.params_,"GetMap"));return this.getRequestUrl_(t,o,e,i,l)}},dg=cc;var uc=class extends og{constructor(t){t=t||{},super({attributions:t.attributions,interpolate:t.interpolate,projection:t.projection,resolutions:t.resolutions}),this.crossOrigin_=t.crossOrigin!==void 0?t.crossOrigin:null,this.referrerPolicy_=t.referrerPolicy,this.url_=t.url,this.imageLoadFunction_=t.imageLoadFunction!==void 0?t.imageLoadFunction:sg,this.params_=Object.assign({},t.params),this.serverType_=t.serverType,this.hidpi_=t.hidpi!==void 0?t.hidpi:!0,this.renderedRevision_=0,this.ratio_=t.ratio!==void 0?t.ratio:1.5,this.loaderProjection_=null}getFeatureInfoUrl(t,e,i,r){let s=q(i),o=this.getProjection();o&&o!==s&&(e=Vi(o,s,t,e),t=de(t,s,o));let a={url:this.url_,params:{...this.params_,...r},projection:o||s};return cg(a,t,e)}getLegendUrl(t,e){return ug({url:this.url_,params:{...this.params_,...e}},t)}getParams(){return this.params_}getImageInternal(t,e,i,r){return this.url_===void 0?null:((!this.loader||this.loaderProjection_!==r)&&(this.loaderProjection_=r,this.loader=hg({crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_,params:this.params_,projection:r,serverType:this.serverType_,hidpi:this.hidpi_,url:this.url_,ratio:this.ratio_,load:(s,o)=>(this.image.setImage(s),this.imageLoadFunction_(this.image,o),ho(s))})),super.getImageInternal(t,e,i,r))}getImageLoadFunction(){return this.imageLoadFunction_}getUrl(){return this.url_}setImageLoadFunction(t){this.imageLoadFunction_=t,this.changed()}setUrl(t){t!=this.url_&&(this.url_=t,this.loader=null,this.changed())}setParams(t){this.params_=Object.assign({},t),this.loader=null,this.changed()}updateParams(t){Object.assign(this.params_,t),this.changed()}changed(){this.image=null,super.changed()}},fg=uc;var n_=!1;function r_(n,t,e,i,r,s,o){let a=new XMLHttpRequest;a.open("GET",typeof n=="function"?n(e,i,r):n,!0),t.getType()=="arraybuffer"&&(a.responseType="arraybuffer"),a.withCredentials=n_,a.onload=function(l){if(!a.status||a.status>=200&&a.status<300){let c=t.getType();try{let h;c=="text"||c=="json"?h=a.responseText:c=="xml"?h=a.responseXML||a.responseText:c=="arraybuffer"&&(h=a.response),h?s(t.readFeatures(h,{extent:e,featureProjection:r}),t.readProjection(h)):o()}catch{o()}}else o()},a.onerror=o,a.send()}function dc(n,t){return function(e,i,r,s,o){r_(n,t,e,i,r,(a,l)=>{this.addFeatures(a),s!==void 0&&s(a)},()=>{this.changed(),o!==void 0&&o()})}}function gg(n,t){return[[-1/0,-1/0,1/0,1/0]]}var fc=class n extends pt{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"){let e=t;this.setGeometry(e)}else{let e=t;this.setProperties(e)}}clone(){let t=new n(this.hasProperties()?this.getProperties():null);t.setGeometryName(this.getGeometryName());let e=this.getGeometry();e&&t.setGeometry(e.clone());let 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_&&(B(this.geometryChangeKey_),this.geometryChangeKey_=null);let t=this.getGeometry();t&&(this.geometryChangeKey_=G(t,L.CHANGE,this.handleGeometryChange_,this)),this.changed()}setGeometry(t){this.set(this.geometryName_,t)}setStyle(t){this.style_=t,this.styleFunction_=t?s_(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 s_(n){if(typeof n=="function")return n;let t;return Array.isArray(n)?t=n:(V(typeof n.getZIndex=="function","Expected an `ol/style/Style` or an array of `ol/style/Style.js`"),t=[n]),function(){return t}}var zo=fc;function jo(n,t,e,i){let r=[],s=ct();for(let o=0,a=e.length;o<a;++o){let l=e[o];s=En(n,t,l[0],i),r.push((s[0]+s[2])/2,(s[1]+s[3])/2),t=l[l.length-1]}return r}function mn(n,t,e,i,r,s,o){let a,l,c=(e-t)/i;if(c===1)a=t;else if(c===2)a=t,l=r;else if(c!==0){let h=n[t],u=n[t+1],d=0,f=[0];for(let m=t+i;m<e;m+=i){let _=n[m],y=n[m+1];d+=Math.sqrt((_-h)*(_-h)+(y-u)*(y-u)),f.push(d),h=_,u=y}let g=r*d,p=qc(f,g);p<0?(l=(g-f[-p-2])/(f[-p-1]-f[-p-2]),a=t+(-p-2)*i):a=t+p*i}o=o>1?o:2,s=s||new Array(o);for(let h=0;h<o;++h)s[h]=a===void 0?NaN:l===void 0?n[a+h]:bt(n[a+h],n[a+i+h],l);return s}function Wo(n,t,e,i,r,s){if(e==t)return null;let o;if(r<n[t+i-1])return s?(o=n.slice(t,t+i),o[i-1]=r,o):null;if(n[e-1]<r)return s?(o=n.slice(e-i,e),o[i-1]=r,o):null;if(r==n[t+i-1])return n.slice(t,t+i);let a=t/i,l=e/i;for(;a<l;){let d=a+l>>1;r<n[(d+1)*i-1]?l=d:a=d+1}let c=n[a*i-1];if(r==c)return n.slice((a-1)*i,(a-1)*i+i);let h=n[(a+1)*i-1],u=(r-c)/(h-c);o=[];for(let d=0;d<i-1;++d)o.push(bt(n[(a-1)*i+d],n[a*i+d],u));return o.push(r),o}function mg(n,t,e,i,r,s,o){if(o)return Wo(n,t,e[e.length-1],i,r,s);let a;if(r<n[i-1])return s?(a=n.slice(0,i),a[i-1]=r,a):null;if(n[n.length-1]<r)return s?(a=n.slice(n.length-i),a[i-1]=r,a):null;for(let l=0,c=e.length;l<c;++l){let h=e[l];if(t!=h){if(r<n[t+i-1])return null;if(r<=n[h-1])return Wo(n,t,h,i,r,!1);t=h}}return null}var mc=class n extends js{constructor(t){super(),this.geometries_=t,this.changeEventsKeys_=[],this.listenGeometriesChange_()}unlistenGeometriesChange_(){this.changeEventsKeys_.forEach(B),this.changeEventsKeys_.length=0}listenGeometriesChange_(){let t=this.geometries_;for(let e=0,i=t.length;e<i;++e)this.changeEventsKeys_.push(G(t[e],L.CHANGE,this.changed,this))}clone(){let t=new n(gc(this.geometries_));return t.applyProperties(this),t}closestPointXY(t,e,i,r){if(r<Xt(this.getExtent(),t,e))return r;let s=this.geometries_;for(let o=0,a=s.length;o<a;++o)r=s[o].closestPointXY(t,e,i,r);return r}containsXY(t,e){let i=this.geometries_;for(let r=0,s=i.length;r<s;++r)if(i[r].containsXY(t,e))return!0;return!1}computeExtent(t){si(t);let e=this.geometries_;for(let i=0,r=e.length;i<r;++i)vs(t,e[i].getExtent());return t}getGeometries(){return gc(this.geometries_)}getGeometriesArray(){return this.geometries_}getGeometriesArrayRecursive(){let t=[],e=this.geometries_;for(let i=0,r=e.length;i<r;++i)e[i].getType()===this.getType()?t=t.concat(e[i].getGeometriesArrayRecursive()):t.push(e[i]);return t}getSimplifiedGeometry(t){if(this.simplifiedGeometryRevision!==this.getRevision()&&(this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=this.getRevision()),t<0||this.simplifiedGeometryMaxMinSquaredTolerance!==0&&t<this.simplifiedGeometryMaxMinSquaredTolerance)return this;let e=[],i=this.geometries_,r=!1;for(let s=0,o=i.length;s<o;++s){let a=i[s],l=a.getSimplifiedGeometry(t);e.push(l),l!==a&&(r=!0)}return r?new n(e):(this.simplifiedGeometryMaxMinSquaredTolerance=t,this)}getType(){return"GeometryCollection"}intersectsExtent(t){let e=this.geometries_;for(let i=0,r=e.length;i<r;++i)if(e[i].intersectsExtent(t))return!0;return!1}isEmpty(){return this.geometries_.length===0}rotate(t,e){let i=this.geometries_;for(let r=0,s=i.length;r<s;++r)i[r].rotate(t,e);this.changed()}scale(t,e,i){i||(i=St(this.getExtent()));let r=this.geometries_;for(let s=0,o=r.length;s<o;++s)r[s].scale(t,e,i);this.changed()}setGeometries(t){this.setGeometriesArray(gc(t))}setGeometriesArray(t){this.unlistenGeometriesChange_(),this.geometries_=t,this.listenGeometriesChange_(),this.changed()}applyTransform(t){let e=this.geometries_;for(let i=0,r=e.length;i<r;++i)e[i].applyTransform(t);this.changed()}translate(t,e){let i=this.geometries_;for(let r=0,s=i.length;r<s;++r)i[r].translate(t,e);this.changed()}disposeInternal(){this.unlistenGeometriesChange_(),super.disposeInternal()}};function gc(n){return n.map(t=>t.clone())}var pc=mc;var _c=class n extends Vt{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){It(this.flatCoordinates,t),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(mr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),_r(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!1,t,e,i,r))}forEachSegment(t){return Ys(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,Wo(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e))}getCoordinates(){return fe(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinateAt(t,e){return mn(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,this.stride)}getLength(){return qn(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){let e=[];return e.length=sn(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new n(e,"XY")}getType(){return"LineString"}intersectsExtent(t){return wr(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=rn(this.flatCoordinates,0,t,this.stride),this.changed()}},tr=_c;var yc=class n extends Vt{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{let r=t,s=[],o=[];for(let l=0,c=r.length;l<c;++l){let h=r[l];It(s,h.getFlatCoordinates()),o.push(s.length)}let a=r.length===0?this.getLayout():r[0].getLayout();this.setFlatCoordinates(a,s),this.ends_=o}}appendLineString(t){It(this.flatCoordinates,t.getFlatCoordinates().slice()),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(pr(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),yr(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!1,t,e,i,r))}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,mg(this.flatCoordinates,0,this.ends_,this.stride,t,e,i))}getCoordinates(){return Ai(this.flatCoordinates,0,this.ends_,this.stride)}getEnds(){return this.ends_}getLineString(t){return t<0||this.ends_.length<=t?null:new tr(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLineStrings(){let t=this.flatCoordinates,e=this.ends_,i=this.layout,r=[],s=0;for(let o=0,a=e.length;o<a;++o){let l=e[o],c=new tr(t.slice(s,l),i);r.push(c),s=l}return r}getLength(){let t=this.ends_,e=0,i=0;for(let r=0,s=t.length;r<s;++r)i+=qn(this.flatCoordinates,e,t[r],this.stride),e=t[r];return i}getFlatMidpoints(){let t=[],e=this.flatCoordinates,i=0,r=this.ends_,s=this.stride;for(let o=0,a=r.length;o<a;++o){let l=r[o],c=mn(e,i,l,s,.5);It(t,c),i=l}return t}getSimplifiedGeometryInternal(t){let e=[],i=[];return e.length=Xs(this.flatCoordinates,0,this.ends_,this.stride,t,e,0,i),new n(e,"XY",i)}getType(){return"MultiLineString"}intersectsExtent(t){return sd(this.flatCoordinates,0,this.ends_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,2),this.flatCoordinates||(this.flatCoordinates=[]);let i=Li(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}},xc=yc;var Ec=class n extends Vt{constructor(t,e){super(),e&&!Array.isArray(t[0])?this.setFlatCoordinates(e,t):this.setCoordinates(t,e)}appendPoint(t){It(this.flatCoordinates,t.getFlatCoordinates()),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,r){if(r<Xt(this.getExtent(),t,e))return r;let s=this.flatCoordinates,o=this.stride;for(let a=0,l=s.length;a<l;a+=o){let c=Ce(t,e,s[a],s[a+1]);if(c<r){r=c;for(let h=0;h<o;++h)i[h]=s[a+h];i.length=o}}return r}getCoordinates(){return fe(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getPoint(t){let e=this.flatCoordinates.length/this.stride;return t<0||e<=t?null:new Oi(this.flatCoordinates.slice(t*this.stride,(t+1)*this.stride),this.layout)}getPoints(){let t=this.flatCoordinates,e=this.layout,i=this.stride,r=[];for(let s=0,o=t.length;s<o;s+=i){let a=new Oi(t.slice(s,s+i),e);r.push(a)}return r}getType(){return"MultiPoint"}intersectsExtent(t){let e=this.flatCoordinates,i=this.stride;for(let r=0,s=e.length;r<s;r+=i){let o=e[r],a=e[r+1];if(hr(t,o,a))return!0}return!1}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=rn(this.flatCoordinates,0,t,this.stride),this.changed()}},ss=Ec;var Cc=class n extends Vt{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])){let r=t,s=[],o=[];for(let a=0,l=r.length;a<l;++a){let c=r[a],h=s.length,u=c.getEnds();for(let d=0,f=u.length;d<f;++d)u[d]+=h;It(s,c.getFlatCoordinates()),o.push(u)}e=r.length===0?this.getLayout():r[0].getLayout(),t=s,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{let i=this.flatCoordinates.length;It(this.flatCoordinates,t.getFlatCoordinates()),e=t.getEnds().slice();for(let r=0,s=e.length;r<s;++r)e[r]+=i}this.endss_.push(e),this.changed()}clone(){let t=this.endss_.length,e=new Array(t);for(let r=0;r<t;++r)e[r]=this.endss_[r].slice();let i=new n(this.flatCoordinates.slice(),this.layout,e);return i.applyProperties(this),i}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(Qu(this.flatCoordinates,0,this.endss_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),td(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,this.maxDelta_,!0,t,e,i,r))}containsXY(t,e){return rd(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t,e)}getArea(){return $u(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),Tr(e,0,this.endss_,this.stride,t)):e=this.flatCoordinates,xr(e,0,this.endss_,this.stride)}getEndss(){return this.endss_}getFlatInteriorPoints(){if(this.flatInteriorPointsRevision_!=this.getRevision()){let t=jo(this.flatCoordinates,0,this.endss_,this.stride);this.flatInteriorPoints_=Us(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t),this.flatInteriorPointsRevision_=this.getRevision()}return this.flatInteriorPoints_}getInteriorPoints(){return new ss(this.getFlatInteriorPoints().slice(),"XYM")}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){let t=this.flatCoordinates;Ks(t,0,this.endss_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=Tr(this.orientedFlatCoordinates_,0,this.endss_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){let e=[],i=[];return e.length=id(this.flatCoordinates,0,this.endss_,this.stride,Math.sqrt(t),e,0,i),new n(e,"XY",i)}getPolygon(t){if(t<0||this.endss_.length<=t)return null;let e;if(t===0)e=0;else{let s=this.endss_[t-1];e=s[s.length-1]}let i=this.endss_[t].slice(),r=i[i.length-1];if(e!==0)for(let s=0,o=i.length;s<o;++s)i[s]-=e;return new Di(this.flatCoordinates.slice(e,r),this.layout,i)}getPolygons(){let t=this.layout,e=this.flatCoordinates,i=this.endss_,r=[],s=0;for(let o=0,a=i.length;o<a;++o){let l=i[o].slice(),c=l[l.length-1];if(s!==0)for(let u=0,d=l.length;u<d;++u)l[u]-=s;let h=new Di(e.slice(s,c),t,l);r.push(h),s=c}return r}getType(){return"MultiPolygon"}intersectsExtent(t){return od(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,3),this.flatCoordinates||(this.flatCoordinates=[]);let i=Ws(this.flatCoordinates,0,t,this.stride,this.endss_);if(i.length===0)this.flatCoordinates.length=0;else{let r=i[i.length-1];this.flatCoordinates.length=r.length===0?0:r[r.length-1]}this.changed()}},Rc=Cc;var pg=Tt(),os=class n{constructor(t,e,i,r,s,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_=s,this.squaredTolerance_,this.stride_=r,this.simplifiedGeometry_}get(t){return this.properties_[t]}getExtent(){return this.extent_||(this.extent_=this.type_==="Point"?Ts(this.flatCoordinates_):En(this.flatCoordinates_,0,this.flatCoordinates_.length,2)),this.extent_}getFlatInteriorPoint(){if(!this.flatInteriorPoints_){let t=St(this.getExtent());this.flatInteriorPoints_=Rr(this.flatCoordinates_,0,this.ends_,2,t,0)}return this.flatInteriorPoints_}getFlatInteriorPoints(){if(!this.flatInteriorPoints_){let t=ld(this.flatCoordinates_,this.ends_),e=jo(this.flatCoordinates_,0,t,2);this.flatInteriorPoints_=Us(this.flatCoordinates_,0,t,2,e)}return this.flatInteriorPoints_}getFlatMidpoint(){return this.flatMidpoints_||(this.flatMidpoints_=mn(this.flatCoordinates_,0,this.flatCoordinates_.length,2,.5)),this.flatMidpoints_}getFlatMidpoints(){if(!this.flatMidpoints_){this.flatMidpoints_=[];let t=this.flatCoordinates_,e=0,i=this.ends_;for(let r=0,s=i.length;r<s;++r){let o=i[r],a=mn(t,e,o,2,.5);It(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=q(t);let e=t.getExtent(),i=t.getWorldExtent();if(e&&i){let r=et(i)/et(e);Et(pg,i[0],i[3],r,-r,0,0,0),Kt(this.flatCoordinates_,0,this.flatCoordinates_.length,2,pg,this.flatCoordinates_)}}applyTransform(t){t(this.flatCoordinates_,this.flatCoordinates_,this.stride_)}clone(){return new n(this.type_,this.flatCoordinates_.slice(),this.ends_?.slice(),this.stride_,Object.assign({},this.properties_),this.id_)}getEnds(){return this.ends_}enableSimplifyTransformed(){return this.simplifyTransformed=ms((t,e)=>{if(t===this.squaredTolerance_)return this.simplifiedGeometry_;this.simplifiedGeometry_=this.clone(),e&&this.simplifiedGeometry_.applyTransform(e);let i=this.simplifiedGeometry_.getFlatCoordinates(),r;switch(this.type_){case"LineString":i.length=sn(i,0,this.simplifiedGeometry_.flatCoordinates_.length,this.simplifiedGeometry_.stride_,t,i,0),r=[i.length];break;case"MultiLineString":r=[],i.length=Xs(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,t,i,0,r);break;case"Polygon":r=[],i.length=Er(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,Math.sqrt(t),i,0,r);break;default:}return r&&(this.simplifiedGeometry_=new n(this.type_,i,r,2,this.properties_,this.id_)),this.squaredTolerance_=t,this.simplifiedGeometry_}),this}};os.prototype.getFlatCoordinates=os.prototype.getOrientedFlatCoordinates;var Fe=os;var wc=class{constructor(t){this.rbush_=new ln(t),this.items_={}}insert(t,e){let i={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3],value:e};this.rbush_.insert(i),this.items_[U(e)]=i}load(t,e){let i=new Array(e.length);for(let r=0,s=e.length;r<s;r++){let o=t[r],a=e[r],l={minX:o[0],minY:o[1],maxX:o[2],maxY:o[3],value:a};i[r]=l,this.items_[U(a)]=l}this.rbush_.load(i)}remove(t){let e=U(t),i=this.items_[e];return delete this.items_[e],this.rbush_.remove(i)!==null}update(t,e){let i=this.items_[U(e)],r=[i.minX,i.minY,i.maxX,i.maxY];we(r,t)||(this.remove(e),this.insert(t,e))}getAll(){return this.rbush_.all().map(function(e){return e.value})}getInExtent(t){let e={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3]};return this.rbush_.search(e).map(function(r){return r.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 r=0,s=t.length;r<s;r++)if(i=e(t[r]),i)return i;return i}isEmpty(){return $t(this.items_)}clear(){this.rbush_.clear(),this.items_={}}getExtent(t){let e=this.rbush_.toJSON();return Qt(e.minX,e.minY,e.maxX,e.maxY,t)}concat(t){this.rbush_.load(t.rbush_.all());for(let e in t.items_)this.items_[e]=t.items_[e]}},Sc=wc;var ee={ADDFEATURE:"addfeature",CHANGEFEATURE:"changefeature",CLEAR:"clear",REMOVEFEATURE:"removefeature",FEATURESLOADSTART:"featuresloadstart",FEATURESLOADEND:"featuresloadend",FEATURESLOADERROR:"featuresloaderror"};var $e=class extends mt{constructor(t,e,i){super(t),this.feature=e,this.features=i}},Tc=class extends Qn{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_=ni,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&&(V(this.format_,"`format` must be set when `url` is set"),this.loader_=dc(this.url_,this.format_)),this.strategy_=t.strategy!==void 0?t.strategy:gg;let e=t.useSpatialIndex!==void 0?t.useSpatialIndex:!0;this.featuresRtree_=e?new Sc:null,this.loadedExtentsRtree_=new Sc,this.loadingExtentsCount_=0,this.nullGeometryFeatures_={},this.idIndex_={},this.uidIndex_={},this.featureChangeKeys_={},this.featuresCollection_=null;let i,r;Array.isArray(t.features)?r=t.features:t.features&&(i=t.features,r=i.getArray()),!e&&i===void 0&&(i=new Mt(r)),r!==void 0&&this.addFeaturesInternal(r),i!==void 0&&this.bindFeaturesCollection_(i)}addFeature(t){this.addFeatureInternal(t),this.changed()}addFeatureInternal(t){let e=U(t);if(!this.addToIndex_(e,t)){this.featuresCollection_&&this.featuresCollection_.remove(t);return}this.setupChangeEvents_(e,t);let i=t.getGeometry();if(i){let r=i.getExtent();this.featuresRtree_&&this.featuresRtree_.insert(r,t)}else this.nullGeometryFeatures_[e]=t;this.dispatchEvent(new $e(ee.ADDFEATURE,t))}setupChangeEvents_(t,e){e instanceof Fe||(this.featureChangeKeys_[t]=[G(e,L.CHANGE,this.handleFeatureChange_,this),G(e,Ee.PROPERTYCHANGE,this.handleFeatureChange_,this)])}addToIndex_(t,e){let i=!0;if(e.getId()!==void 0){let r=String(e.getId());if(!(r in this.idIndex_))this.idIndex_[r]=e;else if(e instanceof Fe){let s=this.idIndex_[r];s instanceof Fe?Array.isArray(s)?s.push(e):this.idIndex_[r]=[s,e]:i=!1}else i=!1}return i&&(V(!(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){let e=[],i=[],r=[];for(let s=0,o=t.length;s<o;s++){let a=t[s],l=U(a);this.addToIndex_(l,a)&&i.push(a)}for(let s=0,o=i.length;s<o;s++){let a=i[s],l=U(a);this.setupChangeEvents_(l,a);let c=a.getGeometry();if(c){let h=c.getExtent();e.push(h),r.push(a)}else this.nullGeometryFeatures_[l]=a}if(this.featuresRtree_&&this.featuresRtree_.load(e,r),this.hasListener(ee.ADDFEATURE))for(let s=0,o=i.length;s<o;s++)this.dispatchEvent(new $e(ee.ADDFEATURE,i[s]))}bindFeaturesCollection_(t){let e=!1;this.addEventListener(ee.ADDFEATURE,function(i){e||(e=!0,t.push(i.feature),e=!1)}),this.addEventListener(ee.REMOVEFEATURE,function(i){e||(e=!0,t.remove(i.feature),e=!1)}),t.addEventListener(wt.ADD,i=>{e||(e=!0,this.addFeature(i.element),e=!1)}),t.addEventListener(wt.REMOVE,i=>{e||(e=!0,this.removeFeature(i.element),e=!1)}),this.featuresCollection_=t}clear(t){if(t){for(let i in this.featureChangeKeys_)this.featureChangeKeys_[i].forEach(B);this.featuresCollection_||(this.featureChangeKeys_={},this.idIndex_={},this.uidIndex_={})}else if(this.featuresRtree_){this.featuresRtree_.forEach(i=>{this.removeFeatureInternal(i)});for(let i in this.nullGeometryFeatures_)this.removeFeatureInternal(this.nullGeometryFeatures_[i])}this.featuresCollection_&&this.featuresCollection_.clear(),this.featuresRtree_&&this.featuresRtree_.clear(),this.nullGeometryFeatures_={};let e=new $e(ee.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){let i=[t[0],t[1],t[0],t[1]];return this.forEachFeatureInExtent(i,function(r){let s=r.getGeometry();if(s instanceof Fe||s.intersectsCoordinate(t))return e(r)})}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){let r=i.getGeometry();if(r instanceof Fe||r.intersectsExtent(t)){let s=e(i);if(s)return s}})}getFeaturesCollection(){return this.featuresCollection_}getFeatures(){let t;return this.featuresCollection_?t=this.featuresCollection_.getArray().slice(0):this.featuresRtree_&&(t=this.featuresRtree_.getAll(),$t(this.nullGeometryFeatures_)||It(t,Object.values(this.nullGeometryFeatures_))),t}getFeaturesAtCoordinate(t){let 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);let r=Ms(t,e);return[].concat(...r.map(s=>this.featuresRtree_.getInExtent(s)))}return this.featuresCollection_?this.featuresCollection_.getArray().slice(0):[]}getClosestFeatureToCoordinate(t,e){let i=t[0],r=t[1],s=null,o=[NaN,NaN],a=1/0,l=[-1/0,-1/0,1/0,1/0];return e=e||ei,this.featuresRtree_.forEachInExtent(l,function(c){if(e(c)){let h=c.getGeometry(),u=a;if(a=h instanceof Fe?0:h.closestPointXY(i,r,o,a),a<u){s=c;let d=Math.sqrt(a);l[0]=i-d,l[1]=r-d,l[2]=i+d,l[3]=r+d}}}),s}getExtent(t){return this.featuresRtree_?.getExtent(t)??null}getFeatureById(t){let e=this.idIndex_[t.toString()];return e!==void 0?e:null}getFeatureByUid(t){let e=this.uidIndex_[t];return e!==void 0?e:null}getFormat(){return this.format_}getOverlaps(){return this.overlaps_}getUrl(){return this.url_}handleFeatureChange_(t){let e=t.target,i=U(e),r=e.getGeometry();if(!r)i in this.nullGeometryFeatures_||(this.featuresRtree_&&this.featuresRtree_.remove(e),this.nullGeometryFeatures_[i]=e);else{let o=r.getExtent();i in this.nullGeometryFeatures_?(delete this.nullGeometryFeatures_[i],this.featuresRtree_&&this.featuresRtree_.insert(o,e)):this.featuresRtree_&&this.featuresRtree_.update(o,e)}let s=e.getId();if(s!==void 0){let o=s.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 $e(ee.CHANGEFEATURE,e))}hasFeature(t){let e=t.getId();return e!==void 0?e in this.idIndex_:U(t)in this.uidIndex_}isEmpty(){return this.featuresRtree_?this.featuresRtree_.isEmpty()&&$t(this.nullGeometryFeatures_):this.featuresCollection_?this.featuresCollection_.getLength()===0:!0}loadFeatures(t,e,i){let r=this.loadedExtentsRtree_,s=this.strategy_(t,e,i);for(let o=0,a=s.length;o<a;++o){let l=s[o];r.forEachInExtent(l,function(h){return le(h.extent,l)})||(++this.loadingExtentsCount_,this.dispatchEvent(new $e(ee.FEATURESLOADSTART)),this.loader_.call(this,l,e,i,h=>{--this.loadingExtentsCount_,this.dispatchEvent(new $e(ee.FEATURESLOADEND,void 0,h))},()=>{--this.loadingExtentsCount_,this.dispatchEvent(new $e(ee.FEATURESLOADERROR))}),r.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){let e=this.loadedExtentsRtree_,i=e.forEachInExtent(t,function(r){if(we(r.extent,t))return r});i&&e.remove(i)}removeFeatures(t){let e=!1;for(let i=0,r=t.length;i<r;++i)e=this.removeFeatureInternal(t[i])||e;e&&this.changed()}removeFeature(t){if(!t)return;this.removeFeatureInternal(t)&&this.changed()}removeFeatureInternal(t){let e=U(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(B),delete this.featureChangeKeys_[e];let r=t.getId();if(r!==void 0){let s=r.toString(),o=this.idIndex_[s];o===t?delete this.idIndex_[s]:Array.isArray(o)&&(o.splice(o.indexOf(t),1),o.length===1&&(this.idIndex_[s]=o[0]))}return delete this.uidIndex_[e],this.hasListener(ee.REMOVEFEATURE)&&this.dispatchEvent(new $e(ee.REMOVEFEATURE,t)),!0}removeFromIdIndex_(t){for(let e in this.idIndex_)if(this.idIndex_[e]===t){delete this.idIndex_[e];break}}setLoader(t){this.loader_=t}setUrl(t){V(this.format_,"`format` must be set when `url` is set"),this.url_=t,this.setLoader(dc(t,this.format_))}setOverlaps(t){this.overlaps_=t,this.changed()}},vc=Tc;var Ic=class{constructor(){this.dataProjection=void 0,this.defaultFeatureProjection=void 0,this.featureClass=zo,this.supportedMediaTypes=null}getReadOptions(t,e){if(e){let i=e.dataProjection?q(e.dataProjection):this.readProjection(t);e.extent&&i&&i.getUnits()==="tile-pixels"&&(i=q(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 F()}readFeature(t,e){return F()}readFeatures(t,e){return F()}readGeometry(t,e){return F()}readProjection(t){return F()}writeFeature(t,e){return F()}writeFeatures(t,e){return F()}writeGeometry(t,e){return F()}},_g=Ic;function Xo(n,t,e){let i=e?q(e.featureProjection):null,r=e?q(e.dataProjection):null,s=n;if(i&&r&&!ve(i,r)){t&&(s=n.clone());let o=t?i:r,a=t?r:i;o.getUnits()==="tile-pixels"?s.transform(o,a):s.applyTransform(li(o,a))}if(t&&e&&e.decimals!==void 0){let o=Math.pow(10,e.decimals),a=function(l){for(let c=0,h=l.length;c<h;++c)l[c]=Math.round(l[c]*o)/o;return l};s===n&&(s=n.clone()),s.applyTransform(a)}return s}var o_={Point:Oi,LineString:tr,Polygon:Di,MultiPoint:ss,MultiLineString:xc,MultiPolygon:Rc};function a_(n,t,e){return Array.isArray(t[0])?(Ks(n,0,t,e)||(n=n.slice(),Tr(n,0,t,e)),n):(Sr(n,0,t,e)||(n=n.slice(),Pn(n,0,t,e)),n)}function Mc(n,t){let e=n.geometry;if(!e)return[];if(Array.isArray(e))return e.map(s=>Mc({...n,geometry:s})).flat();let i=e.type==="MultiPolygon"?"Polygon":e.type;if(i==="GeometryCollection"||i==="Circle")throw new Error("Unsupported geometry type: "+i);let r=e.layout.length;return Xo(new Fe(i,i==="Polygon"?a_(e.flatCoordinates,e.ends,r):e.flatCoordinates,e.ends?.flat(),r,n.properties||{},n.id).enableSimplifyTransformed(),!1,t)}function Uo(n,t){if(!n)return null;if(Array.isArray(n)){let i=n.map(r=>Uo(r,t));return new pc(i)}let e=o_[n.type];return Xo(new e(n.flatCoordinates,n.layout||"XY",n.ends),!1,t)}var bc=class extends _g{constructor(){super()}getType(){return"json"}readFeature(t,e){return this.readFeatureFromObject(Yo(t),this.getReadOptions(t,e))}readFeatures(t,e){return this.readFeaturesFromObject(Yo(t),this.getReadOptions(t,e))}readFeatureFromObject(t,e){return F()}readFeaturesFromObject(t,e){return F()}readGeometry(t,e){return this.readGeometryFromObject(Yo(t),this.getReadOptions(t,e))}readGeometryFromObject(t,e){return F()}readProjection(t){return this.readProjectionFromObject(Yo(t))}readProjectionFromObject(t){return F()}writeFeature(t,e){return JSON.stringify(this.writeFeatureObject(t,e))}writeFeatureObject(t,e){return F()}writeFeatures(t,e){return JSON.stringify(this.writeFeaturesObject(t,e))}writeFeaturesObject(t,e){return F()}writeGeometry(t,e){return JSON.stringify(this.writeGeometryObject(t,e))}writeGeometryObject(t,e){return F()}};function Yo(n){if(typeof n=="string"){let t=JSON.parse(n);return t||null}return n!==null?n:null}var yg=bc;var Lc=class extends yg{constructor(t){t=t||{},super(),this.dataProjection=q(t.dataProjection?t.dataProjection:"EPSG:4326"),t.featureProjection&&(this.defaultFeatureProjection=q(t.featureProjection)),t.featureClass&&(this.featureClass=t.featureClass),this.geometryName_=t.geometryName,this.extractGeometryName_=t.extractGeometryName,this.supportedMediaTypes=["application/geo+json","application/vnd.geo+json"]}readFeatureFromObject(t,e){let i=null;t.type==="Feature"?i=t:i={type:"Feature",geometry:t,properties:null};let r=Pc(i.geometry,e);if(this.featureClass===Fe)return Mc({geometry:r,id:i.id,properties:i.properties},e);let s=new zo;return this.geometryName_?s.setGeometryName(this.geometryName_):this.extractGeometryName_&&i.geometry_name&&s.setGeometryName(i.geometry_name),s.setGeometry(Uo(r,e)),"id"in i&&s.setId(i.id),i.properties&&s.setProperties(i.properties,!0),s}readFeaturesFromObject(t,e){let i=t,r=null;if(i.type==="FeatureCollection"){let s=t;r=[];let o=s.features;for(let a=0,l=o.length;a<l;++a){let c=this.readFeatureFromObject(o[a],e);c&&r.push(c)}}else r=[this.readFeatureFromObject(t,e)];return r.flat()}readGeometryFromObject(t,e){return l_(t,e)}readProjectionFromObject(t){let e=t.crs,i;if(e)if(e.type=="name")i=q(e.properties.name);else if(e.type==="EPSG")i=q("EPSG:"+e.properties.code);else throw new Error("Unknown SRS type");else i=this.dataProjection;return i}writeFeatureObject(t,e){e=this.adaptOptions(e);let i={type:"Feature",geometry:null,properties:null},r=t.getId();if(r!==void 0&&(i.id=r),!t.hasProperties())return i;let s=t.getProperties(),o=t.getGeometry();return o&&(i.geometry=Ac(o,e),delete s[t.getGeometryName()]),$t(s)||(i.properties=s),i}writeFeaturesObject(t,e){e=this.adaptOptions(e);let i=[];for(let r=0,s=t.length;r<s;++r)i.push(this.writeFeatureObject(t[r],e));return{type:"FeatureCollection",features:i}}writeGeometryObject(t,e){return Ac(t,this.adaptOptions(e))}};function Pc(n,t){if(!n)return null;let e;switch(n.type){case"Point":{e=c_(n);break}case"LineString":{e=u_(n);break}case"Polygon":{e=m_(n);break}case"MultiPoint":{e=f_(n);break}case"MultiLineString":{e=d_(n);break}case"MultiPolygon":{e=g_(n);break}case"GeometryCollection":{e=h_(n);break}default:throw new Error("Unsupported GeoJSON type: "+n.type)}return e}function l_(n,t){let e=Pc(n,t);return Uo(e,t)}function h_(n,t){return n.geometries.map(function(i){return Pc(i,t)})}function c_(n){let t=n.coordinates;return{type:"Point",flatCoordinates:t,layout:bi(t.length)}}function u_(n){let t=n.coordinates,e=t.flat();return{type:"LineString",flatCoordinates:e,ends:[e.length],layout:bi(t[0]?.length||2)}}function d_(n){let t=n.coordinates,e=t[0]?.[0]?.length||2,i=[],r=Li(i,0,t,e);return{type:"MultiLineString",flatCoordinates:i,ends:r,layout:bi(e)}}function f_(n){let t=n.coordinates;return{type:"MultiPoint",flatCoordinates:t.flat(),layout:bi(t[0]?.length||2)}}function g_(n){let t=n.coordinates,e=[],i=t[0]?.[0]?.[0].length||2,r=Ws(e,0,t,i);return{type:"MultiPolygon",flatCoordinates:e,ends:r,layout:bi(i)}}function m_(n){let t=n.coordinates,e=[],i=t[0]?.[0]?.length,r=Li(e,0,t,i);return{type:"Polygon",flatCoordinates:e,ends:r,layout:bi(i)}}function Ac(n,t){n=Xo(n,!0,t);let e=n.getType(),i;switch(e){case"Point":{i=C_(n,t);break}case"LineString":{i=__(n,t);break}case"Polygon":{i=R_(n,t);break}case"MultiPoint":{i=x_(n,t);break}case"MultiLineString":{i=y_(n,t);break}case"MultiPolygon":{i=E_(n,t);break}case"GeometryCollection":{i=p_(n,t);break}case"Circle":{i={type:"GeometryCollection",geometries:[]};break}default:throw new Error("Unsupported geometry type: "+e)}return i}function p_(n,t){return t=Object.assign({},t),delete t.featureProjection,{type:"GeometryCollection",geometries:n.getGeometriesArray().map(function(i){return Ac(i,t)})}}function __(n,t){return{type:"LineString",coordinates:n.getCoordinates()}}function y_(n,t){return{type:"MultiLineString",coordinates:n.getCoordinates()}}function x_(n,t){return{type:"MultiPoint",coordinates:n.getCoordinates()}}function E_(n,t){let e;return t&&(e=t.rightHanded),{type:"MultiPolygon",coordinates:n.getCoordinates(e)}}function C_(n,t){return{type:"Point",coordinates:n.getCoordinates()}}function R_(n,t){let e;return t&&(e=t.rightHanded),{type:"Polygon",coordinates:n.getCoordinates(e)}}var Oc=Lc;var xg=["fullscreenchange","webkitfullscreenchange"],Eg={ENTERFULLSCREEN:"enterfullscreen",LEAVEFULLSCREEN:"leavefullscreen"},Fc=class extends me{constructor(t){t=t||{},super({element:document.createElement("div"),target:t.target}),this.on,this.once,this.un,this.keys_=t.keys!==void 0?t.keys:!1,this.source_=t.source,this.isInFullscreen_=!1,this.boundHandleMapTargetChange_=this.handleMapTargetChange_.bind(this),this.cssClassName_=t.className!==void 0?t.className:"ol-full-screen",this.documentListeners_=[],this.activeClassName_=t.activeClassName!==void 0?t.activeClassName.split(" "):[this.cssClassName_+"-true"],this.inactiveClassName_=t.inactiveClassName!==void 0?t.inactiveClassName.split(" "):[this.cssClassName_+"-false"];let e=t.label!==void 0?t.label:"\u2922";this.labelNode_=typeof e=="string"?document.createTextNode(e):e;let i=t.labelActive!==void 0?t.labelActive:"\xD7";this.labelActiveNode_=typeof i=="string"?document.createTextNode(i):i;let r=t.tipLabel?t.tipLabel:"Toggle full-screen";this.button_=document.createElement("button"),this.button_.title=r,this.button_.setAttribute("type","button"),this.button_.appendChild(this.labelNode_),this.button_.addEventListener(L.CLICK,this.handleClick_.bind(this),!1),this.setClassName_(this.button_,this.isInFullscreen_),this.element.className=`${this.cssClassName_} ${ge} ${ki}`,this.element.appendChild(this.button_)}handleClick_(t){t.preventDefault(),this.handleFullScreen_()}handleFullScreen_(){let t=this.getMap();if(!t)return;let e=t.getOwnerDocument();if(Cg(e))if(Rg(e))S_(e);else{let i;this.source_?i=typeof this.source_=="string"?e.getElementById(this.source_):this.source_:i=t.getTargetElement(),this.keys_?w_(i):wg(i)}}handleFullScreenChange_(){let t=this.getMap();if(!t)return;let e=this.isInFullscreen_;this.isInFullscreen_=Rg(t.getOwnerDocument()),e!==this.isInFullscreen_&&(this.setClassName_(this.button_,this.isInFullscreen_),this.isInFullscreen_?(Dn(this.labelActiveNode_,this.labelNode_),this.dispatchEvent(Eg.ENTERFULLSCREEN)):(Dn(this.labelNode_,this.labelActiveNode_),this.dispatchEvent(Eg.LEAVEFULLSCREEN)),t.updateSize())}setClassName_(t,e){e?(t.classList.remove(...this.inactiveClassName_),t.classList.add(...this.activeClassName_)):(t.classList.remove(...this.activeClassName_),t.classList.add(...this.inactiveClassName_))}setMap(t){let e=this.getMap();e&&e.removeChangeListener(_t.TARGET,this.boundHandleMapTargetChange_),super.setMap(t),this.handleMapTargetChange_(),t&&t.addChangeListener(_t.TARGET,this.boundHandleMapTargetChange_)}handleMapTargetChange_(){let t=this.documentListeners_;for(let i=0,r=t.length;i<r;++i)B(t[i]);t.length=0;let e=this.getMap();if(e){let i=e.getOwnerDocument();Cg(i)?this.element.classList.remove(Ha):this.element.classList.add(Ha);for(let r=0,s=xg.length;r<s;++r)t.push(G(i,xg[r],this.handleFullScreenChange_,this));this.handleFullScreenChange_()}}};function Cg(n){let t=n.body;return!!(t.webkitRequestFullscreen||t.requestFullscreen&&n.fullscreenEnabled)}function Rg(n){return!!(n.webkitIsFullScreen||n.fullscreenElement)}function wg(n){n.requestFullscreen?n.requestFullscreen():n.webkitRequestFullscreen&&n.webkitRequestFullscreen()}function w_(n){n.webkitRequestFullscreen?n.webkitRequestFullscreen():wg(n)}function S_(n){n.exitFullscreen?n.exitFullscreen():n.webkitExitFullscreen&&n.webkitExitFullscreen()}var Dc=Fc;var kc="projection",Sg="coordinateFormat",Nc=class extends me{constructor(t){t=t||{};let e=document.createElement("div");e.className=t.className!==void 0?t.className:"ol-mouse-position",super({element:e,render:t.render,target:t.target}),this.on,this.once,this.un,this.addChangeListener(kc,this.handleProjectionChanged_),t.coordinateFormat&&this.setCoordinateFormat(t.coordinateFormat),t.projection&&this.setProjection(t.projection),this.renderOnMouseOut_=t.placeholder!==void 0,this.placeholder_=this.renderOnMouseOut_?t.placeholder:" ",this.renderedHTML_=e.innerHTML,this.mapProjection_=null,this.transform_=null,this.wrapX_=t.wrapX!==!1}handleProjectionChanged_(){this.transform_=null}getCoordinateFormat(){return this.get(Sg)}getProjection(){return this.get(kc)}handleMouseMove(t){let e=this.getMap();this.updateHTML_(e.getEventPixel(t))}handleMouseOut(t){this.updateHTML_(null)}setMap(t){if(super.setMap(t),t){let e=t.getViewport();this.listenerKeys.push(G(e,Si.POINTERMOVE,this.handleMouseMove,this)),this.renderOnMouseOut_&&this.listenerKeys.push(G(e,Si.POINTEROUT,this.handleMouseOut,this)),this.updateHTML_(null)}}setCoordinateFormat(t){this.set(Sg,t)}setProjection(t){this.set(kc,q(t))}updateHTML_(t){let e=this.placeholder_;if(t&&this.mapProjection_){if(!this.transform_){let s=this.getProjection();s?this.transform_=Ye(this.mapProjection_,s):this.transform_=zu}let r=this.getMap().getCoordinateFromPixelInternal(t);if(r){let s=hi();if(s&&(this.transform_=Ye(this.mapProjection_,s)),this.transform_(r,r),this.wrapX_){let a=s||this.getProjection()||this.mapProjection_;Tn(r,a)}let o=this.getCoordinateFormat();o?e=o(r):e=r.toString()}}(!this.renderedHTML_||e!==this.renderedHTML_)&&(this.element.innerHTML=e,this.renderedHTML_=e)}render(t){let e=t.frameState;e?this.mapProjection_!=e.viewState.projection&&(this.mapProjection_=e.viewState.projection,this.transform_=null):this.mapProjection_=null}},Gc=Nc;var zc="units",T_=[1,2,5],as=25.4/.28,jc=class extends me{constructor(t){t=t||{};let e=document.createElement("div");e.style.pointerEvents="none",super({element:e,render:t.render,target:t.target}),this.on,this.once,this.un;let i=t.className!==void 0?t.className:t.bar?"ol-scale-bar":"ol-scale-line";this.innerElement_=document.createElement("div"),this.innerElement_.className=i+"-inner",this.element.className=i+" "+ge,this.element.appendChild(this.innerElement_),this.viewState_=null,this.minWidth_=t.minWidth!==void 0?t.minWidth:64,this.maxWidth_=t.maxWidth,this.renderedVisible_=!1,this.renderedWidth_=void 0,this.renderedHTML_="",this.addChangeListener(zc,this.handleUnitsChanged_),this.setUnits(t.units||"metric"),this.scaleBar_=t.bar||!1,this.scaleBarSteps_=t.steps||4,this.scaleBarText_=t.text||!1,this.dpi_=t.dpi||void 0}getUnits(){return this.get(zc)}handleUnitsChanged_(){this.updateElement_()}setUnits(t){this.set(zc,t)}setDpi(t){this.dpi_=t}updateElement_(){let t=this.viewState_;if(!t){this.renderedVisible_&&(this.element.style.display="none",this.renderedVisible_=!1);return}let e=t.center,i=t.projection,r=this.getUnits(),s=r=="degrees"?"degrees":"m",o=An(i,t.resolution,e,s),a=this.minWidth_*(this.dpi_||as)/as,l=this.maxWidth_!==void 0?this.maxWidth_*(this.dpi_||as)/as:void 0,c=a*o,h="";if(r=="degrees"){let E=Se.degrees;c*=E,c<E/60?(h="\u2033",o*=3600):c<E?(h="\u2032",o*=60):h="\xB0"}else if(r=="imperial")c<.9144?(h="in",o/=.0254):c<1609.344?(h="ft",o/=.3048):(h="mi",o/=1609.344);else if(r=="nautical")o/=1852,h="NM";else if(r=="metric")c<1e-6?(h="nm",o*=1e9):c<.001?(h="\u03BCm",o*=1e6):c<1?(h="mm",o*=1e3):c<1e3?h="m":(h="km",o/=1e3);else if(r=="us")c<.9144?(h="in",o*=39.37):c<1609.344?(h="ft",o/=.30480061):(h="mi",o/=1609.3472);else throw new Error("Invalid units");let u=3*Math.floor(Math.log(a*o)/Math.log(10)),d,f,g,p=0,m,_;for(;;){g=Math.floor(u/3);let E=Math.pow(10,g);if(d=T_[(u%3+3)%3]*E,f=Math.round(d/o),isNaN(f)){this.element.style.display="none",this.renderedVisible_=!1;return}if(l!==void 0&&f>=l){d=p,f=m,g=_;break}else if(f>=a)break;p=d,m=f,_=g,++u}let y=this.scaleBar_?this.createScaleBar(f,d,h):d.toFixed(g<0?-g:0)+" "+h;this.renderedHTML_!=y&&(this.innerElement_.innerHTML=y,this.renderedHTML_=y),this.renderedWidth_!=f&&(this.innerElement_.style.width=f+"px",this.renderedWidth_=f),this.renderedVisible_||(this.element.style.display="",this.renderedVisible_=!0)}createScaleBar(t,e,i){let r=this.getScaleForResolution(),s=r<1?Math.round(1/r).toLocaleString()+" : 1":"1 : "+Math.round(r).toLocaleString(),o=this.scaleBarSteps_,a=t/o,l=[this.createMarker("absolute")];for(let h=0;h<o;++h){let u=h%2===0?"ol-scale-singlebar-odd":"ol-scale-singlebar-even";l.push(`<div><div class="ol-scale-singlebar ${u}" style="width: ${a}px;"></div>`+this.createMarker("relative")+(h%2===0||o===2?this.createStepText(h,t,!1,e,i):"")+"</div>")}return l.push(this.createStepText(o,t,!0,e,i)),(this.scaleBarText_?`<div class="ol-scale-text" style="width: ${t}px;">`+s+"</div>":"")+l.join("")}createMarker(t){return`<div class="ol-scale-step-marker" style="position: ${t}; top: ${t==="absolute"?3:-10}px;"></div>`}createStepText(t,e,i,r,s){let a=(t===0?0:Math.round(r/this.scaleBarSteps_*t*100)/100)+(t===0?"":" "+s),l=t===0?-3:e/this.scaleBarSteps_*-1,c=t===0?0:e/this.scaleBarSteps_*2;return`<div class="ol-scale-step-text" style="margin-left: ${l}px;text-align: ${t===0?"left":"center"};min-width: ${c}px;left: ${i?e+"px":"unset"};">`+a+"</div>"}getScaleForResolution(){let t=An(this.viewState_.projection,this.viewState_.resolution,this.viewState_.center,"m"),e=this.dpi_||as,i=1e3/25.4;return t*i*e}render(t){let e=t.frameState;e?this.viewState_=e.viewState:this.viewState_=null,this.updateElement_()}},Wc=jc;var Xc=class extends pe{constructor(t){t=t||{},super(t),this.condition_=t.condition?t.condition:to,this.lastAngle_=void 0,this.lastMagnitude_=void 0,this.lastScaleDelta_=0,this.duration_=t.duration!==void 0?t.duration:400}handleDragEvent(t){if(!Ni(t))return;let e=t.map,i=e.getSize(),r=t.pixel,s=r[0]-i[0]/2,o=i[1]/2-r[1],a=Math.atan2(o,s),l=Math.sqrt(s*s+o*o),c=e.getView();if(this.lastAngle_!==void 0){let h=this.lastAngle_-a;c.adjustRotationInternal(h)}this.lastAngle_=a,this.lastMagnitude_!==void 0&&c.adjustResolutionInternal(this.lastMagnitude_/l),this.lastMagnitude_!==void 0&&(this.lastScaleDelta_=this.lastMagnitude_/l),this.lastMagnitude_=l}handleUpEvent(t){if(!Ni(t))return!0;let i=t.map.getView(),r=this.lastScaleDelta_>1?1:-1;return i.endInteraction(this.duration_,r),this.lastScaleDelta_=0,!1}handleDownEvent(t){return Ni(t)&&this.condition_(t)?(t.map.getView().beginInteraction(),this.lastAngle_=void 0,this.lastMagnitude_=void 0,!0):!1}},Ko=Xc;var Vo=class{model;el;map=null;mapContainer=null;lastProcessedCallId=0;pendingCalls=[];eventQueue=[];isMapReady=!1;methodHandlers=new Map;modelListeners=[];constructor(t,e){this.model=t,this.el=e}createMapContainer(){let t=this.model.get("width")||"100%",e=this.model.get("height")||"400px";this.el.style.width="100%",this.el.style.display="block",e.endsWith("%")&&(this.el.style.height="100%");let i=document.createElement("div");return i.style.width=t,i.style.height=e,i.style.position="relative",i.style.minWidth="200px",this.el.appendChild(i),this.mapContainer=i,i}setupModelListeners(){let t=()=>this.processJsCalls(),e=()=>this.onCenterChange(),i=()=>this.onZoomChange(),r=()=>this.onStyleChange();this.model.on("change:_js_calls",t),this.model.on("change:center",e),this.model.on("change:zoom",i),this.model.on("change:style",r),this.modelListeners.push(()=>this.model.off("change:_js_calls",t),()=>this.model.off("change:center",e),()=>this.model.off("change:zoom",i),()=>this.model.off("change:style",r))}removeModelListeners(){this.modelListeners.forEach(t=>t()),this.modelListeners=[]}registerMethod(t,e){this.methodHandlers.set(t,e)}executeMethod(t,e,i){let r=this.methodHandlers.get(t);if(r)try{r(e,i)}catch(s){console.error(`Error executing method ${t}:`,s)}else console.warn(`Unknown method: ${t}`)}processJsCalls(){let e=(this.model.get("_js_calls")||[]).filter(i=>i.id>this.lastProcessedCallId);for(let i of e)this.isMapReady?this.executeMethod(i.method,i.args,i.kwargs):this.pendingCalls.push(i),this.lastProcessedCallId=i.id}processPendingCalls(){for(let t of this.pendingCalls)this.executeMethod(t.method,t.args,t.kwargs);this.pendingCalls=[]}sendEvent(t,e){let i={type:t,data:e,timestamp:Date.now()};this.eventQueue.push(i),this.model.set("_js_events",[...this.eventQueue]),this.model.save_changes()}restoreState(){let t=this.model.get("_sources")||{};for(let[h,u]of Object.entries(t))this.executeMethod("addSource",[h],u);let e=new Set(["fill","line","symbol","circle","heatmap","fill-extrusion","raster","hillshade","color-relief","background"]),i=this.model.get("_layers")||{},r=Object.entries(i).filter(([,h])=>e.has(h.type)),s=r.filter(([h,u])=>h.startsWith("basemap-")||u.type==="raster"),o=r.filter(([h,u])=>!(h.startsWith("basemap-")||u.type==="raster")),a=[...s,...o];for(let[h,u]of a)this.executeMethod("addLayer",[],u);let l=this.model.get("_controls")||{},c=Object.keys(i);for(let[h,u]of Object.entries(l)){let d=u;d.type==="layer-control"?this.executeMethod("addLayerControl",[],{position:d.position,layers:c,...d.options}):d.type==="draw-control"?this.executeMethod("addDrawControl",[],{position:d.position,...d.options}):d.type==="control-grid"?this.executeMethod("addControlGrid",[],{position:d.position,...d.options}):this.executeMethod("addControl",[d.type],{position:d.position,...d.options})}}getMap(){return this.map}getIsMapReady(){return this.isMapReady}getModel(){return this.model}};var Bo=class extends Vo{map=null;olMethodHandlers={};layersMap=new globalThis.Map;controlsMap=new globalThis.Map;constructor(t,e){super(t,e),this.registerDefaultMethods()}registerMethod(t,e){this.olMethodHandlers[t]=e}registerDefaultMethods(){this.registerMethod("addBasemap",this.handleAddBasemap.bind(this)),this.registerMethod("addTileLayer",this.handleAddTileLayer.bind(this)),this.registerMethod("addGeoJSON",this.handleAddGeoJSON.bind(this)),this.registerMethod("addWMSLayer",this.handleAddWMSLayer.bind(this)),this.registerMethod("addImageWMSLayer",this.handleAddImageWMSLayer.bind(this)),this.registerMethod("removeLayer",this.handleRemoveLayer.bind(this)),this.registerMethod("setVisibility",this.handleSetVisibility.bind(this)),this.registerMethod("setOpacity",this.handleSetOpacity.bind(this)),this.registerMethod("addControl",this.handleAddControl.bind(this)),this.registerMethod("removeControl",this.handleRemoveControl.bind(this)),this.registerMethod("setCenter",this.handleSetCenter.bind(this)),this.registerMethod("setZoom",this.handleSetZoom.bind(this)),this.registerMethod("flyTo",this.handleFlyTo.bind(this)),this.registerMethod("fitBounds",this.handleFitBounds.bind(this)),this.registerMethod("fitExtent",this.handleFitExtent.bind(this)),this.registerMethod("addMarker",this.handleAddMarker.bind(this))}async initialize(){let t=this.model.get("center")||[0,0],e=this.model.get("zoom")||2;this.el.style.width="100%",this.el.style.display="block";let i=document.createElement("div");i.style.width=this.model.get("width")||"100%",i.style.height=this.model.get("height")||"600px",i.style.position="relative",i.style.minWidth="200px",this.el.appendChild(i),this.map=new ah({target:i,view:new Bt({center:nn(t),zoom:e}),controls:kn({attribution:!1}),interactions:jn().extend([new Ko])});let r=this.model.get("_js_calls");if(r&&r.length>0)for(let s of r)await this.executeOLMethod(s);this.model.on("change:_js_calls",()=>{this.handleJsCallsChange()}),this.model.on("change:center",()=>{let s=this.model.get("center");this.map&&this.map.getView().setCenter(nn(s))}),this.model.on("change:zoom",()=>{let s=this.model.get("zoom");this.map&&this.map.getView().setZoom(s)}),this.map.getView().on("change:center",()=>{if(this.map){let s=Wu(this.map.getView().getCenter()||[0,0]);this.model.set("center",s),this.model.save_changes()}}),this.map.getView().on("change:resolution",()=>{if(this.map){let s=this.map.getView().getZoom();this.model.set("zoom",s),this.model.save_changes()}})}handleJsCallsChange(){let t=this.model.get("_js_calls");if(t&&t.length>0){let e=t[t.length-1];this.executeOLMethod(e)}}async executeOLMethod(t){let{method:e,args:i,kwargs:r}=t,s=this.olMethodHandlers[e];if(s)try{s(i,r)}catch(o){console.error(`Error executing method ${e}:`,o)}else console.warn(`Unknown method: ${e}`)}createMap(){let t=this.model.get("center")||[0,0],e=this.model.get("zoom")||2,i=this.createMapContainer();return new ah({target:i,view:new Bt({center:nn(t),zoom:e}),controls:kn({attribution:!1}),interactions:jn().extend([new Ko])})}onCenterChange(){let t=this.model.get("center");this.map&&this.map.getView().setCenter(nn(t))}onZoomChange(){let t=this.model.get("zoom");this.map&&this.map.getView().setZoom(t)}onStyleChange(){}handleAddBasemap(t,e){if(!this.map)return;let i=t[0],r=e.name||"basemap",s=e.attribution||"",o=this.layersMap.get("basemap-"+r);o&&this.map.removeLayer(o);let a=new Po({source:new nc({url:i,attributions:s?[s]:void 0}),zIndex:0});this.map.getLayers().insertAt(0,a),this.layersMap.set("basemap-"+r,a)}handleAddTileLayer(t,e){if(!this.map)return;let i=t[0],r=e.name||`tiles-${this.layersMap.size}`,s=e.attribution||"",o=e.opacity??1,a=e.minZoom??0,l=e.maxZoom??22,c=new Po({source:new nc({url:i,attributions:s?[s]:void 0,minZoom:a,maxZoom:l}),opacity:o});this.map.addLayer(c),this.layersMap.set(r,c)}handleAddGeoJSON(t,e){if(!this.map)return;let i=e.data,r=e.name||`geojson-${this.layersMap.size}`,s=e.fitBounds!==!1,o=e.style||{},a=new vc({features:new Oc().readFeatures(i,{featureProjection:"EPSG:3857"})}),l=new Vh({source:a,style:this.createVectorStyle(o)});if(this.map.addLayer(l),this.layersMap.set(r,l),s){let c=a.getExtent();c&&c.every(h=>isFinite(h))&&this.map.getView().fit(c,{padding:[50,50,50,50],duration:500})}}createVectorStyle(t){let e=new Pe({color:t.fillColor||"rgba(51, 136, 255, 0.5)"}),i=new Ki({color:t.strokeColor||"#3388ff",width:t.strokeWidth??2}),r=new Yi({radius:t.radius??6,fill:e,stroke:i});return new Ze({fill:e,stroke:i,image:r})}handleAddWMSLayer(t,e){if(!this.map)return;let i=e.url,r=e.name||`wms-${this.layersMap.size}`,s=e.layers,o=e.format||"image/png",a=e.transparent!==!1,l=e.attribution||"",c=new Po({source:new dg({url:i,params:{LAYERS:s,FORMAT:o,TRANSPARENT:a},serverType:e.serverType||void 0,attributions:l?[l]:void 0})});this.map.addLayer(c),this.layersMap.set(r,c)}handleAddImageWMSLayer(t,e){if(!this.map)return;let i=e.url,r=e.name||`imagewms-${this.layersMap.size}`,s=e.layers,o=e.format||"image/png",a=e.transparent!==!1,l=e.attribution||"",c=new Zf({source:new fg({url:i,params:{LAYERS:s,FORMAT:o,TRANSPARENT:a},serverType:e.serverType||void 0,attributions:l?[l]:void 0})});this.map.addLayer(c),this.layersMap.set(r,c)}handleRemoveLayer(t,e){if(!this.map)return;let[i]=t,r=this.layersMap.get(i);r&&(this.map.removeLayer(r),this.layersMap.delete(i))}handleSetVisibility(t,e){let[i,r]=t,s=this.layersMap.get(i);s&&s.setVisible(r)}handleSetOpacity(t,e){let[i,r]=t,s=this.layersMap.get(i);s&&s.setOpacity(r)}handleAddControl(t,e){if(!this.map)return;let i=t[0],r=e.position||"top-right",s;switch(i){case"zoom":case"navigation":s=new br;break;case"scale":s=new Wc({units:e.units||"metric"});break;case"fullscreen":s=new Dc;break;case"attribution":s=new Ir({collapsible:e.collapsible!==!1});break;case"rotate":s=new Mr({autoHide:e.autoHide!==!1});break;case"mousePosition":s=new Gc({coordinateFormat:mu(4),projection:"EPSG:4326"});break}s&&(this.map.addControl(s),this.controlsMap.set(i,s))}handleRemoveControl(t,e){if(!this.map)return;let[i]=t,r=this.controlsMap.get(i);r&&(this.map.removeControl(r),this.controlsMap.delete(i))}handleSetCenter(t,e){if(!this.map)return;let[i,r]=t;this.map.getView().setCenter(nn([i,r]))}handleSetZoom(t,e){if(!this.map)return;let[i]=t;this.map.getView().setZoom(i)}handleFlyTo(t,e){if(!this.map)return;let[i,r]=t,s=e.zoom,o=e.duration||2e3;this.map.getView().animate({center:nn([i,r]),zoom:s,duration:o})}handleFitBounds(t,e){if(!this.map)return;let i=t[0],r=e.padding||50,s=e.duration||1e3,o=fr([i[0],i[1],i[2],i[3]],"EPSG:4326","EPSG:3857");this.map.getView().fit(o,{padding:[r,r,r,r],duration:s})}handleFitExtent(t,e){if(!this.map)return;let i=t[0],r=e.padding||50,s=e.duration||1e3;this.map.getView().fit(i,{padding:[r,r,r,r],duration:s})}handleAddMarker(t,e){if(!this.map)return;let[i,r]=t,s=e.id||e.name||`marker-${this.layersMap.size}`,o=e.popup,a=e.color||"#3388ff",l=new Oc().readFeature({type:"Feature",geometry:{type:"Point",coordinates:[i,r]},properties:{popup:o}},{featureProjection:"EPSG:3857"}),c=Array.isArray(l)?l:[l],h=new vc({features:c}),u=new Ze({image:new Yi({radius:8,fill:new Pe({color:a}),stroke:new Ki({color:"#ffffff",width:2})})}),d=new Vh({source:h,style:u});this.map.addLayer(d),this.layersMap.set(s,d)}destroy(){this.removeModelListeners(),this.map&&(this.map.setTarget(void 0),this.map=null),this.layersMap.clear(),this.controlsMap.clear()}};var ls=null;function v_({model:n,el:t}){return ls=new Bo(n,t),ls.initialize().catch(e=>{console.error("Failed to initialize OpenLayers map:",e)}),()=>{ls&&(ls.destroy(),ls=null)}}var vO={render:v_};export{vO as default,v_ as render};
|
|
1
|
+
var wt={ADD:"add",REMOVE:"remove"};var Ee={PROPERTYCHANGE:"propertychange"};var L={CHANGE:"change",ERROR:"error",BLUR:"blur",CLEAR:"clear",CONTEXTMENU:"contextmenu",CLICK:"click",DBLCLICK:"dblclick",DRAGENTER:"dragenter",DRAGOVER:"dragover",DROP:"drop",FOCUS:"focus",KEYDOWN:"keydown",KEYPRESS:"keypress",LOAD:"load",RESIZE:"resize",TOUCHMOVE:"touchmove",WHEEL:"wheel"};var ta=class{constructor(){this.disposed=!1}dispose(){this.disposed||(this.disposed=!0,this.disposeInternal())}disposeInternal(){}},Ci=ta;function qc(n,t,e){let i,r;e=e||jt;let s=0,o=n.length,a=!1;for(;s<o;)i=s+(o-s>>1),r=+e(n[i],t),r<0?s=i+1:(o=i,a=!r);return a?s:~s}function jt(n,t){return n>t?1:n<t?-1:0}function $c(n,t){return n<t?1:n>t?-1:0}function Ri(n,t,e){if(n[0]<=t)return 0;let i=n.length;if(t<=n[i-1])return i-1;if(typeof e=="function"){for(let r=1;r<i;++r){let s=n[r];if(s===t)return r;if(s<t)return e(t,n[r-1],s)>0?r-1:r}return i-1}if(e>0){for(let r=1;r<i;++r)if(n[r]<t)return r-1;return i-1}if(e<0){for(let r=1;r<i;++r)if(n[r]<=t)return r;return i-1}for(let r=1;r<i;++r){if(n[r]==t)return r;if(n[r]<t)return n[r-1]-t<t-n[r]?r-1:r}return i-1}function Jc(n,t,e){for(;t<e;){let i=n[t];n[t]=n[e],n[e]=i,++t,--e}}function It(n,t){let e=Array.isArray(t)?t:[t],i=e.length;for(let r=0;r<i;r++)n[n.length]=e[r]}function Ot(n,t){let 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 Qc(n,t,e){let i=t||jt;return n.every(function(r,s){if(s===0)return!0;let o=i(n[s-1],r);return!(o>0||e&&o===0)})}function ei(){return!0}function ii(){return!1}function ni(){}function ms(n){let t,e,i;return function(){let r=Array.prototype.slice.call(arguments);return(!e||this!==i||!Ot(r,e))&&(i=this,e=r,t=n.apply(this,arguments)),t}}function ps(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 ze(n){for(let t in n)delete n[t]}function $t(n){let t;for(t in n)return!1;return!t}var ea=class{constructor(t){this.propagationStopped,this.defaultPrevented,this.type=t,this.target=null}preventDefault(){this.defaultPrevented=!0}stopPropagation(){this.propagationStopped=!0}};var mt=ea;var ia=class extends Ci{constructor(t){super(),this.eventTarget_=t,this.pendingRemovals_=null,this.dispatching_=null,this.listeners_=null}addEventListener(t,e){if(!t||!e)return;let i=this.listeners_||(this.listeners_={}),r=i[t]||(i[t]=[]);r.includes(e)||r.push(e)}dispatchEvent(t){let e=typeof t=="string",i=e?t:t.type,r=this.listeners_&&this.listeners_[i];if(!r)return;let s=e?new mt(t):t;s.target||(s.target=this.eventTarget_||this);let 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=r.length;h<c;++h)if("handleEvent"in r[h]?l=r[h].handleEvent(s):l=r[h].call(this,s),l===!1||s.propagationStopped){l=!1;break}if(--o[i]===0){let h=a[i];for(delete a[i];h--;)this.removeEventListener(i,ni);delete o[i]}return l}disposeInternal(){this.listeners_&&ze(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;let i=this.listeners_[t];if(!i)return;let r=i.indexOf(e);r!==-1&&(this.pendingRemovals_&&t in this.pendingRemovals_?(i[r]=ni,++this.pendingRemovals_[t]):(i.splice(r,1),i.length===0&&delete this.listeners_[t]))}},je=ia;function G(n,t,e,i,r){if(r){let o=e;e=function(a){return n.removeEventListener(t,e),o.call(i??this,a)}}else i&&i!==n&&(e=e.bind(i));let s={target:n,type:t,listener:e};return n.addEventListener(t,e),s}function _n(n,t,e,i){return G(n,t,e,i,!0)}function B(n){n&&n.target&&(n.target.removeEventListener(n.type,n.listener),ze(n))}var yn=class extends je{constructor(){super(),this.on=this.onInternal,this.once=this.onceInternal,this.un=this.unInternal,this.revision_=0}changed(){++this.revision_,this.dispatchEvent(L.CHANGE)}getRevision(){return this.revision_}onInternal(t,e){if(Array.isArray(t)){let i=t.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=G(this,t[s],e);return r}return G(this,t,e)}onceInternal(t,e){let i;if(Array.isArray(t)){let r=t.length;i=new Array(r);for(let s=0;s<r;++s)i[s]=_n(this,t[s],e)}else i=_n(this,t,e);return e.ol_key=i,i}unInternal(t,e){let i=e.ol_key;if(i)Ag(i);else if(Array.isArray(t))for(let r=0,s=t.length;r<s;++r)this.removeEventListener(t[r],e);else this.removeEventListener(t,e)}};yn.prototype.on;yn.prototype.once;yn.prototype.un;function Ag(n){if(Array.isArray(n))for(let t=0,e=n.length;t<e;++t)B(n[t]);else B(n)}var _s=yn;function F(){throw new Error("Unimplemented abstract method.")}var Pg=0;function U(n){return n.ol_uid||(n.ol_uid=String(++Pg))}var ys=class extends mt{constructor(t,e,i){super(t),this.key=e,this.oldValue=i}},na=class extends _s{constructor(t){super(),this.on,this.once,this.un,U(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 ys(i,t,e)),i=Ee.PROPERTYCHANGE,this.hasListener(i)&&this.dispatchEvent(new ys(i,t,e))}addChangeListener(t,e){this.addEventListener(`change:${t}`,e)}removeChangeListener(t,e){this.removeEventListener(`change:${t}`,e)}set(t,e,i){let r=this.values_||(this.values_={});if(i)r[t]=e;else{let s=r[t];r[t]=e,s!==e&&this.notify(t,s)}}setProperties(t,e){for(let 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_){let i=this.values_[t];delete this.values_[t],$t(this.values_)&&(this.values_=null),e||this.notify(t,i)}}},pt=na;var tu={LENGTH:"length"},xn=class extends mt{constructor(t,e,i){super(t),this.element=e,this.index=i}},ra=class extends pt{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,r=this.array_.length;i<r;++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){let e=this.array_;for(let i=0,r=e.length;i<r;++i)t(e[i],i,e)}getArray(){return this.array_}item(t){return this.array_[t]}getLength(){return this.get(tu.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 xn(wt.ADD,e,t))}pop(){return this.removeAt(this.getLength()-1)}push(t){let e=this.getLength();return this.insertAt(e,t),this.getLength()}remove(t){let e=this.array_;for(let i=0,r=e.length;i<r;++i)if(e[i]===t)return this.removeAt(i)}removeAt(t){if(t<0||t>=this.getLength())return;let e=this.array_[t];return this.array_.splice(t,1),this.updateLength_(),this.dispatchEvent(new xn(wt.REMOVE,e,t)),e}setAt(t,e){let 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);let r=this.array_[t];this.array_[t]=e,this.dispatchEvent(new xn(wt.REMOVE,r,t)),this.dispatchEvent(new xn(wt.ADD,e,t))}updateLength_(){this.set(tu.LENGTH,this.array_.length)}assertUnique_(t,e){let i=this.array_;for(let r=0,s=i.length;r<s;++r)if(i[r]===t&&r!==e)throw new Error("Duplicate item added to a unique collection")}},Mt=ra;var sa=class extends mt{constructor(t,e,i){super(t),this.map=e,this.frameState=i!==void 0?i:null}},wi=sa;var oa=class extends wi{constructor(t,e,i,r,s,o){super(t,e,s),this.originalEvent=i,this.pixel_=null,this.coordinate_=null,this.dragging=r!==void 0?r:!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()}},We=oa;var at={SINGLECLICK:"singleclick",CLICK:L.CLICK,DBLCLICK:L.DBLCLICK,POINTERDRAG:"pointerdrag",POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"};var Ji=typeof navigator<"u"&&typeof navigator.userAgent<"u"?navigator.userAgent.toLowerCase():"",Og=Ji.includes("safari")&&!Ji.includes("chrom"),dy=Og&&(Ji.includes("version/15.4")||/cpu (os|iphone os) 15_4 like mac os x/.test(Ji)),eu=Ji.includes("webkit")&&!Ji.includes("edge"),aa=Ji.includes("macintosh"),iu=typeof devicePixelRatio<"u"?devicePixelRatio:1,xt=typeof WorkerGlobalScope<"u"&&typeof OffscreenCanvas<"u"&&self instanceof WorkerGlobalScope,xs=typeof Image<"u"&&Image.prototype.decode,la=typeof createImageBitmap=="function",Es=(function(){let n=!1;try{let t=Object.defineProperty({},"passive",{get:function(){n=!0}});window.addEventListener("_",null,t),window.removeEventListener("_",null,t)}catch{}return n})();var Si={POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"};var ha=class extends je{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;let i=this.map_.getViewport();this.activePointers_=[],this.trackedTouches_={},this.element_=i,this.pointerdownListenerKey_=G(i,Si.POINTERDOWN,this.handlePointerDown_,this),this.originalPointerMoveEvent_,this.relayedListenerKey_=G(i,Si.POINTERMOVE,this.relayMoveEvent_,this),this.boundHandleTouchMove_=this.handleTouchMove_.bind(this),this.element_.addEventListener(L.TOUCHMOVE,this.boundHandleTouchMove_,Es?{passive:!1}:!1)}emulateClick_(t){let e=new We(at.CLICK,this.map_,t);this.dispatchEvent(e),this.clickTimeoutId_!==void 0?(clearTimeout(this.clickTimeoutId_),this.clickTimeoutId_=void 0,e=new We(at.DBLCLICK,this.map_,t),this.dispatchEvent(e)):this.clickTimeoutId_=setTimeout(()=>{this.clickTimeoutId_=void 0;let i=new We(at.SINGLECLICK,this.map_,t);this.dispatchEvent(i)},250)}updateActivePointers_(t){let e=t,i=e.pointerId;if(e.type==at.POINTERUP||e.type==at.POINTERCANCEL){delete this.trackedTouches_[i];for(let r in this.trackedTouches_)if(this.trackedTouches_[r].target!==e.target){delete this.trackedTouches_[r];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);let e=new We(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(B),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);let e=new We(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){let i=this.map_.getOwnerDocument();this.dragListenerKeys_.push(G(i,at.POINTERMOVE,this.handlePointerMove_,this),G(i,at.POINTERUP,this.handlePointerUp_,this),G(this.element_,at.POINTERCANCEL,this.handlePointerUp_,this)),this.element_.getRootNode&&this.element_.getRootNode()!==i&&this.dragListenerKeys_.push(G(this.element_.getRootNode(),at.POINTERUP,this.handlePointerUp_,this))}}handlePointerMove_(t){if(this.isMoving_(t)){this.updateActivePointers_(t),this.dragging_=!0;let e=new We(at.POINTERDRAG,this.map_,t,this.dragging_,void 0,this.activePointers_);this.dispatchEvent(e)}}relayMoveEvent_(t){this.originalPointerMoveEvent_=t;let e=!!(this.down_&&this.isMoving_(t));this.dispatchEvent(new We(at.POINTERMOVE,this.map_,t,e))}handleTouchMove_(t){let 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_&&(B(this.relayedListenerKey_),this.relayedListenerKey_=null),this.element_.removeEventListener(L.TOUCHMOVE,this.boundHandleTouchMove_),this.pointerdownListenerKey_&&(B(this.pointerdownListenerKey_),this.pointerdownListenerKey_=null),this.dragListenerKeys_.forEach(B),this.dragListenerKeys_.length=0,this.element_=null,super.disposeInternal()}},nu=ha;var Xe={POSTRENDER:"postrender",MOVESTART:"movestart",MOVEEND:"moveend",LOADSTART:"loadstart",LOADEND:"loadend"};var _t={LAYERGROUP:"layergroup",SIZE:"size",TARGET:"target",VIEW:"view"};var O={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4};function V(n,t){if(!n)throw new Error(t)}var lr=1/0,ca=class{constructor(t,e){this.priorityFunction_=t,this.keyFunction_=e,this.elements_=[],this.priorities_=[],this.queuedElements_={}}clear(){this.elements_.length=0,this.priorities_.length=0,ze(this.queuedElements_)}dequeue(){let 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));let r=this.keyFunction_(i);return delete this.queuedElements_[r],i}enqueue(t){V(!(this.keyFunction_(t)in this.queuedElements_),"Tried to enqueue an `element` that was already added to the queue");let 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){let e=this.elements_,i=this.priorities_,r=e.length,s=e[t],o=i[t],a=t;for(;t<r>>1;){let l=this.getLeftChildIndex_(t),h=this.getRightChildIndex_(t),c=h<r&&i[h]<i[l]?h:l;e[t]=e[c],i[t]=i[c],t=c}e[t]=s,i[t]=o,this.siftDown_(a,t)}siftDown_(t,e){let i=this.elements_,r=this.priorities_,s=i[e],o=r[e];for(;e>t;){let a=this.getParentIndex_(e);if(r[a]>o)i[e]=i[a],r[e]=r[a],e=a;else break}i[e]=s,r[e]=o}reprioritize(){let t=this.priorityFunction_,e=this.elements_,i=this.priorities_,r=0,s=e.length,o,a,l;for(a=0;a<s;++a)o=e[a],l=t(o),l==lr?delete this.queuedElements_[this.keyFunction_(o)]:(i[r]=l,e[r++]=o);e.length=r,i.length=r,this.heapify_()}},ru=ca;var ua=class extends ru{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){let e=super.enqueue(t);return e&&t[0].addEventListener(L.CHANGE,this.boundHandleTileChange_),e}getTilesLoading(){return this.tilesLoading_}handleTileChange(t){let e=t.target,i=e.getState();if(i===O.LOADED||i===O.ERROR||i===O.EMPTY){i!==O.ERROR&&e.removeEventListener(L.CHANGE,this.boundHandleTileChange_);let r=e.getKey();r in this.tilesLoadingKeys_&&(delete this.tilesLoadingKeys_[r],--this.tilesLoading_),this.tileChangeCallback_()}}loadMoreTiles(t,e){let i=0;for(;this.tilesLoading_<t&&i<e&&this.getCount()>0;){let r=this.dequeue()[0],s=r.getKey();r.getState()===O.IDLE&&!(s in this.tilesLoadingKeys_)&&(this.tilesLoadingKeys_[s]=!0,++this.tilesLoading_,++i,r.load())}}},su=ua;function ou(n,t,e,i,r){if(!n||!(e in n.wantedTiles))return lr;if(!n.wantedTiles[e][t.getKey()])return lr;let s=n.viewState.center,o=i[0]-s[0],a=i[1]-s[1];return 65536*Math.log(r)+Math.sqrt(o*o+a*a)/r}var dt={ANIMATING:0,INTERACTING:1};var ae={CENTER:"center",RESOLUTION:"resolution",ROTATION:"rotation"};function Q(n,t,e){return Math.min(Math.max(n,t),e)}function au(n,t,e,i,r,s){let o=r-e,a=s-i;if(o!==0||a!==0){let l=((n-e)*o+(t-i)*a)/(o*o+a*a);l>1?(e=r,i=s):l>0&&(e+=o*l,i+=a*l)}return Ce(n,t,e,i)}function Ce(n,t,e,i){let r=e-n,s=i-t;return r*r+s*s}function lu(n){let t=n.length;for(let i=0;i<t;i++){let r=i,s=Math.abs(n[i][i]);for(let a=i+1;a<t;a++){let l=Math.abs(n[a][i]);l>s&&(s=l,r=a)}if(s===0)return null;let o=n[r];n[r]=n[i],n[i]=o;for(let a=i+1;a<t;a++){let 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]}}let e=new Array(t);for(let i=t-1;i>=0;i--){e[i]=n[i][t]/n[i][i];for(let r=i-1;r>=0;r--)n[r][t]-=n[r][i]*e[i]}return e}function Cs(n){return n*180/Math.PI}function Re(n){return n*Math.PI/180}function Wt(n,t){let e=n%t;return e*t<0?e+t:e}function bt(n,t,e){return n+e*(t-n)}function Ti(n,t){let e=Math.pow(10,t);return Math.round(n*e)/e}function da(n,t){return Math.round(Ti(n,t))}function vi(n,t){return Math.floor(Ti(n,t))}function Ue(n,t){return Math.ceil(Ti(n,t))}function Rs(n,t,e){if(n>=t&&n<e)return n;let i=e-t;return((n-t)%i+i)%i+t}function fa(n,t,e){return(function(i,r,s,o,a){if(!i)return;if(!r&&!t)return i;let l=t?0:s[0]*r,h=t?0:s[1]*r,c=a?a[0]:0,u=a?a[1]:0,d=n[0]+l/2+c,f=n[2]-l/2+c,g=n[1]+h/2+u,p=n[3]-h/2+u;d>f&&(d=(f+d)/2,f=d),g>p&&(g=(p+g)/2,p=g);let m=Q(i[0],d,f),_=Q(i[1],g,p);if(o&&e&&r){let y=30*r;m+=-y*Math.log(1+Math.max(0,d-i[0])/y)+y*Math.log(1+Math.max(0,i[0]-f)/y),_+=-y*Math.log(1+Math.max(0,g-i[1])/y)+y*Math.log(1+Math.max(0,i[1]-p)/y)}return[m,_]})}function hu(n){return n}var yt={UNKNOWN:0,INTERSECTING:1,ABOVE:2,RIGHT:4,BELOW:8,LEFT:16};function ga(n){let t=ct();for(let e=0,i=n.length;e<i;++e)Qi(t,n[e]);return t}function Fg(n,t,e){let i=Math.min.apply(null,n),r=Math.min.apply(null,t),s=Math.max.apply(null,n),o=Math.max.apply(null,t);return Qt(i,r,s,o,e)}function ri(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 Ss(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n.slice()}function Xt(n,t,e){let i,r;return t<n[0]?i=n[0]-t:n[2]<t?i=t-n[2]:i=0,e<n[1]?r=n[1]-e:n[3]<e?r=e-n[3]:r=0,i*i+r*r}function Jt(n,t){return hr(n,t[0],t[1])}function le(n,t){return n[0]<=t[0]&&t[2]<=n[2]&&n[1]<=t[1]&&t[3]<=n[3]}function hr(n,t,e){return n[0]<=t&&t<=n[2]&&n[1]<=e&&e<=n[3]}function ws(n,t){let e=n[0],i=n[1],r=n[2],s=n[3],o=t[0],a=t[1],l=yt.UNKNOWN;return o<e?l=l|yt.LEFT:o>r&&(l=l|yt.RIGHT),a<i?l=l|yt.BELOW:a>s&&(l=l|yt.ABOVE),l===yt.UNKNOWN&&(l=yt.INTERSECTING),l}function ct(){return[1/0,1/0,-1/0,-1/0]}function Qt(n,t,e,i,r){return r?(r[0]=n,r[1]=t,r[2]=e,r[3]=i,r):[n,t,e,i]}function si(n){return Qt(1/0,1/0,-1/0,-1/0,n)}function Ts(n,t){let e=n[0],i=n[1];return Qt(e,i,e,i,t)}function En(n,t,e,i,r){let s=si(r);return ma(s,n,t,e,i)}function we(n,t){return n[0]==t[0]&&n[2]==t[2]&&n[1]==t[1]&&n[3]==t[3]}function vs(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 Qi(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 ma(n,t,e,i,r){for(;e<i;e+=r)Dg(n,t[e],t[e+1]);return n}function Dg(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 Is(n,t){let e;return e=t(Cn(n)),e||(e=t(Rn(n)),e)||(e=t(wn(n)),e)||(e=t(he(n)),e)?e:!1}function cr(n){let t=0;return Yt(n)||(t=W(n)*et(n)),t}function Cn(n){return[n[0],n[1]]}function Rn(n){return[n[2],n[1]]}function St(n){return[(n[0]+n[2])/2,(n[1]+n[3])/2]}function cu(n,t){let e;if(t==="bottom-left")e=Cn(n);else if(t==="bottom-right")e=Rn(n);else if(t==="top-left")e=he(n);else if(t==="top-right")e=wn(n);else throw new Error("Invalid corner");return e}function oi(n,t,e,i,r){let[s,o,a,l,h,c,u,d]=pa(n,t,e,i);return Qt(Math.min(s,a,h,u),Math.min(o,l,c,d),Math.max(s,a,h,u),Math.max(o,l,c,d),r)}function pa(n,t,e,i){let r=t*i[0]/2,s=t*i[1]/2,o=Math.cos(e),a=Math.sin(e),l=r*o,h=r*a,c=s*o,u=s*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 et(n){return n[3]-n[1]}function Ut(n,t,e){let i=e||ct();return lt(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]):si(i),i}function he(n){return[n[0],n[3]]}function wn(n){return[n[2],n[3]]}function W(n){return n[2]-n[0]}function lt(n,t){return n[0]<=t[2]&&n[2]>=t[0]&&n[1]<=t[3]&&n[3]>=t[1]}function Yt(n){return n[2]<n[0]||n[3]<n[1]}function uu(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n}function du(n,t,e){let i=!1,r=ws(n,t),s=ws(n,e);if(r===yt.INTERSECTING||s===yt.INTERSECTING)i=!0;else{let 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),p,m;s&yt.ABOVE&&!(r&yt.ABOVE)&&(p=d-(f-h)/g,i=p>=o&&p<=l),!i&&s&yt.RIGHT&&!(r&yt.RIGHT)&&(m=f-(d-l)*g,i=m>=a&&m<=h),!i&&s&yt.BELOW&&!(r&yt.BELOW)&&(p=d-(f-a)/g,i=p>=o&&p<=l),!i&&s&yt.LEFT&&!(r&yt.LEFT)&&(m=f-(d-o)*g,i=m>=a&&m<=h)}return i}function fu(n,t,e,i){if(Yt(n))return si(e);let r=[];if(i>1){let a=n[2]-n[0],l=n[3]-n[1];for(let h=0;h<i;++h)r.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 r=[n[0],n[1],n[2],n[1],n[2],n[3],n[0],n[3]];t(r,r,2);let s=[],o=[];for(let a=0,l=r.length;a<l;a+=2)s.push(r[a]),o.push(r[a+1]);return Fg(s,o,e)}function _a(n,t){let e=t.getExtent(),i=St(n);if(t.canWrapX()&&(i[0]<e[0]||i[0]>=e[2])){let r=W(e),o=Math.floor((i[0]-e[0])/r)*r;n[0]-=o,n[2]-=o}return n}function Ms(n,t,e){if(t.canWrapX()){let i=t.getExtent();if(!isFinite(n[0])||!isFinite(n[2]))return[[i[0],n[1],i[2],n[3]]];_a(n,t);let r=W(i);if(W(n)>r&&!e)return[[i[0],n[1],i[2],n[3]]];if(n[0]<i[0])return[[n[0]+r,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]-r,n[3]]]}return[n]}function ur(n,t){let e=(""+n).split("."),i=(""+t).split(".");for(let r=0;r<Math.max(e.length,i.length);r++){let s=parseInt(e[r]||"0",10),o=parseInt(i[r]||"0",10);if(s>o)return 1;if(o>s)return-1}return 0}function gu(n,t){return n[0]+=+t[0],n[1]+=+t[1],n}function mu(n){return(function(t){return Ng(t,n)})}function kg(n,t,e){return n?t.replace("{x}",n[0].toFixed(e)).replace("{y}",n[1].toFixed(e)):""}function tn(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 Sn(n,t){let e=Math.cos(t),i=Math.sin(t),r=n[0]*e-n[1]*i,s=n[1]*e+n[0]*i;return n[0]=r,n[1]=s,n}function pu(n,t){return n[0]*=t,n[1]*=t,n}function Ng(n,t){return kg(n,"{x}, {y}",t)}function Tn(n,t){if(t.canWrapX()){let e=W(t.getExtent()),i=_u(n,t,e);i&&(n[0]-=i*e)}return n}function _u(n,t,e){let i=t.getExtent(),r=0;return t.canWrapX()&&(n[0]<i[0]||n[0]>i[2])&&(e=e||W(i),r=Math.floor((n[0]-i[0])/e)),r}function yu(n,t,e){let i=Math.sqrt((t[0]-n[0])*(t[0]-n[0])+(t[1]-n[1])*(t[1]-n[1])),r=[(t[0]-n[0])/i,(t[1]-n[1])/i],s=[-r[1],r[0]],o=Math.sqrt((e[0]-n[0])*(e[0]-n[0])+(e[1]-n[1])*(e[1]-n[1])),a=[(e[0]-n[0])/o,(e[1]-n[1])/o],l=i===0||o===0?0:Math.acos(Q(a[0]*r[0]+a[1]*r[1],-1,1));return l=Math.max(l,1e-5),a[0]*s[0]+a[1]*s[1]>0?l:Math.PI*2-l}function ya(n){return Math.pow(n,3)}function ce(n){return 1-ya(1-n)}function xu(n){return 3*n*n-2*n*n*n}function Eu(n){return n}var Gg=63710088e-1;function xa(n,t,e){e=e||Gg;let i=Re(n[1]),r=Re(t[1]),s=(r-i)/2,o=Re(t[0]-n[0])/2,a=Math.sin(s)*Math.sin(s)+Math.sin(o)*Math.sin(o)*Math.cos(i)*Math.cos(r);return 2*e*Math.atan2(Math.sqrt(a),Math.sqrt(1-a))}var Cu={info:1,warn:2,error:3,none:4},zg=Cu.info;function bs(...n){zg>Cu.warn||console.warn(...n)}var Se={radians:6370997/(2*Math.PI),degrees:2*Math.PI*6370997/360,ft:.3048,m:1,"us-ft":1200/3937};var Ea=class{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_||Se[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_}},vn=Ea;var dr=6378137,In=Math.PI*dr,jg=[-In,-In,In,In],Wg=[-180,-85,180,85],Ls=dr*Math.log(Math.tan(Math.PI/2)),Ii=class extends vn{constructor(t){super({code:t,units:"m",extent:jg,global:!0,worldExtent:Wg,getPointResolution:function(e,i){return e/Math.cosh(i[1]/dr)}})}},Ca=[new Ii("EPSG:3857"),new Ii("EPSG:102100"),new Ii("EPSG:102113"),new Ii("EPSG:900913"),new Ii("http://www.opengis.net/def/crs/EPSG/0/3857"),new Ii("http://www.opengis.net/gml/srs/epsg.xml#3857")];function Ru(n,t,e,i){let r=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(r));for(let s=0;s<r;s+=i){t[s]=In*n[s]/180;let o=dr*Math.log(Math.tan(Math.PI*(+n[s+1]+90)/360));o>Ls?o=Ls:o<-Ls&&(o=-Ls),t[s+1]=o}return t}function wu(n,t,e,i){let r=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(r));for(let s=0;s<r;s+=i)t[s]=180*n[s]/In,t[s+1]=360*Math.atan(Math.exp(n[s+1]/dr))/Math.PI-90;return t}var Xg=6378137,Su=[-180,-90,180,90],Ug=Math.PI*Xg/180,ai=class extends vn{constructor(t,e){super({code:t,units:"degrees",extent:Su,axisOrientation:e,global:!0,metersPerUnit:Ug,worldExtent:Su})}},Ra=[new ai("CRS:84"),new ai("EPSG:4326","neu"),new ai("urn:ogc:def:crs:OGC:1.3:CRS84"),new ai("urn:ogc:def:crs:OGC:2:84"),new ai("http://www.opengis.net/def/crs/OGC/1.3/CRS84"),new ai("http://www.opengis.net/gml/srs/epsg.xml#4326","neu"),new ai("http://www.opengis.net/def/crs/EPSG/0/4326","neu")];var wa={};function Tu(n){return wa[n]||wa[n.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\w+)$/,"EPSG:$3")]||null}function vu(n,t){wa[n]=t}var Mn={};function bn(n,t,e){let i=n.getCode(),r=t.getCode();i in Mn||(Mn[i]={}),Mn[i][r]=e}function As(n,t){return n in Mn&&t in Mn[n]?Mn[n][t]:null}var Ps=.9996,ue=.00669438,Fs=ue*ue,Ds=Fs*ue,en=ue/(1-ue),Iu=Math.sqrt(1-ue),Ln=(1-Iu)/(1+Iu),Au=Ln*Ln,Sa=Au*Ln,Ta=Sa*Ln,Pu=Ta*Ln,Ou=1-ue/4-3*Fs/64-5*Ds/256,Yg=3*ue/8+3*Fs/32+45*Ds/1024,Kg=15*Fs/256+45*Ds/1024,Vg=35*Ds/3072,Bg=3/2*Ln-27/32*Sa+269/512*Pu,Zg=21/16*Au-55/32*Ta,Hg=151/96*Sa-417/128*Pu,qg=1097/512*Ta,Os=6378137;function $g(n,t,e){let i=n-5e5,o=(e.north?t:t-1e7)/Ps/(Os*Ou),a=o+Bg*Math.sin(2*o)+Zg*Math.sin(4*o)+Hg*Math.sin(6*o)+qg*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-ue*h,p=Math.sqrt(1-ue*h),m=Os/p,_=(1-ue)/g,y=en*c**2,E=y*y,x=i/(m*Ps),C=x*x,T=C*x,I=T*x,S=I*x,w=S*x,M=a-u/_*(C/2-I/24*(5+3*d+10*y-4*E-9*en))+w/720*(61+90*d+298*y+45*f-252*en-3*E),N=(x-T/6*(1+2*d+y)+S/120*(5-2*y+28*d-3*E+8*en+24*f))/c;return N=Rs(N+Re(Fu(e.number)),-Math.PI,Math.PI),[Cs(N),Cs(M)]}var Mu=-80,bu=84,Jg=-180,Qg=180;function tm(n,t,e){n=Rs(n,Jg,Qg),t<Mu?t=Mu:t>bu&&(t=bu);let i=Re(t),r=Math.sin(i),s=Math.cos(i),o=r/s,a=o*o,l=a*a,h=Re(n),c=Fu(e.number),u=Re(c),d=Os/Math.sqrt(1-ue*r**2),f=en*s**2,g=s*Rs(h-u,-Math.PI,Math.PI),p=g*g,m=p*g,_=m*g,y=_*g,E=y*g,x=Os*(Ou*i-Yg*Math.sin(2*i)+Kg*Math.sin(4*i)-Vg*Math.sin(6*i)),C=Ps*d*(g+m/6*(1-a+f)+y/120*(5-18*a+l+72*f-58*en))+5e5,T=Ps*(x+d*o*(p/2+_/24*(5-a+9*f+4*f**2)+E/720*(61-58*a+l+600*f-330*en)));return e.north||(T+=1e7),[C,T]}function Fu(n){return(n-1)*6-180+3}var em=[/^EPSG:(\d+)$/,/^urn:ogc:def:crs:EPSG::(\d+)$/,/^http:\/\/www\.opengis\.net\/def\/crs\/EPSG\/0\/(\d+)$/];function Du(n){let t=0;for(let r of em){let s=n.match(r);if(s){t=parseInt(s[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 Lu(n,t){return function(e,i,r,s){let o=e.length;r=r>1?r:2,s=s??r,i||(r>2?i=e.slice():i=new Array(o));for(let a=0;a<o;a+=s){let l=e[a],h=e[a+1],c=n(l,h,t);i[a]=c[0],i[a+1]=c[1]}return i}}function ku(n){return Du(n)?new vn({code:n,units:"m"}):null}function Nu(n){let t=Du(n.getCode());return t?{forward:Lu(tm,t),inverse:Lu($g,t)}:null}var im=[Nu],nm=[ku];var Ia=!0;function ba(n){Ia=!(n===void 0?!0:n)}function La(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 zu(n,t){if(t!==void 0&&n!==t){for(let e=0,i=n.length;e<i;++e)t[e]=n[e];n=t}return n}function Ma(n){vu(n.getCode(),n),bn(n,n,La)}function rm(n){n.forEach(Ma)}function q(n){if(typeof n!="string")return n;let t=Tu(n);if(t)return t;for(let e of nm){let i=e(n);if(i)return i}return null}function An(n,t,e,i){n=q(n);let r,s=n.getPointResolutionFunc();if(s){if(r=s(t,e),i&&i!==n.getUnits()){let o=n.getMetersPerUnit();o&&(r=r*o/Se[i])}}else{let o=n.getUnits();if(o=="degrees"&&!i||i=="degrees")r=t;else{let a=Ye(n,q("EPSG:4326"));if(!a&&o!=="degrees")r=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);let c=xa(h.slice(0,2),h.slice(2,4)),u=xa(h.slice(4,6),h.slice(6,8));r=(c+u)/2}let l=i?Se[i]:n.getMetersPerUnit();l!==void 0&&(r/=l)}}return r}function Gu(n){rm(n),n.forEach(function(t){n.forEach(function(e){t!==e&&bn(t,e,La)})})}function sm(n,t,e,i){n.forEach(function(r){t.forEach(function(s){bn(r,s,e),bn(s,r,i)})})}function ks(n,t){return n?typeof n=="string"?q(n):n:q(t)}function ju(n){return(function(t,e,i,r){let s=t.length;i=i!==void 0?i:2,r=r??i,e=e!==void 0?e:new Array(s);for(let o=0;o<s;o+=r){let a=n(t.slice(o,o+i)),l=a.length;for(let h=0,c=r;h<c;++h)e[o+h]=h>=l?t[o+h]:a[h]}return e})}function nn(n,t){return ba(),de(n,"EPSG:4326",t!==void 0?t:"EPSG:3857")}function Wu(n,t){let e=de(n,t!==void 0?t:"EPSG:3857","EPSG:4326"),i=e[0];return(i<-180||i>180)&&(e[0]=Wt(i+180,360)-180),e}function ve(n,t){if(n===t)return!0;let e=n.getUnits()===t.getUnits();return(n.getCode()===t.getCode()||Ye(n,t)===La)&&e}function Ye(n,t){let e=n.getCode(),i=t.getCode(),r=As(e,i);if(r)return r;let s=null,o=null;for(let l of im)s||(s=l(n)),o||(o=l(t));if(!s&&!o)return null;let a="EPSG:4326";if(o)if(s)r=va(s.inverse,o.forward);else{let l=As(e,a);l&&(r=va(l,o.forward))}else{let l=As(a,i);l&&(r=va(s.inverse,l))}return r&&(Ma(n),Ma(t),bn(n,t,r)),r}function va(n,t){return function(e,i,r,s){return i=n(e,i,r,s),t(i,i,r,s)}}function li(n,t){let e=q(n),i=q(t);return Ye(e,i)}function de(n,t,e){let i=li(t,e);if(!i){let r=q(t).getCode(),s=q(e).getCode();throw new Error(`No transform available between ${r} and ${s}`)}return i(n,void 0,n.length)}function fr(n,t,e,i){let r=li(t,e);return fu(n,r,void 0,i)}var Te=null;function hi(){return Te}function gr(n,t){return Te?de(n,t,Te):n}function Ie(n,t){return Te?de(n,Te,t):(Ia&&!tn(n,[0,0])&&n[0]>=-180&&n[0]<=180&&n[1]>=-90&&n[1]<=90&&(Ia=!1,bs("Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates.")),n)}function Mi(n,t){return Te?fr(n,t,Te):n}function Gt(n,t){return Te?fr(n,Te,t):n}function Xu(n,t){if(!Te)return n;let e=q(t).getMetersPerUnit(),i=Te.getMetersPerUnit();return e&&i?n*e/i:n}function om(){Gu(Ca),Gu(Ra),sm(Ra,Ca,Ru,wu)}om();var wx=new Array(6);function Tt(){return[1,0,0,1,0,0]}function Uu(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 ht(n,t){let 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 Et(n,t,e,i,r,s,o,a){let l=Math.sin(s),h=Math.cos(s);return n[0]=i*h,n[1]=r*l,n[2]=-i*l,n[3]=r*h,n[4]=o*i*h-a*i*l+t,n[5]=o*r*l+a*r*h+e,n}function Gs(n,t){let e=am(t);V(e!==0,"Transformation matrix cannot be inverted");let i=t[0],r=t[1],s=t[2],o=t[3],a=t[4],l=t[5];return n[0]=o/e,n[1]=-r/e,n[2]=-s/e,n[3]=i/e,n[4]=(s*l-o*a)/e,n[5]=-(i*l-r*a)/e,n}function am(n){return n[0]*n[3]-n[1]*n[2]}var lm=[1e5,1e5,1e5,1e5,2,2];function Yu(n){return"matrix("+n.join(", ")+")"}function Ns(n){return n.substring(7,n.length-1).split(",").map(parseFloat)}function Ku(n,t){let e=Ns(n),i=Ns(t);for(let r=0;r<6;++r)if(Math.round((e[r]-i[r])*lm[r])!==0)return!1;return!0}function Kt(n,t,e,i,r,s,o){s=s||[],o=o||2;let a=0;for(let l=t;l<e;l+=i){let h=n[l],c=n[l+1];s[a++]=r[0]*h+r[2]*c+r[4],s[a++]=r[1]*h+r[3]*c+r[5];for(let u=2;u<o;u++)s[a++]=n[l+u]}return s&&s.length!=a&&(s.length=a),s}function zs(n,t,e,i,r,s,o){o=o||[];let a=Math.cos(r),l=Math.sin(r),h=s[0],c=s[1],u=0;for(let d=t;d<e;d+=i){let 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 p=d+2;p<d+i;++p)o[u++]=n[p]}return o&&o.length!=u&&(o.length=u),o}function Vu(n,t,e,i,r,s,o,a){a=a||[];let l=o[0],h=o[1],c=0;for(let u=t;u<e;u+=i){let d=n[u]-l,f=n[u+1]-h;a[c++]=l+r*d,a[c++]=h+s*f;for(let g=u+2;g<u+i;++g)a[c++]=n[g]}return a&&a.length!=c&&(a.length=c),a}function Bu(n,t,e,i,r,s,o){o=o||[];let a=0;for(let l=t;l<e;l+=i){o[a++]=n[l]+r,o[a++]=n[l+1]+s;for(let h=l+2;h<l+i;++h)o[a++]=n[h]}return o&&o.length!=a&&(o.length=a),o}var Zu=Tt(),hm=[NaN,NaN],Aa=class extends pt{constructor(){super(),this.extent_=ct(),this.extentRevision_=-1,this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=0,this.simplifyTransformedInternal=ms((t,e,i)=>{if(!i)return this.getSimplifiedGeometry(e);let r=this.clone();return r.applyTransform(i),r.getSimplifiedGeometry(e)})}simplifyTransformed(t,e){return this.simplifyTransformedInternal(this.getRevision(),t,e)}clone(){return F()}closestPointXY(t,e,i,r){return F()}containsXY(t,e){return this.closestPointXY(t,e,hm,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 F()}getExtent(t){if(this.extentRevision_!=this.getRevision()){let e=this.computeExtent(this.extent_);(isNaN(e[0])||isNaN(e[1]))&&si(e),this.extentRevision_=this.getRevision()}return uu(this.extent_,t)}rotate(t,e){F()}scale(t,e,i){F()}simplify(t){return this.getSimplifiedGeometry(t*t)}getSimplifiedGeometry(t){return F()}getType(){return F()}applyTransform(t){F()}intersectsExtent(t){return F()}translate(t,e){F()}transform(t,e){let i=q(t),r=i.getUnits()=="tile-pixels"?function(s,o,a){let l=i.getExtent(),h=i.getWorldExtent(),c=et(h)/et(l);Et(Zu,h[0],h[3],c,-c,0,0,0);let u=Kt(s,0,s.length,a,Zu,o),d=li(i,e);return d?d(u,u,a):u}:li(i,e);return this.applyTransform(r),this}},js=Aa;var Pa=class extends js{constructor(){super(),this.layout="XY",this.stride=2,this.flatCoordinates}computeExtent(t){return En(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinates(){return F()}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;let 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=Hu(t),this.layout=t,this.flatCoordinates=e}setCoordinates(t,e){F()}setLayout(t,e,i){let r;if(t)r=Hu(t);else{for(let s=0;s<i;++s){if(e.length===0){this.layout="XY",this.stride=2;return}e=e[0]}r=e.length,t=bi(r)}this.layout=t,this.stride=r}applyTransform(t){this.flatCoordinates&&(t(this.flatCoordinates,this.flatCoordinates,this.layout.startsWith("XYZ")?3:2,this.stride),this.changed())}rotate(t,e){let i=this.getFlatCoordinates();if(i){let r=this.getStride();zs(i,0,i.length,r,t,e,i),this.changed()}}scale(t,e,i){e===void 0&&(e=t),i||(i=St(this.getExtent()));let r=this.getFlatCoordinates();if(r){let s=this.getStride();Vu(r,0,r.length,s,t,e,i,r),this.changed()}}translate(t,e){let i=this.getFlatCoordinates();if(i){let r=this.getStride();Bu(i,0,i.length,r,t,e,i),this.changed()}}};function bi(n){let t;return n==2?t="XY":n==3?t="XYZ":n==4&&(t="XYZM"),t}function Hu(n){let t;return n=="XY"?t=2:n=="XYZ"||n=="XYM"?t=3:n=="XYZM"&&(t=4),t}function qu(n,t,e){let i=n.getFlatCoordinates();if(!i)return null;let r=n.getStride();return Kt(i,0,i.length,r,t,e)}var Vt=Pa;function Oa(n,t,e,i){let r=0,s=n[e-i],o=n[e-i+1],a=0,l=0;for(;t<e;t+=i){let h=n[t]-s,c=n[t+1]-o;r+=l*h-a*c,a=h,l=c}return r/2}function Fa(n,t,e,i){let r=0;for(let s=0,o=e.length;s<o;++s){let a=e[s];r+=Oa(n,t,a,i),t=a}return r}function $u(n,t,e,i){let r=0;for(let s=0,o=e.length;s<o;++s){let a=e[s];r+=Fa(n,t,a,i),t=a[a.length-1]}return r}function Ju(n,t,e,i,r,s,o){let a=n[t],l=n[t+1],h=n[e]-a,c=n[e+1]-l,u;if(h===0&&c===0)u=t;else{let d=((r-a)*h+(s-l)*c)/(h*h+c*c);if(d>1)u=e;else if(d>0){for(let f=0;f<i;++f)o[f]=bt(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 mr(n,t,e,i,r){let s=n[t],o=n[t+1];for(t+=i;t<e;t+=i){let a=n[t],l=n[t+1],h=Ce(s,o,a,l);h>r&&(r=h),s=a,o=l}return r}function pr(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];r=mr(n,t,a,i,r),t=a}return r}function Qu(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];r=pr(n,t,a,i,r),t=a[a.length-1]}return r}function _r(n,t,e,i,r,s,o,a,l,h,c){if(t==e)return h;let u,d;if(r===0){if(d=Ce(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(Ju(n,f-i,f,i,o,a,c),d=Ce(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))/r|0,1);if(s&&(Ju(n,e-i,t,i,o,a,c),d=Ce(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 yr(n,t,e,i,r,s,o,a,l,h,c){c=c||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){let f=e[u];h=_r(n,t,f,i,r,s,o,a,l,h,c),t=f}return h}function td(n,t,e,i,r,s,o,a,l,h,c){c=c||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){let f=e[u];h=yr(n,t,f,i,r,s,o,a,l,h,c),t=f[f.length-1]}return h}function ed(n,t,e,i){for(let r=0,s=e.length;r<s;++r)n[t++]=e[r];return t}function rn(n,t,e,i){for(let r=0,s=e.length;r<s;++r){let o=e[r];for(let a=0;a<i;++a)n[t++]=o[a]}return t}function Li(n,t,e,i,r){r=r||[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=rn(n,t,e[o],i);r[s++]=l,t=l}return r.length=s,r}function Ws(n,t,e,i,r){r=r||[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=Li(n,t,e[o],i,r[s]);l.length===0&&(l[0]=t),r[s++]=l,t=l[l.length-1]}return r.length=s,r}function fe(n,t,e,i,r){r=r!==void 0?r:[];let s=0;for(let o=t;o<e;o+=i)r[s++]=n.slice(o,o+i);return r.length=s,r}function Ai(n,t,e,i,r){r=r!==void 0?r:[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=e[o];r[s++]=fe(n,t,l,i,r[s]),t=l}return r.length=s,r}function xr(n,t,e,i,r){r=r!==void 0?r:[];let s=0;for(let o=0,a=e.length;o<a;++o){let l=e[o];r[s++]=l.length===1&&l[0]===t?[]:Ai(n,t,l,i,r[s]),t=l[l.length-1]}return r.length=s,r}function sn(n,t,e,i,r,s,o){let a=(e-t)/i;if(a<3){for(;t<e;t+=i)s[o++]=n[t],s[o++]=n[t+1];return o}let l=new Array(a);l[0]=1,l[a-1]=1;let h=[t,e-i],c=0;for(;h.length>0;){let u=h.pop(),d=h.pop(),f=0,g=n[d],p=n[d+1],m=n[u],_=n[u+1];for(let y=d+i;y<u;y+=i){let E=n[y],x=n[y+1],C=au(E,x,g,p,m,_);C>f&&(c=y,f=C)}f>r&&(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]&&(s[o++]=n[t+u*i],s[o++]=n[t+u*i+1]);return o}function Xs(n,t,e,i,r,s,o,a){for(let l=0,h=e.length;l<h;++l){let c=e[l];o=sn(n,t,c,i,r,s,o),a.push(o),t=c}return o}function Pi(n,t){return t*Math.round(n/t)}function cm(n,t,e,i,r,s,o){if(t==e)return o;let a=Pi(n[t],r),l=Pi(n[t+1],r);t+=i,s[o++]=a,s[o++]=l;let h,c;do if(h=Pi(n[t],r),c=Pi(n[t+1],r),t+=i,t==e)return s[o++]=h,s[o++]=c,o;while(h==a&&c==l);for(;t<e;){let u=Pi(n[t],r),d=Pi(n[t+1],r);if(t+=i,u==h&&d==c)continue;let f=h-a,g=c-l,p=u-a,m=d-l;if(f*m==g*p&&(f<0&&p<f||f==p||f>0&&p>f)&&(g<0&&m<g||g==m||g>0&&m>g)){h=u,c=d;continue}s[o++]=h,s[o++]=c,a=h,l=c,h=u,c=d}return s[o++]=h,s[o++]=c,o}function Er(n,t,e,i,r,s,o,a){for(let l=0,h=e.length;l<h;++l){let c=e[l];o=cm(n,t,c,i,r,s,o),a.push(o),t=c}return o}function id(n,t,e,i,r,s,o,a){for(let l=0,h=e.length;l<h;++l){let c=e[l],u=[];o=Er(n,t,c,i,r,s,o,u),a.push(u),t=c[c.length-1]}return o}var Da=class n extends Vt{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,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(mr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),_r(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!0,t,e,i,r))}getArea(){return Oa(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinates(){return fe(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getSimplifiedGeometryInternal(t){let e=[];return e.length=sn(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=rn(this.flatCoordinates,0,t,this.stride),this.changed()}},ka=Da;var Na=class n extends Vt{constructor(t,e){super(),this.setCoordinates(t,e)}clone(){let t=new n(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,r){let s=this.flatCoordinates,o=Ce(t,e,s[0],s[1]);if(o<r){let a=this.stride;for(let l=0;l<a;++l)i[l]=s[l];return i.length=a,o}return r}getCoordinates(){return this.flatCoordinates.slice()}computeExtent(t){return Ts(this.flatCoordinates,t)}getType(){return"Point"}intersectsExtent(t){return hr(t,this.flatCoordinates[0],this.flatCoordinates[1])}setCoordinates(t,e){this.setLayout(e,t,0),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=ed(this.flatCoordinates,0,t,this.stride),this.changed()}},Oi=Na;function nd(n,t,e,i,r){return!Is(r,function(o){return!Fi(n,t,e,i,o[0],o[1])})}function Fi(n,t,e,i,r,s){let o=0,a=n[e-i],l=n[e-i+1];for(;t<e;t+=i){let h=n[t],c=n[t+1];l<=s?c>s&&(h-a)*(s-l)-(r-a)*(c-l)>0&&o++:c<=s&&(h-a)*(s-l)-(r-a)*(c-l)<0&&o--,a=h,l=c}return o!==0}function Cr(n,t,e,i,r,s){if(e.length===0||!Fi(n,t,e[0],i,r,s))return!1;for(let o=1,a=e.length;o<a;++o)if(Fi(n,e[o-1],e[o],i,r,s))return!1;return!0}function rd(n,t,e,i,r,s){if(e.length===0)return!1;for(let o=0,a=e.length;o<a;++o){let l=e[o];if(Cr(n,t,l,i,r,s))return!0;t=l[l.length-1]}return!1}function Rr(n,t,e,i,r,s,o){let a,l,h,c,u,d,f,g=r[s+1],p=[];for(let y=0,E=e.length;y<E;++y){let 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,p.push(h)),c=u,d=f}let m=NaN,_=-1/0;for(p.sort(jt),c=p[0],a=1,l=p.length;a<l;++a){u=p[a];let y=Math.abs(u-c);y>_&&(h=(c+u)/2,Cr(n,t,e,i,h,g)&&(m=h,_=y)),c=u}return isNaN(m)&&(m=r[s]),o?(o.push(m,g,_),o):[m,g,_]}function Us(n,t,e,i,r){let s=[];for(let o=0,a=e.length;o<a;++o){let l=e[o];s=Rr(n,t,l,i,r,2*o,s),t=l[l.length-1]}return s}function Ys(n,t,e,i,r){let s;for(t+=i;t<e;t+=i)if(s=r(n.slice(t-i,t),n.slice(t,t+i)),s)return s;return!1}function wr(n,t,e,i,r,s){return s=s??ma(ct(),n,t,e,i),lt(r,s)?s[0]>=r[0]&&s[2]<=r[2]||s[1]>=r[1]&&s[3]<=r[3]?!0:Ys(n,t,e,i,function(o,a){return du(r,o,a)}):!1}function sd(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){if(wr(n,t,e[s],i,r))return!0;t=e[s]}return!1}function Ga(n,t,e,i,r){return!!(wr(n,t,e,i,r)||Fi(n,t,e,i,r[0],r[1])||Fi(n,t,e,i,r[0],r[3])||Fi(n,t,e,i,r[2],r[1])||Fi(n,t,e,i,r[2],r[3]))}function za(n,t,e,i,r){if(!Ga(n,t,e[0],i,r))return!1;if(e.length===1)return!0;for(let s=1,o=e.length;s<o;++s)if(nd(n,e[s-1],e[s],i,r)&&!wr(n,e[s-1],e[s],i,r))return!1;return!0}function od(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];if(za(n,t,a,i,r))return!0;t=a[a.length-1]}return!1}function ad(n,t,e,i){for(;t<e-i;){for(let r=0;r<i;++r){let s=n[t+r];n[t+r]=n[e-i+r],n[e-i+r]=s}t+=i,e-=i}}function ja(n,t,e,i){let r=0,s=n[e-i],o=n[e-i+1];for(;t<e;t+=i){let a=n[t],l=n[t+1];r+=(a-s)*(l+o),s=a,o=l}return r===0?void 0:r>0}function Sr(n,t,e,i,r){r=r!==void 0?r:!1;for(let s=0,o=e.length;s<o;++s){let a=e[s],l=ja(n,t,a,i);if(s===0){if(r&&l||!r&&!l)return!1}else if(r&&!l||!r&&l)return!1;t=a}return!0}function Ks(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s){let a=e[s];if(!Sr(n,t,a,i,r))return!1;a.length&&(t=a[a.length-1])}return!0}function Pn(n,t,e,i,r){r=r!==void 0?r:!1;for(let s=0,o=e.length;s<o;++s){let a=e[s],l=ja(n,t,a,i);(s===0?r&&l||!r&&!l:r&&!l||!r&&l)&&ad(n,t,a,i),t=a}return t}function Tr(n,t,e,i,r){for(let s=0,o=e.length;s<o;++s)t=Pn(n,t,e[s],i,r);return t}function ld(n,t){let e=[],i=0,r=0,s;for(let o=0,a=t.length;o<a;++o){let l=t[o],h=ja(n,i,l,2);if(s===void 0&&(s=h),h===s)e.push(t.slice(r,o+1));else{if(e.length===0)continue;e[e.length-1].push(t[r])}r=o+1,i=l}return e}var Vs=class n extends Vt{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?It(this.flatCoordinates,t.getFlatCoordinates()):this.flatCoordinates=t.getFlatCoordinates().slice(),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(pr(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),yr(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!0,t,e,i,r))}containsXY(t,e){return Cr(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,e)}getArea(){return Fa(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),Pn(e,0,this.ends_,this.stride,t)):e=this.flatCoordinates,Ai(e,0,this.ends_,this.stride)}getEnds(){return this.ends_}getFlatInteriorPoint(){if(this.flatInteriorPointRevision_!=this.getRevision()){let t=St(this.getExtent());this.flatInteriorPoint_=Rr(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,0),this.flatInteriorPointRevision_=this.getRevision()}return this.flatInteriorPoint_}getInteriorPoint(){return new Oi(this.getFlatInteriorPoint(),"XYM")}getLinearRingCount(){return this.ends_.length}getLinearRing(t){return t<0||this.ends_.length<=t?null:new ka(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLinearRings(){let t=this.layout,e=this.flatCoordinates,i=this.ends_,r=[],s=0;for(let o=0,a=i.length;o<a;++o){let l=i[o],h=new ka(e.slice(s,l),t);r.push(h),s=l}return r}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){let t=this.flatCoordinates;Sr(t,0,this.ends_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=Pn(this.orientedFlatCoordinates_,0,this.ends_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){let e=[],i=[];return e.length=Er(this.flatCoordinates,0,this.ends_,this.stride,Math.sqrt(t),e,0,i),new n(e,"XY",i)}getType(){return"Polygon"}intersectsExtent(t){return za(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,2),this.flatCoordinates||(this.flatCoordinates=[]);let i=Li(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}},Di=Vs;function Wa(n){if(Yt(n))throw new Error("Cannot create polygon from empty extent");let t=n[0],e=n[1],i=n[2],r=n[3],s=[t,e,t,r,i,r,i,e,t,e];return new Vs(s,"XY",[s.length])}function Xa(n,t,e,i){let r=W(t)/e[0],s=et(t)/e[1];return i?Math.min(n,Math.max(r,s)):Math.min(n,Math.min(r,s))}function Ua(n,t,e){let i=Math.min(n,t),r=50;return i*=Math.log(1+r*Math.max(0,n/t-1))/r+1,e&&(i=Math.max(i,e),i/=Math.log(1+r*Math.max(0,e/n-1))/r+1),Q(i,e/2,t*2)}function hd(n,t,e,i){return t=t!==void 0?t:!0,(function(r,s,o,a){if(r!==void 0){let l=n[0],h=n[n.length-1],c=e?Xa(l,e,o,i):l;if(a)return t?Ua(r,c,h):Q(r,h,c);let u=Math.min(c,r),d=Math.floor(Ri(n,u,s));return n[d]>c&&d<n.length-1?n[d+1]:n[d]}})}function cd(n,t,e,i,r,s){return i=i!==void 0?i:!0,e=e!==void 0?e:0,(function(o,a,l,h){if(o!==void 0){let c=r?Xa(t,r,l,s):t;if(h)return i?Ua(o,c,e):Q(o,e,c);let u=1e-9,d=Math.ceil(Math.log(t/c)/Math.log(n)-u),f=-a*(.5-u)+.5,g=Math.min(c,o),p=Math.floor(Math.log(t/g)/Math.log(n)+f),m=Math.max(d,p),_=t/Math.pow(n,m);return Q(_,e,c)}})}function Ya(n,t,e,i,r){return e=e!==void 0?e:!0,(function(s,o,a,l){if(s!==void 0){let h=i?Xa(n,i,a,r):n;return!e||!l?Q(s,t,h):Ua(s,h,t)}})}function On(n){if(n!==void 0)return 0}function Ka(n){if(n!==void 0)return n}function ud(n){let 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 dd(n){let t=n===void 0?Re(5):n;return(function(e,i){return i||e===void 0?e:Math.abs(e)<=t?0:e})}var Va=0,Za=class extends pt{constructor(t){super(),this.on,this.once,this.un,t=Object.assign({},t),this.hints_=[0,0],this.animations_=[],this.updateAnimationKey_,this.projection_=ks(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&&ba(),t.center&&(t.center=Ie(t.center,this.projection_)),t.extent&&(t.extent=Gt(t.extent,this.projection_)),this.applyOptions_(t)}applyOptions_(t){let e=Object.assign({},t);for(let a in ae)delete e[a];this.setProperties(e,!0);let 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;let r=um(t),s=i.constraint,o=fm(t);this.constraints_={center:r,resolution:s,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;let i=this.getCenterInternal();if(i){let r=t||[0,0,0,0];e=e||[0,0,0,0];let s=this.getResolution(),o=s/2*(r[3]-e[3]+e[1]-r[1]),a=s/2*(r[0]-e[0]+e[2]-r[2]);this.setCenterInternal([i[0]+o,i[1]-a])}}getUpdatedOptions_(t){let 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);let e=new Array(arguments.length);for(let i=0;i<e.length;++i){let r=arguments[i];r.center&&(r=Object.assign({},r),r.center=Ie(r.center,this.getProjection())),r.anchor&&(r=Object.assign({},r),r.anchor=Ie(r.anchor,this.getProjection())),e[i]=r}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 r=0;for(;r<e&&!this.isDef();++r){let c=arguments[r];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(r===e){i&&Bs(i,!0);return}let s=Date.now(),o=this.targetCenter_.slice(),a=this.targetResolution_,l=this.targetRotation_,h=[];for(;r<e;++r){let c=arguments[r],u={start:s,complete:!1,anchor:c.anchor,duration:c.duration!==void 0?c.duration:1e3,easing:c.easing||xu,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;let d=Wt(c.rotation-l+Math.PI,2*Math.PI)-Math.PI;u.targetRotation=l+d,l=u.targetRotation}gm(u)?u.complete=!0:s+=u.duration,h.push(u)}this.animations_.push(h),this.setHint(dt.ANIMATING,1),this.updateAnimations_()}getAnimating(){return this.hints_[dt.ANIMATING]>0}getInteracting(){return this.hints_[dt.INTERACTING]>0}cancelAnimations(){this.setHint(dt.ANIMATING,-this.hints_[dt.ANIMATING]);let t;for(let e=0,i=this.animations_.length;e<i;++e){let r=this.animations_[e];if(r[0].callback&&Bs(r[0].callback,!1),!t)for(let s=0,o=r.length;s<o;++s){let a=r[s];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;let t=Date.now(),e=!1;for(let i=this.animations_.length-1;i>=0;--i){let r=this.animations_[i],s=!0;for(let o=0,a=r.length;o<a;++o){let l=r[o];if(l.complete)continue;let h=t-l.start,c=l.duration>0?h/l.duration:1;c>=1?(l.complete=!0,c=1):s=!1;let u=l.easing(c);if(l.sourceCenter){let d=l.sourceCenter[0],f=l.sourceCenter[1],g=l.targetCenter[0],p=l.targetCenter[1];this.nextCenter_=l.targetCenter;let m=d+u*(g-d),_=f+u*(p-f);this.targetCenter_=[m,_]}if(l.sourceResolution&&l.targetResolution){let d=u===1?l.targetResolution:l.sourceResolution+u*(l.targetResolution-l.sourceResolution);if(l.anchor){let 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){let d=u===1?Wt(l.targetRotation+Math.PI,2*Math.PI)-Math.PI:l.sourceRotation+u*(l.targetRotation-l.sourceRotation);if(l.anchor){let 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(s){this.animations_[i]=null,this.setHint(dt.ANIMATING,-1),this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN;let o=r[0].callback;o&&Bs(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,r=this.getCenterInternal();return r!==void 0&&(i=[r[0]-e[0],r[1]-e[1]],Sn(i,t-this.getRotation()),gu(i,e)),i}calculateCenterZoom(t,e){let i,r=this.getCenterInternal(),s=this.getResolution();if(r!==void 0&&s!==void 0){let o=e[0]-t*(e[0]-r[0])/s,a=e[1]-t*(e[1]-r[1])/s;i=[o,a]}return i}getViewportSize_(t){let e=this.viewportSize_;if(t){let i=e[0],r=e[1];return[Math.abs(i*Math.cos(t))+Math.abs(r*Math.sin(t)),Math.abs(i*Math.sin(t))+Math.abs(r*Math.cos(t))]}return e}setViewportSize(t){this.viewportSize_=Array.isArray(t)?t.slice():[100,100],this.getAnimating()||this.resolveConstraints(0)}getCenter(){let t=this.getCenterInternal();return t&&gr(t,this.getProjection())}getCenterInternal(){return this.get(ae.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){let e=this.calculateExtentInternal(t);return Mi(e,this.getProjection())}calculateExtentInternal(t){t=t||this.getViewportSizeMinusPadding_();let e=this.getCenterInternal();V(e,"The view center is not defined");let i=this.getResolution();V(i!==void 0,"The view resolution is not defined");let r=this.getRotation();return V(r!==void 0,"The view rotation is not defined"),oi(e,i,r,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(ae.RESOLUTION)}getResolutions(){return this.resolutions_}getResolutionForExtent(t,e){return this.getResolutionForExtentInternal(Gt(t,this.getProjection()),e)}getResolutionForExtentInternal(t,e){e=e||this.getViewportSizeMinusPadding_();let i=W(t)/e[0],r=et(t)/e[1];return Math.max(i,r)}getResolutionForValueFunction(t){t=t||2;let e=this.getConstrainedResolution(this.maxResolution_),i=this.minResolution_,r=Math.log(e/i)/Math.log(t);return(function(s){return e/Math.pow(t,s*r)})}getRotation(){return this.get(ae.ROTATION)}getValueForResolutionFunction(t){let e=Math.log(t||2),i=this.getConstrainedResolution(this.maxResolution_),r=this.minResolution_,s=Math.log(i/r)/e;return(function(o){return Math.log(i/o)/e/s})}getViewportSizeMinusPadding_(t){let e=this.getViewportSize_(t),i=this.padding_;return i&&(e=[e[0]-i[1]-i[3],e[1]-i[0]-i[2]]),e}getState(){let t=this.getProjection(),e=this.getResolution(),i=this.getRotation(),r=this.getCenterInternal(),s=this.padding_;if(s){let o=this.getViewportSizeMinusPadding_();r=Ba(r,this.getViewportSize_(),[o[0]/2+s[3],o[1]/2+s[0]],e,i)}return{center:r.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,e=this.getResolution();return e!==void 0&&(t=this.getZoomForResolution(e)),t}getZoomForResolution(t){let e=this.minZoom_||0,i,r;if(this.resolutions_){let s=Ri(this.resolutions_,t,1);e=s,i=this.resolutions_[s],s==this.resolutions_.length-1?r=2:r=i/this.resolutions_[s+1]}else i=this.maxResolution_,r=this.zoomFactor_;return e+Math.log(i/t)/Math.log(r)}getResolutionForZoom(t){if(this.resolutions_?.length){if(this.resolutions_.length===1)return this.resolutions_[0];let e=Q(Math.floor(t),0,this.resolutions_.length-2),i=this.resolutions_[e]/this.resolutions_[e+1];return this.resolutions_[e]/Math.pow(i,Q(t-e,0,1))}return this.maxResolution_/Math.pow(this.zoomFactor_,t-this.minZoom_)}fit(t,e){let i;if(V(Array.isArray(t)||typeof t.getSimplifiedGeometry=="function","Invalid extent or geometry provided as `geometry`"),Array.isArray(t)){V(!Yt(t),"Cannot fit empty extent provided as `geometry`");let r=Gt(t,this.getProjection());i=Wa(r)}else if(t.getType()==="Circle"){let r=Gt(t.getExtent(),this.getProjection());i=Wa(r),i.rotate(this.getRotation(),St(r))}else{let r=hi();r?i=t.clone().transform(r,this.getProjection()):i=t}this.fitInternal(i,e)}rotatedExtentForGeometry(t){let e=this.getRotation(),i=Math.cos(e),r=Math.sin(-e),s=t.getFlatCoordinates(),o=t.getStride(),a=1/0,l=1/0,h=-1/0,c=-1/0;for(let u=0,d=s.length;u<d;u+=o){let f=s[u]*i-s[u+1]*r,g=s[u]*r+s[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_());let r=e.padding!==void 0?e.padding:[0,0,0,0],s=e.nearest!==void 0?e.nearest:!1,o;e.minResolution!==void 0?o=e.minResolution:e.maxZoom!==void 0?o=this.getResolutionForZoom(e.maxZoom):o=0;let a=this.rotatedExtentForGeometry(t),l=this.getResolutionForExtentInternal(a,[i[0]-r[1]-r[3],i[1]-r[0]-r[2]]);l=isNaN(l)?o:Math.max(l,o),l=this.getConstrainedResolution(l,s?0:1);let h=this.getRotation(),c=Math.sin(h),u=Math.cos(h),d=St(a);d[0]+=(r[1]-r[3])/2*l,d[1]+=(r[0]-r[2])/2*l;let f=d[0]*u-d[1]*c,g=d[1]*u+d[0]*c,p=this.getConstrainedCenter([f,g],l),m=e.callback?e.callback:ni;e.duration!==void 0?this.animateInternal({resolution:l,center:p,duration:e.duration,easing:e.easing},m):(this.targetResolution_=l,this.targetCenter_=p,this.applyTargetState_(!1,!0),Bs(m,!0))}centerOn(t,e,i){this.centerOnInternal(Ie(t,this.getProjection()),e,i)}centerOnInternal(t,e,i){this.setCenterInternal(Ba(t,e,i,this.getResolution(),this.getRotation()))}calculateCenterShift(t,e,i,r){let s,o=this.padding_;if(o&&t){let a=this.getViewportSizeMinusPadding_(-i),l=Ba(t,r,[a[0]/2+o[3],a[1]/2+o[0]],e,i);s=[t[0]-l[0],t[1]-l[1]]}return s}isDef(){return!!this.getCenterInternal()&&this.getResolution()!==void 0}adjustCenter(t){let e=gr(this.targetCenter_,this.getProjection());this.setCenter([e[0]+t[0],e[1]+t[1]])}adjustCenterInternal(t){let e=this.targetCenter_;this.setCenterInternal([e[0]+t[0],e[1]+t[1]])}adjustResolution(t,e){e=e&&Ie(e,this.getProjection()),this.adjustResolutionInternal(t,e)}adjustResolutionInternal(t,e){let i=this.getAnimating()||this.getInteracting(),r=this.getViewportSize_(this.getRotation()),s=this.constraints_.resolution(this.targetResolution_*t,0,r,i);e&&(this.targetCenter_=this.calculateCenterZoom(s,e)),this.targetResolution_*=t,this.applyTargetState_()}adjustZoom(t,e){this.adjustResolution(Math.pow(this.zoomFactor_,-t),e)}adjustRotation(t,e){e&&(e=Ie(e,this.getProjection())),this.adjustRotationInternal(t,e)}adjustRotationInternal(t,e){let i=this.getAnimating()||this.getInteracting(),r=this.constraints_.rotation(this.targetRotation_+t,i);e&&(this.targetCenter_=this.calculateCenterRotate(r,e)),this.targetRotation_+=t,this.applyTargetState_()}setCenter(t){this.setCenterInternal(t&&Ie(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){let i=this.getAnimating()||this.getInteracting()||e,r=this.constraints_.rotation(this.targetRotation_,i),s=this.getViewportSize_(r),o=this.constraints_.resolution(this.targetResolution_,0,s,i),a=this.constraints_.center(this.targetCenter_,o,s,i,this.calculateCenterShift(this.targetCenter_,o,r,s));this.get(ae.ROTATION)!==r&&this.set(ae.ROTATION,r),this.get(ae.RESOLUTION)!==o&&(this.set(ae.RESOLUTION,o),this.set("zoom",this.getZoom(),!0)),(!a||!this.get(ae.CENTER)||!tn(this.get(ae.CENTER),a))&&this.set(ae.CENTER,a),this.getAnimating()&&!t&&this.cancelAnimations(),this.cancelAnchor_=void 0}resolveConstraints(t,e,i){t=t!==void 0?t:200;let r=e||0,s=this.constraints_.rotation(this.targetRotation_),o=this.getViewportSize_(s),a=this.constraints_.resolution(this.targetResolution_,r,o),l=this.constraints_.center(this.targetCenter_,a,o,!1,this.calculateCenterShift(this.targetCenter_,a,s,o));if(t===0&&!this.cancelAnchor_){this.targetResolution_=a,this.targetRotation_=s,this.targetCenter_=l,this.applyTargetState_();return}i=i||(t===0?this.cancelAnchor_:void 0),this.cancelAnchor_=void 0,(this.getResolution()!==a||this.getRotation()!==s||!this.getCenterInternal()||!tn(this.getCenterInternal(),l))&&(this.getAnimating()&&this.cancelAnimations(),this.animateInternal({rotation:s,center:l,resolution:a,duration:t,easing:ce,anchor:i}))}beginInteraction(){this.resolveConstraints(0),this.setHint(dt.INTERACTING,1)}endInteraction(t,e,i){i=i&&Ie(i,this.getProjection()),this.endInteractionInternal(t,e,i)}endInteractionInternal(t,e,i){this.getInteracting()&&(this.setHint(dt.INTERACTING,-1),this.resolveConstraints(t,e,i))}getConstrainedCenter(t,e){let i=this.getViewportSize_(this.getRotation());return this.constraints_.center(t,e||this.getResolution(),i)}getConstrainedZoom(t,e){let i=this.getResolutionForZoom(t);return this.getZoomForResolution(this.getConstrainedResolution(i,e))}getConstrainedResolution(t,e){e=e||0;let i=this.getViewportSize_(this.getRotation());return this.constraints_.resolution(t,e,i)}};function Bs(n,t){setTimeout(function(){n(t)},0)}function um(n){if(n.extent!==void 0){let e=n.smoothExtentConstraint!==void 0?n.smoothExtentConstraint:!0;return fa(n.extent,n.constrainOnlyCenter,e)}let t=ks(n.projection,"EPSG:3857");if(n.multiWorld!==!0&&t.isGlobal()){let e=t.getExtent().slice();return e[0]=-1/0,e[2]=1/0,fa(e,!1,!1)}return hu}function dm(n){let t,e,i,o=n.minZoom!==void 0?n.minZoom:Va,a=n.maxZoom!==void 0?n.maxZoom:28,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=ks(n.projection,"EPSG:3857"),f=d.getExtent(),g=n.constrainOnlyCenter,p=n.extent;if(!h&&!p&&d.isGlobal()&&(g=!1,p=f),n.resolutions!==void 0){let m=n.resolutions;e=m[o],i=m[a]!==void 0?m[a]:m[m.length-1],n.constrainResolution?t=hd(m,c,!g&&p,u):t=Ya(e,i,c,!g&&p,u)}else{let _=(f?Math.max(W(f),et(f)):360*Se.degrees/d.getMetersPerUnit())/256/Math.pow(2,Va),y=_/Math.pow(2,28-Va);e=n.maxResolution,e!==void 0?o=0:e=_/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=_/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=cd(l,e,i,c,!g&&p,u):t=Ya(e,i,c,!g&&p,u)}return{constraint:t,maxResolution:e,minResolution:i,minZoom:o,zoomFactor:l}}function fm(n){if(n.enableRotation!==void 0?n.enableRotation:!0){let e=n.constrainRotation;return e===void 0||e===!0?dd():e===!1?Ka:typeof e=="number"?ud(e):Ka}return On}function gm(n){return!(n.sourceCenter&&n.targetCenter&&!tn(n.sourceCenter,n.targetCenter)||n.sourceResolution!==n.targetResolution||n.sourceRotation!==n.targetRotation)}function Ba(n,t,e,i,r){let s=Math.cos(-r),o=Math.sin(-r),a=n[0]*s-n[1]*o,l=n[1]*s+n[0]*o;a+=(t[0]/2-e[0])*i,l+=(e[1]-t[1]/2)*i,o=-o;let h=a*s-l*o,c=l*s+a*o;return[h,c]}var Bt=Za;var vr="ol-hidden";var ge="ol-unselectable",Ha="ol-unsupported",ki="ol-control",qa="ol-collapsed",mm=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"),gd=["style","variant","weight","size","lineHeight","family"],Zs={normal:400,bold:700},Hs=function(n){let t=n.match(mm);if(!t)return null;let e={lineHeight:"normal",size:"1.2em",style:"normal",weight:"400",variant:"normal"};for(let i=0,r=gd.length;i<r;++i){let s=t[i+1];s!==void 0&&(e[gd[i]]=typeof s=="string"?s.trim():s)}return isNaN(Number(e.weight))&&e.weight in Zs&&(e.weight=Zs[e.weight]),e.families=e.family.split(/,\s?/).map(i=>i.trim().replace(/^['"]|['"]$/g,"")),e};function nt(n,t,e,i){let r;return e&&e.length?r=e.shift():xt?r=new class extends OffscreenCanvas{style={}}(n??300,t??150):r=document.createElement("canvas"),n&&(r.width=n),t&&(r.height=t),r.getContext("2d",i)}var $a;function Fn(){return $a||($a=nt(1,1)),$a}function on(n){let t=n.canvas;t.width=1,t.height=1,n.clearRect(0,0,1,1)}function Dn(n,t){let e=t.parentNode;e&&e.replaceChild(n,t)}function md(n){for(;n.lastChild;)n.lastChild.remove()}function pd(n,t){let e=n.childNodes;for(let i=0;;++i){let r=e[i],s=t[i];if(!r&&!s)break;if(r!==s){if(!r){n.appendChild(s);continue}if(!s){n.removeChild(r),--i;continue}n.insertBefore(s,r)}}}function qs(){return new Proxy({childNodes:[],appendChild:function(t){return this.childNodes.push(t),t},remove:function(){},removeChild:function(t){let 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){let 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 Me(n){return typeof HTMLCanvasElement<"u"&&n instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&n instanceof OffscreenCanvas}var Ja=class extends pt{constructor(t){super();let 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)B(this.listenerKeys[e]);if(this.listenerKeys.length=0,this.map_=t,t){let e=this.target_??t.getOverlayContainerStopEvent();this.element&&e.appendChild(this.element),this.render!==ni&&this.listenerKeys.push(G(t,Xe.POSTRENDER,this.render,this)),t.render()}}render(t){}setTarget(t){this.target_=typeof t=="string"?document.getElementById(t):t}},me=Ja;var Qa=class extends me{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;let e=t.className!==void 0?t.className:"ol-attribution",i=t.tipLabel!==void 0?t.tipLabel:"Attributions",r=t.expandClassName!==void 0?t.expandClassName:e+"-expand",s=t.collapseLabel!==void 0?t.collapseLabel:"\u203A",o=t.collapseClassName!==void 0?t.collapseClassName:e+"-collapse";typeof s=="string"?(this.collapseLabel_=document.createElement("span"),this.collapseLabel_.textContent=s,this.collapseLabel_.className=o):this.collapseLabel_=s;let a=t.label!==void 0?t.label:"i";typeof a=="string"?(this.label_=document.createElement("span"),this.label_.textContent=a,this.label_.className=r):this.label_=a;let 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(L.CLICK,this.handleClick_.bind(this),!1);let h=e+" "+ge+" "+ki+(this.collapsed_&&this.collapsible_?" "+qa:"")+(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){let e=this.getMap().getAllLayers(),i=new Set(e.flatMap(r=>r.getAttributions(t)));if(this.attributions_!==void 0&&(Array.isArray(this.attributions_)?this.attributions_.forEach(r=>i.add(r)):i.add(this.attributions_)),!this.overrideCollapsible_){let r=!e.some(s=>s.getSource()?.getAttributionsCollapsible()===!1);this.setCollapsible(r)}return Array.from(i)}async updateElement_(t){if(!t){this.renderedVisible_&&(this.element.style.display="none",this.renderedVisible_=!1);return}let e=await Promise.all(this.collectSourceAttributions_(t).map(r=>ps(()=>r))),i=e.length>0;if(this.renderedVisible_!=i&&(this.element.style.display=i?"":"none",this.renderedVisible_=i),!Ot(e,this.renderedAttributions_)){md(this.ulElement_);for(let r=0,s=e.length;r<s;++r){let o=document.createElement("li");o.innerHTML=e[r],this.ulElement_.appendChild(o)}this.renderedAttributions_=e}}handleClick_(t){t.preventDefault(),this.handleToggle_(),this.userCollapsed_=this.collapsed_}handleToggle_(){this.element.classList.toggle(qa),this.collapsed_?Dn(this.collapseLabel_,this.label_):Dn(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)}},Ir=Qa;var tl=class extends me{constructor(t){t=t||{},super({element:document.createElement("div"),render:t.render,target:t.target});let e=t.className!==void 0?t.className:"ol-rotate",i=t.label!==void 0?t.label:"\u21E7",r=t.compassClassName!==void 0?t.compassClassName:"ol-compass";this.label_=null,typeof i=="string"?(this.label_=document.createElement("span"),this.label_.className=r,this.label_.textContent=i):(this.label_=i,this.label_.classList.add(r));let s=t.tipLabel?t.tipLabel:"Reset rotation",o=document.createElement("button");o.className=e+"-reset",o.setAttribute("type","button"),o.title=s,o.appendChild(this.label_),o.addEventListener(L.CLICK,this.handleClick_.bind(this),!1);let a=e+" "+ge+" "+ki,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(vr)}handleClick_(t){t.preventDefault(),this.callResetNorth_!==void 0?this.callResetNorth_():this.resetNorth_()}resetNorth_(){let e=this.getMap().getView();if(!e)return;let i=e.getRotation();i!==void 0&&(this.duration_>0&&i%(2*Math.PI)!==0?e.animate({rotation:0,duration:this.duration_,easing:ce}):e.setRotation(0))}render(t){let e=t.frameState;if(!e)return;let i=e.viewState.rotation;if(i!=this.rotation_){let r="rotate("+i+"rad)";if(this.autoHide_){let s=this.element.classList.contains(vr);!s&&i===0?this.element.classList.add(vr):s&&i!==0&&this.element.classList.remove(vr)}this.label_.style.transform=r}this.rotation_=i}},Mr=tl;var el=class extends me{constructor(t){t=t||{},super({element:document.createElement("div"),target:t.target});let e=t.className!==void 0?t.className:"ol-zoom",i=t.delta!==void 0?t.delta:1,r=t.zoomInClassName!==void 0?t.zoomInClassName:e+"-in",s=t.zoomOutClassName!==void 0?t.zoomOutClassName:e+"-out",o=t.zoomInLabel!==void 0?t.zoomInLabel:"+",a=t.zoomOutLabel!==void 0?t.zoomOutLabel:"\u2013",l=t.zoomInTipLabel!==void 0?t.zoomInTipLabel:"Zoom in",h=t.zoomOutTipLabel!==void 0?t.zoomOutTipLabel:"Zoom out",c=document.createElement("button");c.className=r,c.setAttribute("type","button"),c.title=l,c.appendChild(typeof o=="string"?document.createTextNode(o):o),c.addEventListener(L.CLICK,this.handleClick_.bind(this,i),!1);let u=document.createElement("button");u.className=s,u.setAttribute("type","button"),u.title=h,u.appendChild(typeof a=="string"?document.createTextNode(a):a),u.addEventListener(L.CLICK,this.handleClick_.bind(this,-i),!1);let d=e+" "+ge+" "+ki,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){let i=this.getMap().getView();if(!i)return;let r=i.getZoom();if(r!==void 0){let s=i.getConstrainedZoom(r+t);this.duration_>0?(i.getAnimating()&&i.cancelAnimations(),i.animate({zoom:s,duration:this.duration_,easing:ce})):i.setZoom(s)}}},br=el;function kn(n){n=n||{};let t=new Mt;return(n.zoom===void 0||n.zoom)&&t.push(new br(n.zoomOptions)),(n.rotate===void 0||n.rotate)&&t.push(new Mr(n.rotateOptions)),(n.attribution===void 0||n.attribution)&&t.push(new Ir(n.attributionOptions)),t}var il=class{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;let 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;let r=this.points_[e+2]-this.points_[i+2];if(r<1e3/60)return!1;let s=this.points_[e]-this.points_[i],o=this.points_[e+1]-this.points_[i+1];return this.angle_=Math.atan2(o,s),this.initialVelocity_=Math.sqrt(s*s+o*o)/r,this.initialVelocity_>this.minVelocity_}getDistance(){return(this.minVelocity_-this.initialVelocity_)/this.decay_}getAngle(){return this.angle_}},_d=il;var nl={ACTIVE:"active"};var rl=class extends pt{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(nl.ACTIVE)}getMap(){return this.map_}handleEvent(t){return!0}setActive(t){this.set(nl.ACTIVE,t)}setMap(t){this.map_=t}};function yd(n,t,e){let i=n.getCenterInternal();if(i){let r=[i[0]+t[0],i[1]+t[1]];n.animateInternal({duration:e!==void 0?e:250,easing:Eu,center:n.getConstrainedCenter(r)})}}function Nn(n,t,e,i){let r=n.getZoom();if(r===void 0)return;let s=n.getConstrainedZoom(r+t),o=n.getResolutionForZoom(s);n.getAnimating()&&n.cancelAnimations(),n.animate({resolution:o,anchor:e,duration:i!==void 0?i:250,easing:ce})}var Ke=rl;var sl=class extends Ke{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){let i=t.originalEvent,r=t.map,s=t.coordinate,o=i.shiftKey?-this.delta_:this.delta_,a=r.getView();Nn(a,o,s,this.duration_),i.preventDefault(),e=!0}return!e}},xd=sl;function Lr(n){let t=arguments;return function(e){let i=!0;for(let r=0,s=t.length;r<s&&(i=i&&t[r](e),!!i);++r);return i}}var Ed=function(n){let t=n.originalEvent;return t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},pm=function(n){let t=n.map.getTargetElement(),e=t.getRootNode(),i=n.map.getOwnerDocument().activeElement;return e instanceof ShadowRoot?e.host.contains(i):t.contains(i)},$s=function(n){let t=n.map.getTargetElement(),e=t.getRootNode();return(e instanceof ShadowRoot?e.host:t).hasAttribute("tabindex")?pm(n):!0},Cd=ei;var Js=function(n){let t=n.originalEvent;return"pointerId"in t&&t.button==0&&!(eu&&aa&&t.ctrlKey)};var Qs=function(n){let t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&!t.shiftKey};var Rd=function(n){let t=n.originalEvent;return aa?t.metaKey:t.ctrlKey},to=function(n){let t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},eo=function(n){let t=n.originalEvent,e=t.target.tagName;return e!=="INPUT"&&e!=="SELECT"&&e!=="TEXTAREA"&&!t.target.isContentEditable},Ni=function(n){let t=n.originalEvent;return"pointerId"in t&&t.pointerType=="mouse"};var wd=function(n){let t=n.originalEvent;return"pointerId"in t&&t.isPrimary&&t.button===0};var ol=class extends Ke{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){let i=this.handleUpEvent(t);this.handlingDownUpSequence=i&&this.targetPointers.length>0}}else if(t.type==at.POINTERDOWN){let 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 Gn(n){let t=n.length,e=0,i=0;for(let r=0;r<t;r++)e+=n[r].clientX,i+=n[r].clientY;return{clientX:e/t,clientY:i/t}}var pe=ol;var al=class extends pe{constructor(t){super({stopDown:ii}),t=t||{},this.kinetic_=t.kinetic,this.lastCentroid=null,this.lastPointersCount_,this.panning_=!1;let e=t.condition?t.condition:Lr(Qs,wd);this.condition_=t.onFocusOnly?Lr($s,e):e,this.noKinetic_=!1}handleDragEvent(t){let e=t.map;this.panning_||(this.panning_=!0,e.getView().beginInteraction());let i=this.targetPointers,r=e.getEventPixel(Gn(i));if(i.length==this.lastPointersCount_){if(this.kinetic_&&this.kinetic_.update(r[0],r[1]),this.lastCentroid){let s=[this.lastCentroid[0]-r[0],r[1]-this.lastCentroid[1]],a=t.map.getView();pu(s,a.getResolution()),Sn(s,a.getRotation()),a.adjustCenterInternal(s)}}else this.kinetic_&&this.kinetic_.begin();this.lastCentroid=r,this.lastPointersCount_=i.length,t.originalEvent.preventDefault()}handleUpEvent(t){let e=t.map,i=e.getView();if(this.targetPointers.length===0){if(!this.noKinetic_&&this.kinetic_&&this.kinetic_.end()){let r=this.kinetic_.getDistance(),s=this.kinetic_.getAngle(),o=i.getCenterInternal(),a=e.getPixelFromCoordinateInternal(o),l=e.getCoordinateFromPixelInternal([a[0]-r*Math.cos(s),a[1]-r*Math.sin(s)]);i.animateInternal({center:i.getConstrainedCenter(l),duration:500,easing:ce})}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)){let 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}},Sd=al;var ll=class extends pe{constructor(t){t=t||{},super({stopDown:ii}),this.condition_=t.condition?t.condition:Ed,this.lastAngle_=void 0,this.duration_=t.duration!==void 0?t.duration:250}handleDragEvent(t){if(!Ni(t))return;let e=t.map,i=e.getView();if(i.getConstraints().rotation===On)return;let r=e.getSize(),s=t.pixel,o=Math.atan2(r[1]/2-s[1],s[0]-r[0]/2);if(this.lastAngle_!==void 0){let a=o-this.lastAngle_;i.adjustRotationInternal(-a)}this.lastAngle_=o}handleUpEvent(t){return Ni(t)?(t.map.getView().endInteraction(this.duration_),!1):!0}handleDownEvent(t){return Ni(t)&&Js(t)&&this.condition_(t)?(t.map.getView().beginInteraction(),this.lastAngle_=void 0,!0):!1}},Td=ll;var hl=class extends Ci{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_(){let t=this.startPixel_,e=this.endPixel_,i="px",r=this.element_.style;r.left=Math.min(t[0],e[0])+i,r.top=Math.min(t[1],e[1])+i,r.width=Math.abs(e[0]-t[0])+i,r.height=Math.abs(e[1]-t[1])+i}setMap(t){if(this.map_){this.map_.getOverlayContainer().removeChild(this.element_);let 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;let t=this.startPixel_,e=this.endPixel_,r=[t,[t[0],e[1]],e,[e[0],t[1]]].map(this.map_.getCoordinateFromPixelInternal,this.map_);r[4]=r[0].slice(),this.geometry_?this.geometry_.setCoordinates([r]):this.geometry_=new Di([r])}getGeometry(){return this.geometry_}},vd=hl;var zn={BOXSTART:"boxstart",BOXDRAG:"boxdrag",BOXEND:"boxend",BOXCANCEL:"boxcancel"},an=class extends mt{constructor(t,e,i){super(t),this.coordinate=e,this.mapBrowserEvent=i}},cl=class extends pe{constructor(t){super(),this.on,this.once,this.un,t=t??{},this.box_=new vd(t.className||"ol-dragbox"),this.minArea_=t.minArea??64,t.onBoxEnd&&(this.onBoxEnd=t.onBoxEnd),this.startPixel_=null,this.condition_=t.condition??Js,this.boxEndCondition_=t.boxEndCondition??this.defaultBoxEndCondition}defaultBoxEndCondition(t,e,i){let r=i[0]-e[0],s=i[1]-e[1];return r*r+s*s>=this.minArea_}getGeometry(){return this.box_.getGeometry()}handleDragEvent(t){this.startPixel_&&(this.box_.setPixels(this.startPixel_,t.pixel),this.dispatchEvent(new an(zn.BOXDRAG,t.coordinate,t)))}handleUpEvent(t){if(!this.startPixel_)return!1;let e=this.boxEndCondition_(t,this.startPixel_,t.pixel);return e&&this.onBoxEnd(t),this.dispatchEvent(new an(e?zn.BOXEND:zn.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 an(zn.BOXSTART,t.coordinate,t)),!0):!1}onBoxEnd(t){}setActive(t){t||(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new an(zn.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setActive(t)}setMap(t){this.getMap()&&(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new an(zn.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setMap(t)}},Id=cl;var ul=class extends Id{constructor(t){t=t||{};let e=t.condition?t.condition:to;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){let i=this.getMap().getView(),r=this.getGeometry();if(this.out_){let s=i.rotatedExtentForGeometry(r),o=i.getResolutionForExtentInternal(s),a=i.getResolution()/o;r=r.clone(),r.scale(a*a)}i.fitInternal(r,{duration:this.duration_,easing:ce})}},Md=ul;var Gi={LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",DOWN:"ArrowDown"};var dl=class extends Ke{constructor(t){super(),t=t||{},this.defaultCondition_=function(e){return Qs(e)&&eo(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==L.KEYDOWN){let i=t.originalEvent,r=i.key;if(this.condition_(t)&&(r==Gi.DOWN||r==Gi.LEFT||r==Gi.RIGHT||r==Gi.UP)){let o=t.map.getView(),a=o.getResolution()*this.pixelDelta_,l=0,h=0;r==Gi.DOWN?h=-a:r==Gi.LEFT?l=-a:r==Gi.RIGHT?l=a:h=a;let c=[l,h];Sn(c,o.getRotation()),yd(o,c,this.duration_),i.preventDefault(),e=!0}}return!e}},bd=dl;var fl=class extends Ke{constructor(t){super(),t=t||{},this.condition_=t.condition?t.condition:function(e){return!Rd(e)&&eo(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==L.KEYDOWN||t.type==L.KEYPRESS){let i=t.originalEvent,r=i.key;if(this.condition_(t)&&(r==="+"||r==="-")){let s=t.map,o=r==="+"?this.delta_:-this.delta_,a=s.getView();Nn(a,o,void 0,this.duration_),i.preventDefault(),e=!0}}return!e}},Ld=fl;var _m=40,ym=300,gl=class extends Ke{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;let e=t.condition?t.condition:Cd;this.condition_=t.onFocusOnly?Lr($s,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;let 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!==L.WHEEL)return!0;let i=t.map,r=t.originalEvent;r.preventDefault(),this.useAnchor_&&(this.lastAnchor_=t.pixel);let s=r.deltaY;switch(r.deltaMode){case WheelEvent.DOM_DELTA_LINE:s*=_m;break;case WheelEvent.DOM_DELTA_PAGE:s*=ym;break;default:}if(s===0)return!1;this.lastDelta_=s;let o=Date.now();this.startTime_===void 0&&(this.startTime_=o),(!this.mode_||o-this.startTime_>this.trackpadEventGap_)&&(this.mode_=Math.abs(s)<4?"trackpad":"wheel");let 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(-s/this.deltaPerZoom_,this.lastAnchor_?i.getCoordinateFromPixel(this.lastAnchor_):null),this.startTime_=o,!1;this.totalDelta_+=s;let 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){let e=t.getView();e.getAnimating()&&e.cancelAnimations();let i=-Q(this.totalDelta_,-this.maxDelta_*this.deltaPerZoom_,this.maxDelta_*this.deltaPerZoom_)/this.deltaPerZoom_;(e.getConstrainResolution()||this.constrainResolution_)&&(i=i?i>0?1:-1:0),Nn(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)}},Ad=gl;var ml=class extends pe{constructor(t){t=t||{};let e=t;e.stopDown||(e.stopDown=ii),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,i=this.targetPointers[0],r=this.targetPointers[1],s=Math.atan2(r.clientY-i.clientY,r.clientX-i.clientX);if(this.lastAngle_!==void 0){let l=s-this.lastAngle_;this.rotationDelta_+=l,!this.rotating_&&Math.abs(this.rotationDelta_)>this.threshold_&&(this.rotating_=!0),e=l}this.lastAngle_=s;let o=t.map,a=o.getView();a.getConstraints().rotation!==On&&(this.anchor_=o.getCoordinateFromPixelInternal(o.getEventPixel(Gn(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){let 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}},Pd=ml;var pl=class extends pe{constructor(t){t=t||{};let e=t;e.stopDown||(e.stopDown=ii),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,i=this.targetPointers[0],r=this.targetPointers[1],s=i.clientX-r.clientX,o=i.clientY-r.clientY,a=Math.sqrt(s*s+o*o);this.lastDistance_!==void 0&&(e=this.lastDistance_/a),this.lastDistance_=a;let l=t.map,h=l.getView();e!=1&&(this.lastScaleDelta_=e),this.anchor_=l.getCoordinateFromPixelInternal(l.getEventPixel(Gn(this.targetPointers))),l.render(),h.adjustResolutionInternal(e,this.anchor_)}handleUpEvent(t){if(this.targetPointers.length<2){let i=t.map.getView(),r=this.lastScaleDelta_>1?1:-1;return i.endInteraction(this.duration_,r),!1}return!0}handleDownEvent(t){if(this.targetPointers.length>=2){let e=t.map;return this.anchor_=null,this.lastDistance_=void 0,this.lastScaleDelta_=1,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}},Od=pl;function jn(n){n=n||{};let t=new Mt,e=new _d(-.005,.05,100);return(n.altShiftDragRotate===void 0||n.altShiftDragRotate)&&t.push(new Td),(n.doubleClickZoom===void 0||n.doubleClickZoom)&&t.push(new xd({delta:n.zoomDelta,duration:n.zoomDuration})),(n.dragPan===void 0||n.dragPan)&&t.push(new Sd({onFocusOnly:n.onFocusOnly,kinetic:e})),(n.pinchRotate===void 0||n.pinchRotate)&&t.push(new Pd),(n.pinchZoom===void 0||n.pinchZoom)&&t.push(new Od({duration:n.zoomDuration})),(n.keyboard===void 0||n.keyboard)&&(t.push(new bd),t.push(new Ld({delta:n.zoomDelta,duration:n.zoomDuration}))),(n.mouseWheelZoom===void 0||n.mouseWheelZoom)&&t.push(new Ad({onFocusOnly:n.onFocusOnly,duration:n.zoomDuration})),(n.shiftDragZoom===void 0||n.shiftDragZoom)&&t.push(new Md({duration:n.zoomDuration})),t}var rt={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"};var _l=class extends pt{constructor(t){super(),this.on,this.once,this.un,this.background_=t.background;let e=Object.assign({},t);typeof t.properties=="object"&&(delete e.properties,Object.assign(e,t.properties)),e[rt.OPACITY]=t.opacity!==void 0?t.opacity:1,V(typeof e[rt.OPACITY]=="number","Layer opacity must be a number"),e[rt.VISIBLE]=t.visible!==void 0?t.visible:!0,e[rt.Z_INDEX]=t.zIndex,e[rt.MAX_RESOLUTION]=t.maxResolution!==void 0?t.maxResolution:1/0,e[rt.MIN_RESOLUTION]=t.minResolution!==void 0?t.minResolution:0,e[rt.MIN_ZOOM]=t.minZoom!==void 0?t.minZoom:-1/0,e[rt.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){let e=this.state_||{layer:this,managed:t===void 0?!0:t},i=this.getZIndex();return e.opacity=Q(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 F()}getLayerStatesArray(t){return F()}getExtent(){return this.get(rt.EXTENT)}getMaxResolution(){return this.get(rt.MAX_RESOLUTION)}getMinResolution(){return this.get(rt.MIN_RESOLUTION)}getMinZoom(){return this.get(rt.MIN_ZOOM)}getMaxZoom(){return this.get(rt.MAX_ZOOM)}getOpacity(){return this.get(rt.OPACITY)}getSourceState(){return F()}getVisible(){return this.get(rt.VISIBLE)}getZIndex(){return this.get(rt.Z_INDEX)}setBackground(t){this.background_=t,this.changed()}setExtent(t){this.set(rt.EXTENT,t)}setMaxResolution(t){this.set(rt.MAX_RESOLUTION,t)}setMinResolution(t){this.set(rt.MIN_RESOLUTION,t)}setMaxZoom(t){this.set(rt.MAX_ZOOM,t)}setMinZoom(t){this.set(rt.MIN_ZOOM,t)}setOpacity(t){V(typeof t=="number","Layer opacity must be a number"),this.set(rt.OPACITY,t)}setVisible(t){this.set(rt.VISIBLE,t)}setZIndex(t){this.set(rt.Z_INDEX,t)}disposeInternal(){this.state_&&(this.state_.layer=null,this.state_=null),super.disposeInternal()}},io=_l;var zi={ADDLAYER:"addlayer",REMOVELAYER:"removelayer"},be=class extends mt{constructor(t,e){super(t),this.layer=e}},yl={LAYERS:"layers"},xl=class n extends io{constructor(t){t=t||{};let 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(yl.LAYERS,this.handleLayersChanged_),i?Array.isArray(i)?i=new Mt(i.slice(),{unique:!0}):V(typeof i.getArray=="function","Expected `layers` to be an array or a `Collection`"):i=new Mt(void 0,{unique:!0}),this.setLayers(i)}handleLayerChange_(){this.changed()}handleLayersChanged_(){this.layersListenerKeys_.forEach(B),this.layersListenerKeys_.length=0;let t=this.getLayers();this.layersListenerKeys_.push(G(t,wt.ADD,this.handleLayersAdd_,this),G(t,wt.REMOVE,this.handleLayersRemove_,this));for(let i in this.listenerKeys_)this.listenerKeys_[i].forEach(B);ze(this.listenerKeys_);let e=t.getArray();for(let i=0,r=e.length;i<r;i++){let s=e[i];this.registerLayerListeners_(s),this.dispatchEvent(new be(zi.ADDLAYER,s))}this.changed()}registerLayerListeners_(t){let e=[G(t,Ee.PROPERTYCHANGE,this.handleLayerChange_,this),G(t,L.CHANGE,this.handleLayerChange_,this)];t instanceof n&&e.push(G(t,zi.ADDLAYER,this.handleLayerGroupAdd_,this),G(t,zi.REMOVELAYER,this.handleLayerGroupRemove_,this)),this.listenerKeys_[U(t)]=e}handleLayerGroupAdd_(t){this.dispatchEvent(new be(zi.ADDLAYER,t.layer))}handleLayerGroupRemove_(t){this.dispatchEvent(new be(zi.REMOVELAYER,t.layer))}handleLayersAdd_(t){let e=t.element;this.registerLayerListeners_(e),this.dispatchEvent(new be(zi.ADDLAYER,e)),this.changed()}handleLayersRemove_(t){let e=t.element,i=U(e);this.listenerKeys_[i].forEach(B),delete this.listenerKeys_[i],this.dispatchEvent(new be(zi.REMOVELAYER,e)),this.changed()}getLayers(){return this.get(yl.LAYERS)}setLayers(t){let e=this.getLayers();if(e){let i=e.getArray();for(let r=0,s=i.length;r<s;++r)this.dispatchEvent(new be(zi.REMOVELAYER,i[r]))}this.set(yl.LAYERS,t)}getLayersArray(t){return t=t!==void 0?t:[],this.getLayers().forEach(function(e){e.getLayersArray(t)}),t}getLayerStatesArray(t){let e=t!==void 0?t:[],i=e.length;this.getLayers().forEach(function(o){o.getLayerStatesArray(e)});let r=this.getLayerState(),s=r.zIndex;!t&&r.zIndex===void 0&&(s=0);for(let o=i,a=e.length;o<a;o++){let l=e[o];l.opacity*=r.opacity,l.visible=l.visible&&r.visible,l.maxResolution=Math.min(l.maxResolution,r.maxResolution),l.minResolution=Math.max(l.minResolution,r.minResolution),l.minZoom=Math.max(l.minZoom,r.minZoom),l.maxZoom=Math.min(l.maxZoom,r.maxZoom),r.extent!==void 0&&(l.extent!==void 0?l.extent=Ut(l.extent,r.extent):l.extent=r.extent),l.zIndex===void 0&&(l.zIndex=s)}return e}getSourceState(){return"ready"}},Ar=xl;var Lt={PRERENDER:"prerender",POSTRENDER:"postrender",PRECOMPOSE:"precompose",POSTCOMPOSE:"postcompose",RENDERCOMPLETE:"rendercomplete"};var El=class extends io{constructor(t){let 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(rt.SOURCE,this.handleSourcePropertyChange_);let 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(rt.SOURCE)||null}getRenderSource(){return this.getSource()}getSourceState(){let 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_&&(B(this.sourceChangeKey_),this.sourceChangeKey_=null),this.sourceReady_=!1;let t=this.getSource();t&&(this.sourceChangeKey_=G(t,L.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,i=this.getMapInternal();!t&&i&&(t=i.getView()),t instanceof Bt?e={viewState:t.getState(),extent:t.calculateExtent()}:e=t,!e.layerStatesArray&&i&&(e.layerStatesArray=i.getLayerGroup().getLayerStatesArray());let r;if(e.layerStatesArray){if(r=e.layerStatesArray.find(o=>o.layer===this),!r)return!1}else r=this.getLayerState();let s=this.getExtent();return Pr(r,e.viewState)&&(!s||lt(s,e.extent))}getAttributions(t){if(!this.isVisible(t))return[];let e=this.getSource()?.getAttributions();if(!e)return[];let i=t instanceof Bt?t.getViewStateAndExtent():t,r=e(i);return Array.isArray(r)||(r=[r]),r}render(t,e){let 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){let e=this.getRenderer();e&&e.renderDeferred(t)}setMapInternal(t){t||this.unrender(),this.set(rt.MAP,t)}getMapInternal(){return this.get(rt.MAP)}setMap(t){this.mapPrecomposeKey_&&(B(this.mapPrecomposeKey_),this.mapPrecomposeKey_=null),t||this.changed(),this.mapRenderKey_&&(B(this.mapRenderKey_),this.mapRenderKey_=null),t&&(this.mapPrecomposeKey_=G(t,Lt.PRECOMPOSE,this.handlePrecompose_,this),this.mapRenderKey_=G(this,L.CHANGE,t.render,t),this.changed())}handlePrecompose_(t){let e=t.frameState.layerStatesArray,i=this.getLayerState(!1);V(!e.some(r=>r.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(rt.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 Pr(n,t){if(!n.visible)return!1;let e=t.resolution;if(e<n.minResolution||e>=n.maxResolution)return!1;let i=t.zoom;return i>n.minZoom&&i<=n.maxZoom}var ci=El;function no(n,t,e=0,i=n.length-1,r=xm){for(;i>e;){if(i-e>600){let 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));no(n,t,f,g,r)}let s=n[t],o=e,a=i;for(Or(n,e,t),r(n[i],s)>0&&Or(n,e,i);o<a;){for(Or(n,o,a),o++,a--;r(n[o],s)<0;)o++;for(;r(n[a],s)>0;)a--}r(n[e],s)===0?Or(n,e,a):(a++,Or(n,a,i)),a<=t&&(e=a+1),t<=a&&(i=a-1)}}function Or(n,t,e){let i=n[t];n[t]=n[e],n[e]=i}function xm(n,t){return n<t?-1:n>t?1:0}var ln=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,i=[];if(!so(t,e))return i;let r=this.toBBox,s=[];for(;e;){for(let o=0;o<e.children.length;o++){let a=e.children[o],l=e.leaf?r(a):a;so(t,l)&&(e.leaf?i.push(a):Rl(t,l)?this._all(a,i):s.push(a))}e=s.pop()}return i}collides(t){let e=this.data;if(!so(t,e))return!1;let i=[];for(;e;){for(let r=0;r<e.children.length;r++){let s=e.children[r],o=e.leaf?this.toBBox(s):s;if(so(t,o)){if(e.leaf||Rl(t,o))return!0;i.push(s)}}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){let 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=Xn([]),this}remove(t,e){if(!t)return this;let i=this.data,r=this.toBBox(t),s=[],o=[],a,l,h;for(;i||s.length;){if(i||(i=s.pop(),l=s[s.length-1],a=o.pop(),h=!0),i.leaf){let c=Em(t,i.children,e);if(c!==-1)return i.children.splice(c,1),s.push(i),this._condense(s),this}!h&&!i.leaf&&Rl(i,r)?(s.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){let i=[];for(;t;)t.leaf?e.push(...t.children):i.push(...t.children),t=i.pop();return e}_build(t,e,i,r){let s=i-e+1,o=this._maxEntries,a;if(s<=o)return a=Xn(t.slice(e,i+1)),Wn(a,this.toBBox),a;r||(r=Math.ceil(Math.log(s)/Math.log(o)),o=Math.ceil(s/Math.pow(o,r-1))),a=Xn([]),a.leaf=!1,a.height=r;let l=Math.ceil(s/o),h=l*Math.ceil(Math.sqrt(o));Fd(t,e,i,h,this.compareMinX);for(let c=e;c<=i;c+=h){let u=Math.min(c+h-1,i);Fd(t,c,u,l,this.compareMinY);for(let d=c;d<=u;d+=l){let f=Math.min(d+l-1,u);a.children.push(this._build(t,d,f,r-1))}}return Wn(a,this.toBBox),a}_chooseSubtree(t,e,i,r){for(;r.push(e),!(e.leaf||r.length-1===i);){let s=1/0,o=1/0,a;for(let l=0;l<e.children.length;l++){let h=e.children[l],c=Cl(h),u=wm(t,h)-c;u<o?(o=u,s=c<s?c:s,a=h):u===o&&c<s&&(s=c,a=h)}e=a||e.children[0]}return e}_insert(t,e,i){let r=i?t:this.toBBox(t),s=[],o=this._chooseSubtree(r,this.data,e,s);for(o.children.push(t),Dr(o,r);e>=0&&s[e].children.length>this._maxEntries;)this._split(s,e),e--;this._adjustParentBBoxes(r,s,e)}_split(t,e){let i=t[e],r=i.children.length,s=this._minEntries;this._chooseSplitAxis(i,s,r);let o=this._chooseSplitIndex(i,s,r),a=Xn(i.children.splice(o,i.children.length-o));a.height=i.height,a.leaf=i.leaf,Wn(i,this.toBBox),Wn(a,this.toBBox),e?t[e-1].children.push(a):this._splitRoot(i,a)}_splitRoot(t,e){this.data=Xn([t,e]),this.data.height=t.height+1,this.data.leaf=!1,Wn(this.data,this.toBBox)}_chooseSplitIndex(t,e,i){let r,s=1/0,o=1/0;for(let a=e;a<=i-e;a++){let l=Fr(t,0,a,this.toBBox),h=Fr(t,a,i,this.toBBox),c=Sm(l,h),u=Cl(l)+Cl(h);c<s?(s=c,r=a,o=u<o?u:o):c===s&&u<o&&(o=u,r=a)}return r||i-e}_chooseSplitAxis(t,e,i){let r=t.leaf?this.compareMinX:Cm,s=t.leaf?this.compareMinY:Rm,o=this._allDistMargin(t,e,i,r),a=this._allDistMargin(t,e,i,s);o<a&&t.children.sort(r)}_allDistMargin(t,e,i,r){t.children.sort(r);let s=this.toBBox,o=Fr(t,0,e,s),a=Fr(t,i-e,i,s),l=ro(o)+ro(a);for(let h=e;h<i-e;h++){let c=t.children[h];Dr(o,t.leaf?s(c):c),l+=ro(o)}for(let h=i-e-1;h>=e;h--){let c=t.children[h];Dr(a,t.leaf?s(c):c),l+=ro(a)}return l}_adjustParentBBoxes(t,e,i){for(let r=i;r>=0;r--)Dr(e[r],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():Wn(t[e],this.toBBox)}};function Em(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 Wn(n,t){Fr(n,0,n.children.length,t,n)}function Fr(n,t,e,i,r){r||(r=Xn(null)),r.minX=1/0,r.minY=1/0,r.maxX=-1/0,r.maxY=-1/0;for(let s=t;s<e;s++){let o=n.children[s];Dr(r,n.leaf?i(o):o)}return r}function Dr(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 Cm(n,t){return n.minX-t.minX}function Rm(n,t){return n.minY-t.minY}function Cl(n){return(n.maxX-n.minX)*(n.maxY-n.minY)}function ro(n){return n.maxX-n.minX+(n.maxY-n.minY)}function wm(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 Sm(n,t){let e=Math.max(n.minX,t.minX),i=Math.max(n.minY,t.minY),r=Math.min(n.maxX,t.maxX),s=Math.min(n.maxY,t.maxY);return Math.max(0,r-e)*Math.max(0,s-i)}function Rl(n,t){return n.minX<=t.minX&&n.minY<=t.minY&&t.maxX<=n.maxX&&t.maxY<=n.maxY}function so(n,t){return t.minX<=n.maxX&&t.minY<=n.maxY&&t.maxX>=n.minX&&t.maxY>=n.minY}function Xn(n){return{children:n,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function Fd(n,t,e,i,r){let s=[t,e];for(;s.length;){if(e=s.pop(),t=s.pop(),e-t<=i)continue;let o=t+Math.ceil((e-t)/i/2)*i;no(n,o,t,e,r),s.push(t,o,o,e)}}var ao=[NaN,NaN,NaN,0],wl;function Tm(){return wl||(wl=nt(1,1,void 0,{willReadFrequently:!0,desynchronized:!0})),wl}var vm=/^rgba?\(\s*(\d+%?)\s+(\d+%?)\s+(\d+%?)(?:\s*\/\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,Im=/^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,Mm=/^rgba?\(\s*(\d+%)\s*,\s*(\d+%)\s*,\s*(\d+%)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,bm=/^#([\da-f]{3,4}|[\da-f]{6}|[\da-f]{8})$/i;function oo(n,t){return n.endsWith("%")?Number(n.substring(0,n.length-1))/t:Number(n)}function Nr(n){throw new Error('failed to parse "'+n+'" as color')}function Dd(n){if(n.toLowerCase().startsWith("rgb")){let s=n.match(Im)||n.match(vm)||n.match(Mm);if(s){let o=s[4],a=100/255;return[Q(oo(s[1],a)+.5|0,0,255),Q(oo(s[2],a)+.5|0,0,255),Q(oo(s[3],a)+.5|0,0,255),o!==void 0?Q(oo(o,100),0,1):1]}Nr(n)}if(n.startsWith("#")){if(bm.test(n)){let s=n.substring(1),o=s.length<=4?1:2,a=[0,0,0,255];for(let l=0,h=s.length;l<h;l+=o){let c=parseInt(s.substring(l,l+o),16);o===1&&(c+=c<<4),a[l/o]=c}return a[3]=a[3]/255,a}Nr(n)}let t=Tm();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&&Nr(n));let i=t.fillStyle;if(i.startsWith("#")||i.startsWith("rgba"))return Dd(i);t.clearRect(0,0,1,1),t.fillRect(0,0,1,1);let r=Array.from(t.getImageData(0,0,1,1).data);return r[3]=Ti(r[3]/255,3),r}function kd(n){return typeof n=="string"?n:zr(n)}var Lm=1024,kr={},Sl=0;function Nd(n){if(n.length===4)return n;let t=n.slice();return t[3]=1,t}function Tl(n){return n>.0031308?Math.pow(n,1/2.4)*269.025-14.025:n*3294.6}function vl(n){return n>.2068965?Math.pow(n,3):(n-4/29)*(108/841)}function Il(n){return n>10.314724?Math.pow((n+14.025)/269.025,2.4):n/3294.6}function Ml(n){return n>.0088564?Math.pow(n,1/3):n/(108/841)+4/29}function bl(n){let t=Il(n[0]),e=Il(n[1]),i=Il(n[2]),r=Ml(t*.222488403+e*.716873169+i*.06060791),s=500*(Ml(t*.452247074+e*.399439023+i*.148375274)-r),o=200*(r-Ml(t*.016863605+e*.117638439+i*.865350722)),a=Math.atan2(o,s)*(180/Math.PI);return[116*r-16,Math.sqrt(s*s+o*o),a<0?a+360:a,n[3]]}function Gd(n){let t=(n[0]+16)/116,e=n[1],i=n[2]*Math.PI/180,r=vl(t),s=vl(t+e/500*Math.cos(i)),o=vl(t-e/200*Math.sin(i)),a=Tl(s*3.021973625-r*1.617392459-o*.404875592),l=Tl(s*-.943766287+r*1.916279586+o*.027607165),h=Tl(s*.069407491-r*.22898585+o*1.159737864);return[Q(a+.5|0,0,255),Q(l+.5|0,0,255),Q(h+.5|0,0,255),n[3]]}function Gr(n){if(n==="none")return ao;if(kr.hasOwnProperty(n))return kr[n];if(Sl>=Lm){let e=0;for(let i in kr)(e++&3)===0&&(delete kr[i],--Sl)}let t=Dd(n);t.length!==4&&Nr(n);for(let e of t)isNaN(e)&&Nr(n);return kr[n]=t,++Sl,t}function _e(n){return Array.isArray(n)?n:Gr(n)}function zr(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);let r=n[3]===void 0?1:Math.round(n[3]*1e3)/1e3;return"rgba("+t+","+e+","+i+","+r+")"}function Ll(n){return n[0]>0&&n[1]>0}function zd(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 ft(n,t){return Array.isArray(n)?n:(t===void 0?t=[n,n]:(t[0]=n,t[1]=n),t)}var hn=0;var Ft=1<<hn++,J=1<<hn++,zt=1<<hn++,te=1<<hn++,Wi=1<<hn++,jr=1<<hn++,lo=Math.pow(2,hn)-1,Ol={[Ft]:"boolean",[J]:"number",[zt]:"string",[te]:"color",[Wi]:"number[]",[jr]:"size"},Am=Object.keys(Ol).map(Number).sort(jt);function Pm(n){return n in Ol}function Wr(n){let t=[];for(let e of Am)Xr(n,e)&&t.push(Ol[e]);return t.length===0?"untyped":t.length<3?t.join(" or "):t.slice(0,-1).join(", ")+", or "+t[t.length-1]}function Xr(n,t){return(n&t)===t}function ji(n,t){return n===t}var gt=class{constructor(t,e){if(!Pm(t))throw new Error(`literal expressions must have a specific type, got ${Wr(t)}`);this.type=t,this.value=e}},Pl=class{constructor(t,e,...i){this.type=t,this.operator=e,this.args=i}};function Fl(){return{variables:new Set,properties:new Set,featureId:!1,geometryType:!1,mapState:!1}}function vt(n,t,e){switch(typeof n){case"boolean":{if(ji(t,zt))return new gt(zt,n?"true":"false");if(!Xr(t,Ft))throw new Error(`got a boolean, but expected ${Wr(t)}`);return new gt(Ft,n)}case"number":{if(ji(t,jr))return new gt(jr,ft(n));if(ji(t,Ft))return new gt(Ft,!!n);if(ji(t,zt))return new gt(zt,n.toString());if(!Xr(t,J))throw new Error(`got a number, but expected ${Wr(t)}`);return new gt(J,n)}case"string":{if(ji(t,te))return new gt(te,Gr(n));if(ji(t,Ft))return new gt(Ft,!!n);if(!Xr(t,zt))throw new Error(`got a string, but expected ${Wr(t)}`);return new gt(zt,n)}default:}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 Um(n,t,e);for(let i of n)if(typeof i!="number")throw new Error("expected an array of numbers");if(ji(t,jr)){if(n.length!==2)throw new Error(`expected an array of two values for a size, got ${n.length}`);return new gt(jr,n)}if(ji(t,te)){if(n.length===3)return new gt(te,[...n,1]);if(n.length===4)return new gt(te,n);throw new Error(`expected an array of 3 or 4 values for a color, got ${n.length}`)}if(!Xr(t,Wi))throw new Error(`got an array of numbers, but expected ${Wr(t)}`);return new gt(Wi,n)}var R={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"},Om={[R.Get]:Y(Z(1,1/0),jd),[R.Var]:Y(Z(1,1),Fm),[R.Has]:Y(Z(1,1/0),jd),[R.Id]:Y(Dm,Un),[R.Concat]:Y(Z(2,1/0),st(zt)),[R.GeometryType]:Y(km,Un),[R.LineMetric]:Y(Un),[R.Resolution]:Y(Al,Un),[R.Zoom]:Y(Al,Un),[R.Time]:Y(Al,Un),[R.Any]:Y(Z(2,1/0),st(Ft)),[R.All]:Y(Z(2,1/0),st(Ft)),[R.Not]:Y(Z(1,1),st(Ft)),[R.Equal]:Y(Z(2,2),st(lo)),[R.NotEqual]:Y(Z(2,2),st(lo)),[R.GreaterThan]:Y(Z(2,2),st(J)),[R.GreaterThanOrEqualTo]:Y(Z(2,2),st(J)),[R.LessThan]:Y(Z(2,2),st(J)),[R.LessThanOrEqualTo]:Y(Z(2,2),st(J)),[R.Multiply]:Y(Z(2,1/0),Wd),[R.Coalesce]:Y(Z(2,1/0),Wd),[R.Divide]:Y(Z(2,2),st(J)),[R.Add]:Y(Z(2,1/0),st(J)),[R.Subtract]:Y(Z(2,2),st(J)),[R.Clamp]:Y(Z(3,3),st(J)),[R.Mod]:Y(Z(2,2),st(J)),[R.Pow]:Y(Z(2,2),st(J)),[R.Abs]:Y(Z(1,1),st(J)),[R.Floor]:Y(Z(1,1),st(J)),[R.Ceil]:Y(Z(1,1),st(J)),[R.Round]:Y(Z(1,1),st(J)),[R.Sin]:Y(Z(1,1),st(J)),[R.Cos]:Y(Z(1,1),st(J)),[R.Atan]:Y(Z(1,2),st(J)),[R.Sqrt]:Y(Z(1,1),st(J)),[R.Match]:Y(Z(4,1/0),Xd,Gm),[R.Between]:Y(Z(3,3),st(J)),[R.Interpolate]:Y(Z(6,1/0),Xd,zm),[R.Case]:Y(Z(3,1/0),Nm,jm),[R.In]:Y(Z(2,2),Wm),[R.Number]:Y(Z(1,1/0),st(lo)),[R.String]:Y(Z(1,1/0),st(lo)),[R.Array]:Y(Z(1,1/0),st(J)),[R.Color]:Y(Z(1,4),st(J)),[R.Band]:Y(Z(1,3),st(J)),[R.Palette]:Y(Z(2,2),Xm),[R.ToString]:Y(Z(1,1),st(Ft|J|zt|te))};function jd(n,t,e){let i=n.length-1,r=new Array(i);for(let s=0;s<i;++s){let o=n[s+1];switch(typeof o){case"number":{r[s]=new gt(J,o);break}case"string":{r[s]=new gt(zt,o);break}default:throw new Error(`expected a string key or numeric array index for a get operation, got ${o}`)}s===0&&e.properties.add(String(o))}return r}function Fm(n,t,e){let i=n[1];if(typeof i!="string")throw new Error("expected a string argument for var operation");return e.variables.add(i),[new gt(zt,i)]}function Dm(n,t,e){e.featureId=!0}function km(n,t,e){e.geometryType=!0}function Al(n,t,e){e.mapState=!0}function Un(n,t,e){let i=n[0];if(n.length!==1)throw new Error(`expected no arguments for ${i} operation`);return[]}function Z(n,t){return function(e,i,r){let s=e[0],o=e.length-1;if(n===t){if(o!==n){let a=n===1?"":"s";throw new Error(`expected ${n} argument${a} for ${s}, got ${o}`)}}else if(o<n||o>t){let a=t===1/0?`${n} or more`:`${n} to ${t}`;throw new Error(`expected ${a} arguments for ${s}, got ${o}`)}}}function Wd(n,t,e){let i=n.length-1,r=new Array(i);for(let s=0;s<i;++s){let o=vt(n[s+1],t,e);r[s]=o}return r}function st(n){return function(t,e,i){let r=t.length-1,s=new Array(r);for(let o=0;o<r;++o){let a=vt(t[o+1],n,i);s[o]=a}return s}}function Nm(n,t,e){let i=n[0],r=n.length-1;if(r%2===0)throw new Error(`expected an odd number of arguments for ${i}, got ${r} instead`)}function Xd(n,t,e){let i=n[0],r=n.length-1;if(r%2===1)throw new Error(`expected an even number of arguments for operation ${i}, got ${r} instead`)}function Gm(n,t,e){let i=n.length-1,r=zt|J|Ft,s=vt(n[1],r,e),o=vt(n[n.length-1],t,e),a=new Array(i-2);for(let l=0;l<i-2;l+=2){try{let h=vt(n[l+2],s.type,e);a[l]=h}catch(h){throw new Error(`failed to parse argument ${l+1} of match expression: ${h.message}`)}try{let h=vt(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[s,...a,o]}function zm(n,t,e){let i=n[1],r;switch(i[0]){case"linear":r=1;break;case"exponential":let l=i[1];if(typeof l!="number"||l<=0)throw new Error(`expected a number base for exponential interpolation, got ${JSON.stringify(l)} instead`);r=l;break;default:throw new Error(`invalid interpolation type: ${JSON.stringify(i)}`)}let s=new gt(J,r),o;try{o=vt(n[2],J,e)}catch(l){throw new Error(`failed to parse argument 1 in interpolate expression: ${l.message}`)}let a=new Array(n.length-3);for(let l=0;l<a.length;l+=2){try{let h=vt(n[l+3],J,e);a[l]=h}catch(h){throw new Error(`failed to parse argument ${l+2} for interpolate expression: ${h.message}`)}try{let h=vt(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[s,o,...a]}function jm(n,t,e){let i=vt(n[n.length-1],t,e),r=new Array(n.length-1);for(let s=0;s<r.length-1;s+=2){try{let o=vt(n[s+1],Ft,e);r[s]=o}catch(o){throw new Error(`failed to parse argument ${s} of case expression: ${o.message}`)}try{let o=vt(n[s+2],i.type,e);r[s+1]=o}catch(o){throw new Error(`failed to parse argument ${s+1} of case expression: ${o.message}`)}}return r[r.length-1]=i,r}function Wm(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 r;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],r=zt}else r=J;let s=new Array(i.length);for(let a=0;a<s.length;a++)try{let l=vt(i[a],r,e);s[a]=l}catch(l){throw new Error(`failed to parse haystack item ${a} for "in" expression: ${l.message}`)}return[vt(n[1],r,e),...s]}function Xm(n,t,e){let i;try{i=vt(n[1],J,e)}catch(o){throw new Error(`failed to parse first argument in palette expression: ${o.message}`)}let r=n[2];if(!Array.isArray(r))throw new Error("the second argument of palette must be an array");let s=new Array(r.length);for(let o=0;o<s.length;o++){let a;try{a=vt(r[o],te,e)}catch(l){throw new Error(`failed to parse color at index ${o} in palette expression: ${l.message}`)}if(!(a instanceof gt))throw new Error(`the palette color at index ${o} must be a literal value`);s[o]=a}return[i,...s]}function Y(...n){return function(t,e,i){let r=t[0],s;for(let o=0;o<n.length;o++){let 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");s=a}}return new Pl(e,r,...s)}}function Um(n,t,e){let i=n[0],r=Om[i];if(!r)throw new Error(`unknown operator: ${i}`);return r(n,t,e)}function Dl(n){if(!n)return"";let 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 Dl(n.getGeometries()[0]);default:return""}}function kl(){return{variables:{},properties:{},resolution:NaN,featureId:null,geometryType:""}}function Ae(n,t,e){let i=vt(n,t,e);return Le(i,e)}function Le(n,t){if(n instanceof gt){if(n.type===te&&typeof n.value=="string"){let i=Gr(n.value);return function(){return i}}return function(){return n.value}}let e=n.operator;switch(e){case R.Number:case R.String:case R.Coalesce:return Ym(n,t);case R.Get:case R.Var:case R.Has:return Km(n,t);case R.Id:return i=>i.featureId;case R.GeometryType:return i=>i.geometryType;case R.Concat:{let i=n.args.map(r=>Le(r,t));return r=>"".concat(...i.map(s=>s(r).toString()))}case R.Resolution:return i=>i.resolution;case R.Any:case R.All:case R.Between:case R.In:case R.Not:return Bm(n,t);case R.Equal:case R.NotEqual:case R.LessThan:case R.LessThanOrEqualTo:case R.GreaterThan:case R.GreaterThanOrEqualTo:return Vm(n,t);case R.Multiply:case R.Divide:case R.Add:case R.Subtract:case R.Clamp:case R.Mod:case R.Pow:case R.Abs:case R.Floor:case R.Ceil:case R.Round:case R.Sin:case R.Cos:case R.Atan:case R.Sqrt:return Zm(n,t);case R.Case:return Hm(n,t);case R.Match:return qm(n,t);case R.Interpolate:return $m(n,t);case R.ToString:return Jm(n,t);default:throw new Error(`Unsupported operator ${e}`)}}function Ym(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);switch(e){case R.Coalesce:return s=>{for(let o=0;o<i;++o){let a=r[o](s);if(typeof a<"u"&&a!==null)return a}throw new Error("Expected one of the values to be non-null")};case R.Number:case R.String:return s=>{for(let o=0;o<i;++o){let a=r[o](s);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 Km(n,t){let i=n.args[0].value;switch(n.operator){case R.Get:return r=>{let s=n.args,o=r.properties[i];for(let a=1,l=s.length;a<l;++a){let c=s[a].value;o=o[c]}return o};case R.Var:return r=>r.variables[i];case R.Has:return r=>{let s=n.args;if(!(i in r.properties))return!1;let o=r.properties[i];for(let a=1,l=s.length;a<l;++a){let c=s[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){let e=n.operator,i=Le(n.args[0],t),r=Le(n.args[1],t);switch(e){case R.Equal:return s=>i(s)===r(s);case R.NotEqual:return s=>i(s)!==r(s);case R.LessThan:return s=>i(s)<r(s);case R.LessThanOrEqualTo:return s=>i(s)<=r(s);case R.GreaterThan:return s=>i(s)>r(s);case R.GreaterThanOrEqualTo:return s=>i(s)>=r(s);default:throw new Error(`Unsupported comparison operator ${e}`)}}function Bm(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);switch(e){case R.Any:return s=>{for(let o=0;o<i;++o)if(r[o](s))return!0;return!1};case R.All:return s=>{for(let o=0;o<i;++o)if(!r[o](s))return!1;return!0};case R.Between:return s=>{let o=r[0](s),a=r[1](s),l=r[2](s);return o>=a&&o<=l};case R.In:return s=>{let o=r[0](s);for(let a=1;a<i;++a)if(o===r[a](s))return!0;return!1};case R.Not:return s=>!r[0](s);default:throw new Error(`Unsupported logical operator ${e}`)}}function Zm(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);switch(e){case R.Multiply:return s=>{let o=1;for(let a=0;a<i;++a)o*=r[a](s);return o};case R.Divide:return s=>r[0](s)/r[1](s);case R.Add:return s=>{let o=0;for(let a=0;a<i;++a)o+=r[a](s);return o};case R.Subtract:return s=>r[0](s)-r[1](s);case R.Clamp:return s=>{let o=r[0](s),a=r[1](s);if(o<a)return a;let l=r[2](s);return o>l?l:o};case R.Mod:return s=>r[0](s)%r[1](s);case R.Pow:return s=>Math.pow(r[0](s),r[1](s));case R.Abs:return s=>Math.abs(r[0](s));case R.Floor:return s=>Math.floor(r[0](s));case R.Ceil:return s=>Math.ceil(r[0](s));case R.Round:return s=>Math.round(r[0](s));case R.Sin:return s=>Math.sin(r[0](s));case R.Cos:return s=>Math.cos(r[0](s));case R.Atan:return i===2?s=>Math.atan2(r[0](s),r[1](s)):s=>Math.atan(r[0](s));case R.Sqrt:return s=>Math.sqrt(r[0](s));default:throw new Error(`Unsupported numeric operator ${e}`)}}function Hm(n,t){let e=n.args.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=Le(n.args[r],t);return r=>{for(let s=0;s<e-1;s+=2)if(i[s](r))return i[s+1](r);return i[e-1](r)}}function qm(n,t){let e=n.args.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=Le(n.args[r],t);return r=>{let s=i[0](r);for(let o=1;o<e-1;o+=2)if(s===i[o](r))return i[o+1](r);return i[e-1](r)}}function $m(n,t){let e=n.args.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=Le(n.args[r],t);return r=>{let s=i[0](r),o=i[1](r),a,l;for(let h=2;h<e;h+=2){let c=i[h](r),u=i[h+1](r),d=Array.isArray(u);if(d&&(u=Nd(u)),c>=o)return h===2?u:d?Qm(s,o,a,l,c,u):Ur(s,o,a,l,c,u);a=c,l=u}return l}}function Jm(n,t){let e=n.operator,i=n.args.length,r=new Array(i);for(let s=0;s<i;++s)r[s]=Le(n.args[s],t);if(e===R.ToString)return s=>{let o=r[0](s);return n.args[0].type===te?zr(o):o.toString()};throw new Error(`Unsupported convert operator ${e}`)}function Ur(n,t,e,i,r,s){let o=r-e;if(o===0)return i;let a=t-e,l=n===1?a/o:(Math.pow(n,a)-1)/(Math.pow(n,o)-1);return i+l*(s-i)}function Qm(n,t,e,i,r,s){if(r-e===0)return i;let a=bl(i),l=bl(s),h=l[2]-a[2];h>180?h-=360:h<-180&&(h+=360);let c=[Ur(n,t,e,a[0],r,l[0]),Ur(n,t,e,a[1],r,l[1]),a[2]+Ur(n,t,e,0,r,h),Ur(n,t,e,i[3],r,s[3])];return Gd(c)}var b={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4};var Nl=class extends je{constructor(t,e,i,r){super(),this.extent=t,this.pixelRatio_=i,this.resolution=e,this.state=typeof r=="function"?b.IDLE:r,this.image_=null,this.loader=typeof r=="function"?r:null}changed(){this.dispatchEvent(L.CHANGE)}getExtent(){return this.extent}getImage(){return this.image_}getPixelRatio(){return this.pixelRatio_}getResolution(){return this.resolution}getState(){return this.state}load(){if(this.state==b.IDLE&&this.loader){this.state=b.LOADING,this.changed();let t=this.getResolution(),e=Array.isArray(t)?t[0]:t;ps(()=>this.loader(this.getExtent(),e,this.getPixelRatio())).then(i=>{"image"in i&&(this.image_=i.image),"extent"in i&&(this.extent=i.extent),"resolution"in i&&(this.resolution=i.resolution),"pixelRatio"in i&&(this.pixelRatio_=i.pixelRatio),(i instanceof HTMLImageElement||la&&i instanceof ImageBitmap||i instanceof HTMLCanvasElement||i instanceof HTMLVideoElement)&&(this.image_=i),this.state=b.LOADED}).catch(i=>{this.state=b.ERROR,console.error(i)}).finally(()=>this.changed())}}setImage(t){this.image_=t}setResolution(t){this.resolution=t}};function Ud(n,t,e){let i=n,r=!0,s=!1,o=!1,a=[_n(i,L.LOAD,function(){o=!0,s||t()})];return i.src&&xs?(s=!0,i.decode().then(function(){r&&t()}).catch(function(l){r&&(o?t():e())})):a.push(_n(i,L.ERROR,e)),function(){r=!1,a.forEach(B)}}function tp(n,t){return new Promise((e,i)=>{function r(){o(),e(n)}function s(){o(),i(new Error("Image load error"))}function o(){n.removeEventListener("load",r),n.removeEventListener("error",s)}n.addEventListener("load",r),n.addEventListener("error",s),t&&(n.src=t)})}function Gl(n,t){return t&&(n.src=t),n.src&&xs?new Promise((e,i)=>n.decode().then(()=>e(n)).catch(r=>n.complete&&n.width?e(n):i(r))):tp(n)}function ho(n,t){return t&&(n.src=t),n.src&&xs&&la?n.decode().then(()=>createImageBitmap(n)).catch(e=>{if(n.complete&&n.width)return n;throw e}):Gl(n)}var co=Nl;var jl=class{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(let e in this.cache_){let i=this.cache_[e];(t++&3)===0&&!i.hasListener()&&(delete this.cache_[e],delete this.patternCache_[e],--this.cacheSize_)}}}get(t,e){let i=zl(t,e);return i in this.cache_?this.cache_[i]:null}getPattern(t,e){let i=zl(t,e);return i in this.patternCache_?this.patternCache_[i]:null}set(t,e,i,r){let s=zl(t,e),o=s in this.cache_;this.cache_[s]=i,r&&(i.getImageState()===b.IDLE&&i.load(),i.getImageState()===b.LOADING?i.ready().then(()=>{this.patternCache_[s]=Fn().createPattern(i.getImage(1),"repeat")}):this.patternCache_[s]=Fn().createPattern(i.getImage(1),"repeat")),o||++this.cacheSize_}setSize(t){this.maxCacheSize_=t,this.expire()}};function zl(n,t){let e=t?_e(t):"null";return n+":"+e}var Dt=new jl;var Yr=null,uo=class extends je{constructor(t,e,i,r,s){super(),this.hitDetectionImage_=null,this.image_=t,this.crossOrigin_=i?.crossOrigin,this.referrerPolicy_=i?.referrerPolicy,this.canvas_={},this.color_=s,this.imageState_=r===void 0?b.IDLE:r,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_),this.referrerPolicy_!==void 0&&(this.image_.referrerPolicy=this.referrerPolicy_)}isTainted_(){if(this.tainted_===void 0&&this.imageState_===b.LOADED){Yr||(Yr=nt(1,1,void 0,{willReadFrequently:!0})),Yr.drawImage(this.image_,0,0);try{Yr.getImageData(0,0,1,1),this.tainted_=!1}catch{Yr=null,this.tainted_=!0}}return this.tainted_===!0}dispatchChangeEvent_(){this.dispatchEvent(L.CHANGE)}handleImageError_(){this.imageState_=b.ERROR,this.dispatchChangeEvent_()}handleImageLoad_(){this.imageState_=b.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_}setImage(t){this.image_=t}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_()){let t=this.size_[0],e=this.size_[1],i=nt(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_===b.IDLE){this.image_||this.initializeImage_(),this.imageState_=b.LOADING;try{this.src_!==void 0&&(this.image_.src=this.src_)}catch{this.handleImageError_()}this.image_ instanceof HTMLImageElement&&Gl(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_!==b.LOADED)return;let e=this.image_,i=nt(Math.ceil(e.width*t),Math.ceil(e.height*t)),r=i.canvas;i.scale(t,t),i.drawImage(e,0,0),i.globalCompositeOperation="multiply",i.fillStyle=kd(this.color_),i.fillRect(0,0,r.width/t,r.height/t),i.globalCompositeOperation="destination-in",i.drawImage(e,0,0),this.canvas_[t]=r}ready(){return this.ready_||(this.ready_=new Promise(t=>{if(this.imageState_===b.LOADED||this.imageState_===b.ERROR)t();else{let e=()=>{(this.imageState_===b.LOADED||this.imageState_===b.ERROR)&&(this.removeEventListener(L.CHANGE,e),t())};this.addEventListener(L.CHANGE,e)}})),this.ready_}};function Xi(n,t,e,i,r,s){let o=t===void 0?void 0:Dt.get(t,r);return o||(o=new uo(n,n&&"src"in n?n.src||void 0:t,e,i,r),Dt.set(t,r,o,s)),s&&o&&!Dt.getPattern(t,r)&&Dt.set(t,r,o,s),o}var Yd=uo;function Zt(n){return n?Array.isArray(n)?zr(n):typeof n=="object"&&"src"in n?ep(n):n:null}function ep(n){if(!n.offset||!n.size)return Dt.getPattern(n.src,n.color);let t=n.src+":"+n.offset,e=Dt.getPattern(t,n.color);if(e)return e;let i=Dt.get(n.src,null);if(i.getImageState()!==b.LOADED)return null;let r=nt(n.size[0],n.size[1]);return r.drawImage(i.getImage(1),n.offset[0],n.offset[1],n.size[0],n.size[1],0,0,n.size[0],n.size[1]),Xi(r.canvas,t,void 0,b.LOADED,n.color,!0),Dt.getPattern(t,n.color)}var fo="10px sans-serif",Ct="#000",Ve="round",Ht=[],qt=0,Be="round",ui=10,Vd=0,di="#000",Ui="center",un="middle",fi=[0,0,0,0],gi=1,cn=new pt,Kr=null,Kd,Wl={},ip=new Set(["serif","sans-serif","monospace","cursive","fantasy","system-ui","ui-serif","ui-sans-serif","ui-monospace","ui-rounded","emoji","math","fangsong"]);function np(n,t,e){return`${n} ${t} 16px "${e}"`}var Bd=(function(){let t,e;async function i(s){await e.ready;let o=await e.load(s);if(o.length===0)return!1;let a=Hs(s),l=a.families[0].toLowerCase(),h=a.weight;return o.some(c=>{let u=c.family.replace(/^['"]|['"]$/g,"").toLowerCase(),d=Zs[c.weight]||c.weight;return u===l&&c.style===a.style&&d==h})}async function r(){await e.ready;let s=!0,o=cn.getProperties(),a=Object.keys(o).filter(l=>o[l]<100);for(let l=a.length-1;l>=0;--l){let h=a[l],c=o[h];c<100&&(await i(h)?(ze(Wl),cn.set(h,100)):(c+=10,cn.set(h,c,!0),c<100&&(s=!1)))}t=void 0,s||(t=setTimeout(r,100))}return async function(s){e||(e=xt?self.fonts:document.fonts);let o=Hs(s);if(!o)return;let a=o.families,l=!1;for(let h of a){if(ip.has(h))continue;let c=np(o.style,o.weight,h);cn.get(c)===void 0&&(cn.set(c,0,!0),l=!0)}l&&(clearTimeout(t),t=setTimeout(r,100))}})(),rp=(function(){let n;return function(t){let e=Wl[t];if(e==null){if(xt){let i=Hs(t),r=Zd(t,"\u017Dg");e=(isNaN(Number(i.lineHeight))?1.2:Number(i.lineHeight))*(r.actualBoundingBoxAscent+r.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);Wl[t]=e}return e}})();function Zd(n,t){return Kr||(Kr=nt(1,1)),n!=Kd&&(Kr.font=n,Kd=Kr.font),Kr.measureText(t)}function Hd(n,t){return Zd(n,t).width}function Xl(n,t,e){if(t in e)return e[t];let i=t.split(`
|
|
2
|
+
`).reduce((r,s)=>Math.max(r,Hd(n,s)),0);return e[t]=i,i}function qd(n,t){let e=[],i=[],r=[],s=0,o=0,a=0,l=0;for(let h=0,c=t.length;h<=c;h+=2){let u=t[h];if(u===`
|
|
3
|
+
`||h===c){s=Math.max(s,o),r.push(o),o=0,a+=l,l=0;continue}let d=t[h+1]||n.font,f=Hd(d,u);e.push(f),o+=f;let g=rp(d);i.push(g),l=Math.max(l,g)}return{width:s,height:a,widths:e,heights:i,lineWidths:r}}function $d(n,t,e,i,r,s,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]),sp(i,n)):c[0]<0||c[1]<0?(n.translate(l,h),n.scale(c[0],c[1]),n.drawImage(i,r,s,o,a,0,0,o,a)):n.drawImage(i,r,s,o,a,l,h,o*c[0],a*c[1]),n.restore()}function sp(n,t){let e=n.contextInstructions;for(let i=0,r=e.length;i<r;i+=2)Array.isArray(e[i+1])?t[e[i]].apply(t,e[i+1]):t[e[i]]=e[i+1]}var Ul=class n{constructor(t){this.opacity_=t.opacity,this.rotateWithView_=t.rotateWithView,this.rotation_=t.rotation,this.scale_=t.scale,this.scaleArray_=ft(t.scale),this.displacement_=t.displacement,this.declutterMode_=t.declutterMode}clone(){let t=this.getScale();return new n({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 F()}getImage(t){return F()}getHitDetectionImage(){return F()}getPixelRatio(t){return 1}getImageState(){return F()}getImageSize(){return F()}getOrigin(){return F()}getSize(){return F()}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_=ft(t)}listenImageChange(t){F()}load(){F()}unlistenImageChange(t){F()}ready(){return Promise.resolve()}},go=Ul;var Yl=class n extends go{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()?b.LOADING:b.LOADED,this.imageState_===b.LOADING&&this.ready().then(()=>this.imageState_=b.LOADED),this.render()}clone(){let t=this.getScale(),e=new n({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(){let 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){let e=this.fill_?.getKey(),i=`${t},${this.angle_},${this.radius},${this.radius2_},${this.points_},${e}`+Object.values(this.renderOptions_).join(","),r=Dt.get(i,null)?.getImage(1);if(!r){let s=this.renderOptions_,o=Math.ceil(s.size*t),a=nt(o,o);this.draw_(s,a,t),r=a.canvas;let l=new Yd(r,void 0,null,b.LOADED,null);Dt.set(i,null,l),createImageBitmap(r).then(h=>{l.setImage(h)})}return r}getPixelRatio(t){return t}getImageSize(){return this.size_}getImageState(){return this.imageState_}getOrigin(){return this.origin_}getPoints(){return this.points_}getRadius(){return this.radius}setRadius(t){this.radius!==t&&(this.radius=t,this.render())}getRadius2(){return this.radius2_}setRadius2(t){this.radius2_!==t&&(this.radius2_=t,this.render())}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 r=this.radius,s=this.radius2_===void 0?r:this.radius2_;if(r<s){let T=r;r=s,s=T}let o=this.radius2_===void 0?this.points_:this.points_*2,a=2*Math.PI/o,l=s*Math.sin(a),h=Math.sqrt(s*s-l*l),c=r-h,u=Math.sqrt(l*l+c*c),d=u/l;if(t==="miter"&&d<=i)return d*e;let f=e/2/d,g=e/2*(c/u),m=Math.sqrt((r+f)*(r+f)+g*g)-r;if(this.radius2_===void 0||t==="bevel")return m*2;let _=r*Math.sin(a),y=Math.sqrt(r*r-_*_),E=s-y,C=Math.sqrt(_*_+E*E)/_;if(C<=i){let T=C*e/2-s-r;return 2*Math.max(m,T)}return m*2}createRenderOptions(){let t=Ve,e=Be,i=0,r=null,s=0,o,a=0;this.stroke_&&(o=Zt(this.stroke_.getColor()??di),a=this.stroke_.getWidth()??gi,r=this.stroke_.getLineDash(),s=this.stroke_.getLineDashOffset()??0,e=this.stroke_.getLineJoin()??Be,t=this.stroke_.getLineCap()??Ve,i=this.stroke_.getMiterLimit()??ui);let 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:r,lineDashOffset:s,lineJoin:e,miterLimit:i}}render(){this.renderOptions_=this.createRenderOptions();let 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 r=this.fill_.getColor();r===null&&(r=Ct),e.fillStyle=Zt(r),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(),r=0;typeof i=="string"&&(i=_e(i)),i===null?r=1:Array.isArray(i)&&(r=i.length===4?i[3]:1),r===0&&(e=nt(t.size,t.size),this.drawHitDetectionCanvas_(t,e))}return e?e.canvas:this.getImage(1)}createPath_(t){let e=this.points_,i=this.radius;if(e===1/0)t.arc(0,0,i,0,2*Math.PI);else{let r=this.radius2_===void 0?i:this.radius2_;this.radius2_!==void 0&&(e*=2);let s=this.angle_-Math.PI/2,o=2*Math.PI/e;for(let a=0;a<e;a++){let l=s+a*o,h=a%2===0?i:r;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=Ct,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()}},mo=Yl;var Kl=class n extends mo{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(){let t=this.getScale(),e=new n({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}},Yi=Kl;var Vl=class n{constructor(t){t=t||{},this.patternImage_=null,this.color_=null,t.color!==void 0&&this.setColor(t.color)}clone(){let t=this.getColor();return new n({color:Array.isArray(t)?t.slice():t||void 0})}getColor(){return this.color_}setColor(t){if(t!==null&&typeof t=="object"&&"src"in t){let e=Xi(null,t.src,{crossOrigin:"anonymous"},void 0,t.offset?null:t.color?t.color:null,!(t.offset&&t.size));e.ready().then(()=>{this.patternImage_=null}),e.getImageState()===b.IDLE&&e.load(),e.getImageState()===b.LOADING&&(this.patternImage_=e)}this.color_=t}getKey(){let t=this.getColor();return t?t instanceof CanvasPattern||t instanceof CanvasGradient?U(t):typeof t=="object"&&"src"in t?t.src+":"+t.offset:_e(t).toString():""}loading(){return!!this.patternImage_}ready(){return this.patternImage_?this.patternImage_.ready():Promise.resolve()}},Pe=Vl;function Jd(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}var Bl=class n extends go{constructor(t){t=t||{};let e=t.opacity!==void 0?t.opacity:1,i=t.rotation!==void 0?t.rotation:0,r=t.scale!==void 0?t.scale:1,s=t.rotateWithView!==void 0?t.rotateWithView:!1;super({opacity:e,rotation:i,scale:r,displacement:t.displacement!==void 0?t.displacement:[0,0],rotateWithView:s,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,this.referrerPolicy_=t.referrerPolicy;let o=t.img!==void 0?t.img:null,a=t.src;V(!(a!==void 0&&o),"`image` and `src` cannot be provided at the same time"),(a===void 0||a.length===0)&&o&&(a=o.src||U(o)),V(a!==void 0&&a.length>0,"A defined and non-empty `src` or `image` must be provided"),V(!((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=b.IDLE:o!==void 0&&("complete"in o?o.complete?l=o.src?b.LOADED:b.IDLE:l=b.LOADING:l=b.LOADED),this.color_=t.color!==void 0?_e(t.color):null,this.iconImage_=Xi(o,a,{crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_},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{let u=this.getImage(1);if(u.width&&u.height)h=u.width,c=u.height;else if(u instanceof HTMLImageElement){this.initialOptions_=t;let d=()=>{if(this.unlistenImageChange(d),!this.initialOptions_)return;let f=this.iconImage_.getSize();this.setScale(Jd(f[0],f[1],t.width,t.height))};this.listenImageChange(d);return}}h!==void 0&&this.setScale(Jd(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 n({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_,referrerPolicy:this.referrerPolicy_,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_;let r=this.getSize();if(this.anchorXUnits_=="fraction"||this.anchorYUnits_=="fraction"){if(!r)return null;t=this.anchor_.slice(),this.anchorXUnits_=="fraction"&&(t[0]*=r[0]),this.anchorYUnits_=="fraction"&&(t[1]*=r[1])}if(this.anchorOrigin_!="top-left"){if(!r)return null;t===this.anchor_&&(t=this.anchor_.slice()),(this.anchorOrigin_=="top-right"||this.anchorOrigin_=="bottom-right")&&(t[0]=-t[0]+r[0]),(this.anchorOrigin_=="bottom-left"||this.anchorOrigin_=="bottom-right")&&(t[1]=-t[1]+r[1])}this.normalizedAnchor_=t}let 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_}setColor(t){let e=t?_e(t):null;if(this.color_===e||this.color_&&e&&this.color_.length===e.length&&this.color_.every((o,a)=>o===e[a]))return;this.color_=e;let i=this.getSrc(),r=i!==void 0?null:this.getHitDetectionImage(),s=i!==void 0?b.IDLE:this.iconImage_.getImageState();this.iconImage_=Xi(r,i,{crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_},s,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"){let 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_=Xi(null,t,{crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_},b.IDLE,this.color_)}getSize(){return this.size_?this.size_:this.iconImage_.getSize()}getWidth(){let t=this.getScaleArray();if(this.size_)return this.size_[0]*t[0];if(this.iconImage_.getImageState()==b.LOADED)return this.iconImage_.getSize()[0]*t[0]}getHeight(){let t=this.getScaleArray();if(this.size_)return this.size_[1]*t[1];if(this.iconImage_.getImageState()==b.LOADED)return this.iconImage_.getSize()[1]*t[1]}setScale(t){delete this.initialOptions_,super.setScale(t)}listenImageChange(t){this.iconImage_.addEventListener(L.CHANGE,t)}load(){this.iconImage_.load()}unlistenImageChange(t){this.iconImage_.removeEventListener(L.CHANGE,t)}ready(){return this.iconImage_.ready()}},Vr=Bl;var Zl=class n{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.offset_=t.offset,this.width_=t.width}clone(){let t=this.getColor();return new n({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(),offset:this.getOffset(),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_}getOffset(){return this.offset_}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}setOffset(t){this.offset_=t}setWidth(t){this.width_=t}},Ki=Zl;var po=class n{constructor(t){t=t||{},this.geometry_=null,this.geometryFunction_=Qd,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 n({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_=Qd,this.geometry_=t}setZIndex(t){this.zIndex_=t}};function tf(n){let t;if(typeof n=="function")t=n;else{let e;Array.isArray(n)?e=n:(V(typeof n.getZIndex=="function","Expected an `Style` or an array of `Style`"),e=[n]),t=function(){return e}}return t}var Hl=null;function ql(n,t){if(!Hl){let e=new Pe({color:"rgba(255,255,255,0.4)"}),i=new Ki({color:"#3399CC",width:1.25});Hl=[new po({image:new Yi({fill:e,stroke:i,radius:5}),fill:e,stroke:i})]}return Hl}function Qd(n){return n.getGeometry()}var Ze=po;var op="#333",$l=class n{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_=ft(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 Pe({color:op}),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(){let t=this.getScale();return new n({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 Pe?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_=ft(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}},ef=$l;function ap(n){return!0}function of(n){let t=Fl(),e=lp(n,t),i=kl();return function(r,s){if(i.properties=r.getPropertiesInternal(),i.resolution=s,t.featureId){let o=r.getId();o!==void 0?i.featureId=o:i.featureId=null}return t.geometryType&&(i.geometryType=Dl(r.getGeometry())),e(i)}}function th(n){let t=Fl(),e=n.length,i=new Array(e);for(let o=0;o<e;++o)i[o]=Jl(n[o],t);let r=kl(),s=new Array(e);return function(o,a){if(r.properties=o.getPropertiesInternal(),r.resolution=a,t.featureId){let h=o.getId();h!==void 0?r.featureId=h:r.featureId=null}let l=0;for(let h=0;h<e;++h){let c=i[h](r);c&&(s[l]=c,l+=1)}return s.length=l,s}}function lp(n,t){let e=n.length,i=new Array(e);for(let r=0;r<e;++r){let s=n[r],o="filter"in s?Ae(s.filter,Ft,t):ap,a;if(Array.isArray(s.style)){let l=s.style.length;a=new Array(l);for(let h=0;h<l;++h)a[h]=Jl(s.style[h],t)}else a=[Jl(s.style,t)];i[r]={filter:o,styles:a}}return function(r){let s=[],o=!1;for(let a=0;a<e;++a){let l=i[a].filter;if(l(r)&&!(n[a].else&&o)){o=!0;for(let h of i[a].styles){let c=h(r);c&&s.push(c)}}}return s}}function Jl(n,t){let e=Br(n,"",t),i=Zr(n,"",t),r=hp(n,t),s=cp(n,t),o=At(n,"z-index",t);if(!e&&!i&&!r&&!s&&!$t(n))throw new Error("No fill, stroke, point, or text symbolizer properties in style: "+JSON.stringify(n));let a=new Ze;return function(l){let h=!0;if(e){let c=e(l);c&&(h=!1),a.setFill(c)}if(i){let c=i(l);c&&(h=!1),a.setStroke(c)}if(r){let c=r(l);c&&(h=!1),a.setText(c)}if(s){let c=s(l);c&&(h=!1),a.setImage(c)}return o&&a.setZIndex(o(l)),h?null:a}}function Br(n,t,e){let i;if(t+"fill-pattern-src"in n)i=gp(n,t+"fill-",e);else{if(n[t+"fill-color"]==="none")return s=>null;i=yo(n,t+"fill-color",e)}if(!i)return null;let r=new Pe;return function(s){let o=i(s);return o===ao?null:(r.setColor(o),r)}}function Zr(n,t,e){let i=At(n,t+"stroke-width",e),r=yo(n,t+"stroke-color",e);if(!i&&!r)return null;let s=mi(n,t+"stroke-line-cap",e),o=mi(n,t+"stroke-line-join",e),a=af(n,t+"stroke-line-dash",e),l=At(n,t+"stroke-line-dash-offset",e),h=At(n,t+"stroke-miter-limit",e),c=At(n,t+"stroke-offset",e),u=new Ki;return function(d){if(r){let f=r(d);if(f===ao)return null;u.setColor(f)}if(i&&u.setWidth(i(d)),s){let f=s(d);if(f!=="butt"&&f!=="round"&&f!=="square")throw new Error("Expected butt, round, or square line cap");u.setLineCap(f)}if(o){let f=o(d);if(f!=="bevel"&&f!=="round"&&f!=="miter")throw new Error("Expected bevel, round, or miter line join");u.setLineJoin(f)}return a&&u.setLineDash(a(d)),l&&u.setLineDashOffset(l(d)),h&&u.setMiterLimit(h(d)),c&&u.setOffset(c(d)),u}}function hp(n,t){let e="text-",i=mi(n,e+"value",t);if(!i)return null;let r=Br(n,e,t),s=Br(n,e+"background-",t),o=Zr(n,e,t),a=Zr(n,e+"background-",t),l=mi(n,e+"font",t),h=At(n,e+"max-angle",t),c=At(n,e+"offset-x",t),u=At(n,e+"offset-y",t),d=Yn(n,e+"overflow",t),f=mi(n,e+"placement",t),g=At(n,e+"repeat",t),p=xo(n,e+"scale",t),m=Yn(n,e+"rotate-with-view",t),_=At(n,e+"rotation",t),y=mi(n,e+"align",t),E=mi(n,e+"justify",t),x=mi(n,e+"baseline",t),C=Yn(n,e+"keep-upright",t),T=af(n,e+"padding",t),I=Eo(n,e+"declutter-mode"),S=new ef({declutterMode:I});return function(w){if(S.setText(i(w)),r&&S.setFill(r(w)),s&&S.setBackgroundFill(s(w)),o&&S.setStroke(o(w)),a&&S.setBackgroundStroke(a(w)),l&&S.setFont(l(w)),h&&S.setMaxAngle(h(w)),c&&S.setOffsetX(c(w)),u&&S.setOffsetY(u(w)),d&&S.setOverflow(d(w)),f){let M=f(w);if(M!=="point"&&M!=="line")throw new Error("Expected point or line for text-placement");S.setPlacement(M)}if(g&&S.setRepeat(g(w)),p&&S.setScale(p(w)),m&&S.setRotateWithView(m(w)),_&&S.setRotation(_(w)),y){let M=y(w);if(M!=="left"&&M!=="center"&&M!=="right"&&M!=="end"&&M!=="start")throw new Error("Expected left, right, center, start, or end for text-align");S.setTextAlign(M)}if(E){let M=E(w);if(M!=="left"&&M!=="right"&&M!=="center")throw new Error("Expected left, right, or center for text-justify");S.setJustify(M)}if(x){let M=x(w);if(M!=="bottom"&&M!=="top"&&M!=="middle"&&M!=="alphabetic"&&M!=="hanging")throw new Error("Expected bottom, top, middle, alphabetic, or hanging for text-baseline");S.setTextBaseline(M)}return T&&S.setPadding(T(w)),C&&S.setKeepUpright(C(w)),S}}function cp(n,t){return"icon-src"in n?up(n,t):"shape-points"in n?dp(n,t):"circle-radius"in n?fp(n,t):null}function up(n,t){let e="icon-",i=e+"src",r=lf(n[i],i),s=_o(n,e+"anchor",t),o=xo(n,e+"scale",t),a=At(n,e+"opacity",t),l=_o(n,e+"displacement",t),h=At(n,e+"rotation",t),c=Yn(n,e+"rotate-with-view",t),u=rf(n,e+"anchor-origin"),d=sf(n,e+"anchor-x-units"),f=sf(n,e+"anchor-y-units"),g=pi(n,e+"color"),p,m=null;g!==void 0&&(Array.isArray(g)&&g.length>0&&typeof g[0]=="string"?m=yo(n,e+"color",t):p=hf(g,e+"color"));let _=pp(n,e+"cross-origin"),y=_p(n,e+"offset"),E=rf(n,e+"offset-origin"),x=Ql(n,e+"width"),C=Ql(n,e+"height"),T=mp(n,e+"size"),I=Eo(n,e+"declutter-mode"),S={src:r,anchorOrigin:u,anchorXUnits:d,anchorYUnits:f,crossOrigin:_,offset:y,offsetOrigin:E,height:C,width:x,size:T,declutterMode:I},w=null;return function(M){if(w)m&&w.setColor(m(M));else{let N=m?m(M):p;w=new Vr(N!==void 0?Object.assign({},S,{color:N}):Object.assign({},S))}return a&&w.setOpacity(a(M)),l&&w.setDisplacement(l(M)),h&&w.setRotation(h(M)),c&&w.setRotateWithView(c(M)),o&&w.setScale(o(M)),s&&w.setAnchor(s(M)),w}}function dp(n,t){let e="shape-",i=e+"points",r=e+"radius",s=eh(n[i],i);if(!(r in n))throw new Error(`Expected a number for ${r}`);let o=At(n,r,t),a=typeof n[r]=="number"?n[r]:5,l=e+"radius2",h=At(n,l,t),c=typeof n[l]=="number"?n[l]:void 0,u=Br(n,e,t),d=Zr(n,e,t),f=xo(n,e+"scale",t),g=_o(n,e+"displacement",t),p=At(n,e+"rotation",t),m=Yn(n,e+"rotate-with-view",t),_=Ql(n,e+"angle"),y=Eo(n,e+"declutter-mode"),E=new mo({points:s,radius:a,radius2:c,angle:_,declutterMode:y});return function(x){return o&&E.setRadius(o(x)),h&&E.setRadius2(h(x)),u&&E.setFill(u(x)),d&&E.setStroke(d(x)),g&&E.setDisplacement(g(x)),p&&E.setRotation(p(x)),m&&E.setRotateWithView(m(x)),f&&E.setScale(f(x)),E}}function fp(n,t){let e="circle-",i=Br(n,e,t),r=Zr(n,e,t),s=At(n,e+"radius",t),o=xo(n,e+"scale",t),a=_o(n,e+"displacement",t),l=At(n,e+"rotation",t),h=Yn(n,e+"rotate-with-view",t),c=Eo(n,e+"declutter-mode"),u=new Yi({radius:5,declutterMode:c});return function(d){return s&&u.setRadius(s(d)),i&&u.setFill(i(d)),r&&u.setStroke(r(d)),a&&u.setDisplacement(a(d)),l&&u.setRotation(l(d)),h&&u.setRotateWithView(h(d)),o&&u.setScale(o(d)),u}}function pi(n,t){if(!(t in n))return;let e=n[t];return e===void 0?void 0:e}function At(n,t,e){let i=pi(n,t);if(i===void 0)return;let r=Ae(i,J,e);return function(s){return eh(r(s),t)}}function mi(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,zt,e);return function(s){return lf(r(s),t)}}function gp(n,t,e){let i=mi(n,t+"pattern-src",e),r=nf(n,t+"pattern-offset",e),s=nf(n,t+"pattern-size",e),o=yo(n,t+"color",e);return function(a){return{src:i(a),offset:r&&r(a),size:s&&s(a),color:o&&o(a)}}}function Yn(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Ft,e);return function(s){let o=r(s);if(typeof o!="boolean")throw new Error(`Expected a boolean for ${t}`);return o}}function yo(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,te,e);return function(s){return hf(r(s),t)}}function af(n,t,e){let i=pi(n,t);if(i===void 0)return null;if(Array.isArray(i)&&(i.length===0||typeof i[0]!="string")){let s=i.map((o,a)=>{if(typeof o=="number")return()=>o;let l=Ae(o,J,e);return function(h){return eh(l(h),`${t}[${a}]`)}});return function(o){let a=new Array(s.length);for(let l=0;l<s.length;++l)a[l]=s[l](o);return a}}let r=Ae(i,Wi,e);return function(s){return Hr(r(s),t)}}function _o(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Wi,e);return function(s){let o=Hr(r(s),t);if(o.length!==2)throw new Error(`Expected two numbers for ${t}`);return o}}function nf(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Wi,e);return function(s){return cf(r(s),t)}}function xo(n,t,e){let i=pi(n,t);if(i===void 0)return null;let r=Ae(i,Wi|J,e);return function(s){return yp(r(s),t)}}function Ql(n,t){let e=n[t];if(e!==void 0){if(typeof e!="number")throw new Error(`Expected a number for ${t}`);return e}}function mp(n,t){let e=n[t];if(e!==void 0){if(typeof e=="number")return ft(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 pp(n,t){let e=n[t];if(e!==void 0){if(typeof e!="string")throw new Error(`Expected a string for ${t}`);return e}}function rf(n,t){let 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 sf(n,t){let e=n[t];if(e!==void 0){if(e!=="pixels"&&e!=="fraction")throw new Error(`Expected pixels or fraction for ${t}`);return e}}function _p(n,t){let e=n[t];if(e!==void 0)return Hr(e,t)}function Eo(n,t){let 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 Hr(n,t){if(!Array.isArray(n))throw new Error(`Expected an array for ${t}`);let 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 lf(n,t){if(typeof n!="string")throw new Error(`Expected a string for ${t}`);return n}function eh(n,t){if(typeof n!="number")throw new Error(`Expected a number for ${t}`);return n}function hf(n,t){if(typeof n=="string")return n;let e=Hr(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 cf(n,t){let e=Hr(n,t);if(e.length!==2)throw new Error(`Expected an array of two numbers for ${t}`);return e}function yp(n,t){return typeof n=="number"?n:cf(n,t)}var uf={RENDER_ORDER:"renderOrder"},ih=class extends ci{constructor(t){t=t||{};let 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(uf.RENDER_ORDER)}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}getUpdateWhileAnimating(){return this.updateWhileAnimating_}getUpdateWhileInteracting(){return this.updateWhileInteracting_}renderDeclutter(t,e){let i=this.getDeclutter();i in t.declutter||(t.declutter[i]=new ln(9)),this.getRenderer().renderDeclutter(t,e)}setRenderOrder(t){this.set(uf.RENDER_ORDER,t)}setStyle(t){this.style_=t===void 0?ql:t;let e=xp(t);this.styleFunction_=t===null?void 0:tf(e),this.changed()}setDeclutter(t){this.declutter_=t?String(t):void 0,this.changed()}};function xp(n){if(n===void 0)return ql;if(!n)return null;if(typeof n=="function"||n instanceof Ze)return n;if(!Array.isArray(n))return th([n]);if(n.length===0)return[];let t=n.length,e=n[0];if(e instanceof Ze){let r=new Array(t);for(let s=0;s<t;++s){let o=n[s];if(!(o instanceof Ze))throw new Error("Expected a list of style instances");r[s]=o}return r}if("style"in e){let r=new Array(t);for(let s=0;s<t;++s){let o=n[s];if(!("style"in o))throw new Error("Expected a list of rules with a style property");r[s]=o}return of(r)}return th(n)}var Co=ih;var nh=class extends mt{constructor(t,e,i,r){super(t),this.inversePixelTransform=e,this.frameState=i,this.context=r}},Ro=nh;var rh=class extends Ci{constructor(t){super(),this.map_=t}dispatchRenderEvent(t,e){F()}calculateMatrices2D(t){let e=t.viewState,i=t.coordinateToPixelTransform,r=t.pixelToCoordinateTransform;Et(i,t.size[0]/2,t.size[1]/2,1/e.resolution,-1/e.resolution,-e.rotation,-e.center[0],-e.center[1]),Gs(r,i)}forEachFeatureAtCoordinate(t,e,i,r,s,o,a,l){let h,c=e.viewState;function u(x,C,T,I){return s.call(o,C,x?T:null,I)}let d=c.projection,f=Tn(t.slice(),d),g=[[0,0]];if(d.canWrapX()&&r){let x=d.getExtent(),C=W(x);g.push([-C,0],[C,0])}let p=e.layerStatesArray,m=p.length,_=[],y=[];for(let x=0;x<g.length;x++)for(let C=m-1;C>=0;--C){let T=p[C],I=T.layer;if(I.hasRenderer()&&Pr(T,c)&&a.call(l,I)){let S=I.getRenderer(),w=I.getSource();if(S&&w){let M=w.getWrapX()?f:t,N=u.bind(null,T.managed);y[0]=M[0]+g[x][0],y[1]=M[1]+g[x][1],h=S.forEachFeatureAtCoordinate(y,e,i,N,_)}if(h)return h}}if(_.length===0)return;let E=1/_.length;return _.forEach((x,C)=>x.distanceSq+=C*E),_.sort((x,C)=>x.distanceSq-C.distanceSq),_.some(x=>h=x.callback(x.feature,x.layer,x.geometry)),h}hasFeatureAtCoordinate(t,e,i,r,s,o){return this.forEachFeatureAtCoordinate(t,e,i,r,ei,this,s,o)!==void 0}getMap(){return this.map_}renderFrame(t){F()}scheduleExpireIconCache(t){Dt.canExpireCache()&&t.postRenderFunctions.push(Ep)}};function Ep(n,t){Dt.expire()}var df=rh;var sh=class extends df{constructor(t){super(t),this.fontChangeListenerKey_=G(cn,Ee.PROPERTYCHANGE,t.redrawText,t),this.element_=xt?qs():document.createElement("div");let e=this.element_.style;e.position="absolute",e.width="100%",e.height="100%",e.zIndex="0",this.element_.className=ge+" ol-layers";let i=t.getViewport();i&&i.insertBefore(this.element_,i.firstChild||null),this.children_=[],this.renderedVisible_=!0}dispatchRenderEvent(t,e){let i=this.getMap();if(i.hasListener(t)){let r=new Ro(t,void 0,e);i.dispatchEvent(r)}}disposeInternal(){B(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(Lt.PRECOMPOSE,t);let e=t.layerStatesArray.sort((h,c)=>h.zIndex-c.zIndex);e.some(h=>h.layer instanceof Co&&h.layer.getDeclutter())&&(t.declutter={});let r=t.viewState;this.children_.length=0;let s=[],o=null;for(let h=0,c=e.length;h<c;++h){let u=e[h];t.layerIndex=h;let d=u.layer,f=d.getSourceState();if(!Pr(u,r)||f!="ready"&&f!="undefined"){d.unrender();continue}let g=d.render(t,o);g&&(g!==o&&(this.children_.push(g),o=g),s.push(u))}this.declutter(t,s),pd(this.element_,this.children_);let l=this.getMap().getTargetElement();if(Me(l)){let h=l.getContext("2d");for(let c of this.children_){let u=c.firstElementChild||c,d=c.style.backgroundColor;if(d&&(!Me(u)||u.width>0)&&(h.fillStyle=d,h.fillRect(0,0,l.width,l.height)),Me(u)&&u.width>0){h.save();let f=c.style.opacity||u.style.opacity;h.globalAlpha=f===""?1:Number(f);let g=u.style.transform;if(g)h.transform(...Ns(g));else{let p=parseFloat(u.style.width)/u.width,m=parseFloat(u.style.height)/u.height;h.transform(p,0,0,m,0,0)}h.drawImage(u,0,0),h.restore()}}}this.dispatchRenderEvent(Lt.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){let r=e[i],s=r.layer;s.getDeclutter()&&s.renderDeclutter(t,r)}e.forEach(i=>i.layer.renderDeferred(t))}}},ff=sh;function gf(n){if(n instanceof ci){n.setMapInternal(null);return}n instanceof Ar&&n.getLayers().forEach(gf)}function mf(n,t){if(n instanceof ci){n.setMapInternal(t);return}if(n instanceof Ar){let e=n.getLayers().getArray();for(let i=0,r=e.length;i<r;++i)mf(e[i],t)}}var oh=class extends pt{constructor(t){super(),t=t||{},this.on,this.once,this.un;let e=Cp(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:iu,this.postRenderTimeoutHandle_,this.animationDelayKey_,this.animationDelay_=this.animationDelay_.bind(this),this.coordinateToPixelTransform_=Tt(),this.pixelToCoordinateTransform_=Tt(),this.frameIndex_=0,this.frameState_=null,this.previousExtent_=null,this.viewPropertyListenerKey_=null,this.viewChangeListenerKey_=null,this.layerGroupPropertyListenerKeys_=null,xt||(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,xt||(this.resizeObserver_=new ResizeObserver(()=>this.updateSize())),this.controls=e.controls||(xt?new Mt:kn()),this.interactions=e.interactions||(xt?new Mt:jn({onFocusOnly:!0})),this.overlays_=e.overlays,this.overlayIdIndex_={},this.renderer_=null,this.postRenderFunctions_=[],this.tileQueue_=new su(this.getTilePriority.bind(this),this.handleTileChange_.bind(this)),this.addChangeListener(_t.LAYERGROUP,this.handleLayerGroupChanged_),this.addChangeListener(_t.VIEW,this.handleViewChanged_),this.addChangeListener(_t.SIZE,this.handleSizeChanged_),this.addChangeListener(_t.TARGET,this.handleTargetChanged_),this.setProperties(e.values);let i=this;t.view&&!(t.view instanceof Bt)&&t.view.then(function(r){i.setView(new Bt(r))}),this.controls.addEventListener(wt.ADD,r=>{r.element.setMap(this)}),this.controls.addEventListener(wt.REMOVE,r=>{r.element.setMap(null)}),this.interactions.addEventListener(wt.ADD,r=>{r.element.setMap(this)}),this.interactions.addEventListener(wt.REMOVE,r=>{r.element.setMap(null)}),this.overlays_.addEventListener(wt.ADD,r=>{this.addOverlayInternal_(r.element)}),this.overlays_.addEventListener(wt.REMOVE,r=>{let s=r.element.getId();s!==void 0&&delete this.overlayIdIndex_[s.toString()],r.element.setMap(null)}),this.controls.forEach(r=>{r.setMap(this)}),this.interactions.forEach(r=>{r.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){mf(t.layer,this)}addOverlay(t){this.getOverlays().push(t)}addOverlayInternal_(t){let 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;let r=this.getCoordinateFromPixelInternal(t);i=i!==void 0?i:{};let s=i.hitTolerance!==void 0?i.hitTolerance:0,o=i.layerFilter!==void 0?i.layerFilter:ei,a=i.checkWrapped!==!1;return this.renderer_.forEachFeatureAtCoordinate(r,this.frameState_,s,a,e,null,o,null)}getFeaturesAtPixel(t,e){let i=[];return this.forEachFeatureAtPixel(t,function(r){i.push(r)},e),i}getAllLayers(){let t=[];function e(i){i.forEach(function(r){r instanceof Ar?e(r.getLayers()):t.push(r)})}return e(this.getLayers()),t}hasFeatureAtPixel(t,e){if(!this.frameState_||!this.renderer_)return!1;let i=this.getCoordinateFromPixelInternal(t);e=e!==void 0?e:{};let r=e.layerFilter!==void 0?e.layerFilter:ei,s=e.hitTolerance!==void 0?e.hitTolerance:0,o=e.checkWrapped!==!1;return this.renderer_.hasFeatureAtCoordinate(i,this.frameState_,s,o,r,null)}getEventCoordinate(t){return this.getCoordinateFromPixel(this.getEventPixel(t))}getEventCoordinateInternal(t){return this.getCoordinateFromPixelInternal(this.getEventPixel(t))}getEventPixel(t){let i=this.viewport_.getBoundingClientRect(),r=this.getSize(),s=i.width/r[0],o=i.height/r[1],a="changedTouches"in t?t.changedTouches[0]:t;return[(a.clientX-i.left)/s,(a.clientY-i.top)/o]}getTarget(){return this.get(_t.TARGET)}getTargetElement(){return this.targetElement_}getCoordinateFromPixel(t){return gr(this.getCoordinateFromPixelInternal(t),this.getView().getProjection())}getCoordinateFromPixelInternal(t){let e=this.frameState_;return e?ht(e.pixelToCoordinateTransform,t.slice()):null}getControls(){return this.controls}getOverlays(){return this.overlays_}getOverlayById(t){let e=this.overlayIdIndex_[t.toString()];return e!==void 0?e:null}getInteractions(){return this.interactions}getLayerGroup(){return this.get(_t.LAYERGROUP)}setLayers(t){let e=this.getLayerGroup();if(t instanceof Mt){e.setLayers(t);return}let i=e.getLayers();i.clear(),i.extend(t)}getLayers(){return this.getLayerGroup().getLayers()}getLoadingOrNotReady(){let t=this.getLayerGroup().getLayerStatesArray();for(let e=0,i=t.length;e<i;++e){let r=t[e];if(!r.visible)continue;let s=r.layer.getRenderer();if(s&&!s.ready)return!0;let o=r.layer.getSource();if(o&&o.loading)return!0}return!1}getPixelFromCoordinate(t){let e=Ie(t,this.getView().getProjection());return this.getPixelFromCoordinateInternal(e)}getPixelFromCoordinateInternal(t){let e=this.frameState_;return e?ht(e.coordinateToPixelTransform,t.slice(0,2)):null}getPixelRatio(){return this.pixelRatio_}setPixelRatio(t){this.pixelRatio_!==t&&(this.pixelRatio_=t,this.render())}getRenderer(){return this.renderer_}getSize(){return this.get(_t.SIZE)}getView(){return this.get(_t.VIEW)}getViewport(){return this.viewport_}getOverlayContainer(){return this.overlayContainer_}getOverlayContainerStopEvent(){return this.overlayContainerStopEvent_}getOwnerDocument(){let t=this.getTargetElement();return t?t.ownerDocument:document}getTilePriority(t,e,i,r){return ou(this.frameState_,t,e,i,r)}handleBrowserEvent(t,e){e=e||t.type;let i=new We(e,this,t);this.handleMapBrowserEvent(i)}handleMapBrowserEvent(t){if(!this.frameState_)return;let e=t.originalEvent,i=e.type;if(i===Si.POINTERDOWN||i===L.WHEEL||i===L.KEYDOWN){let r=this.getOwnerDocument(),s=this.viewport_.getRootNode?this.viewport_.getRootNode():r,o=e.target,a=s instanceof ShadowRoot?s.host===o?s.host.ownerDocument:s:s===r?r.documentElement:s;if(this.overlayContainerStopEvent_.contains(o)||!a.contains(o))return}if(t.frameState=this.frameState_,this.dispatchEvent(t)!==!1){let r=this.getInteractions().getArray().slice();for(let s=r.length-1;s>=0;s--){let o=r[s];if(o.getMap()!==this||!o.getActive()||!this.getTargetElement())continue;if(!o.handleEvent(t)||t.propagationStopped)break}}}handlePostRender(){let t=this.frameState_,e=this.tileQueue_;if(!e.isEmpty()){let r=this.maxTilesLoading_,s=r;if(t){let o=t.viewHints;if(o[dt.ANIMATING]||o[dt.INTERACTING]){let a=Date.now()-t.time>8;r=a?0:8,s=a?0:2}}e.getTilesLoading()<r&&(e.reprioritize(),e.loadMoreTiles(r,s))}t&&this.renderer_&&!t.animate&&(this.renderComplete_?(this.hasListener(Lt.RENDERCOMPLETE)&&this.renderer_.dispatchRenderEvent(Lt.RENDERCOMPLETE,t),this.loaded_===!1&&(this.loaded_=!0,this.dispatchEvent(new wi(Xe.LOADEND,this,t)))):this.loaded_===!0&&(this.loaded_=!1,this.dispatchEvent(new wi(Xe.LOADSTART,this,t))));let i=this.postRenderFunctions_;if(t)for(let r=0,s=i.length;r<s;++r)i[r](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,r=this.targetChangeHandlerKeys_.length;i<r;++i)B(this.targetChangeHandlerKeys_[i]);this.targetChangeHandlerKeys_=null,this.viewport_.removeEventListener(L.CONTEXTMENU,this.boundHandleBrowserEvent_),this.viewport_.removeEventListener(L.WHEEL,this.boundHandleBrowserEvent_),this.mapBrowserEventHandler_.dispose(),this.mapBrowserEventHandler_=null,this.viewport_.remove()}if(this.targetElement_&&!Me(this.targetElement_)){this.resizeObserver_?.unobserve(this.targetElement_);let i=this.targetElement_.getRootNode();i instanceof ShadowRoot&&this.resizeObserver_.unobserve(i.host),this.setSize(void 0)}let 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(Me(e)||e.appendChild(this.viewport_),this.renderer_||(this.renderer_=new ff(this)),!Me(e)){this.mapBrowserEventHandler_=new nu(this,this.moveTolerance_);for(let r in at)this.mapBrowserEventHandler_.addEventListener(at[r],this.handleMapBrowserEvent.bind(this));this.viewport_.addEventListener(L.CONTEXTMENU,this.boundHandleBrowserEvent_,!1),this.viewport_.addEventListener(L.WHEEL,this.boundHandleBrowserEvent_,Es?{passive:!1}:!1);let i;if(this.keyboardEventTarget_)i=this.keyboardEventTarget_;else{let r=e.getRootNode();i=r instanceof ShadowRoot?r.host:e}if(this.targetChangeHandlerKeys_=[G(i,L.KEYDOWN,this.handleBrowserEvent,this),G(i,L.KEYPRESS,this.handleBrowserEvent,this)],e instanceof HTMLElement){let r=e.getRootNode();r instanceof ShadowRoot&&this.resizeObserver_.observe(r.host),this.resizeObserver_?.observe(e)}}this.updateSize()}}handleTileChange_(){this.render()}handleViewPropertyChanged_(){this.render()}handleViewChanged_(){this.viewPropertyListenerKey_&&(B(this.viewPropertyListenerKey_),this.viewPropertyListenerKey_=null),this.viewChangeListenerKey_&&(B(this.viewChangeListenerKey_),this.viewChangeListenerKey_=null);let t=this.getView();t&&(this.updateViewportSize_(this.getSize()),this.viewPropertyListenerKey_=G(t,Ee.PROPERTYCHANGE,this.handleViewPropertyChanged_,this),this.viewChangeListenerKey_=G(t,L.CHANGE,this.handleViewPropertyChanged_,this),t.resolveConstraints(0)),this.render()}handleLayerGroupChanged_(){this.layerGroupPropertyListenerKeys_&&(this.layerGroupPropertyListenerKeys_.forEach(B),this.layerGroupPropertyListenerKeys_=null);let t=this.getLayerGroup();t&&(this.handleLayerAdd_(new be("addlayer",t)),this.layerGroupPropertyListenerKeys_=[G(t,Ee.PROPERTYCHANGE,this.render,this),G(t,L.CHANGE,this.render,this),G(t,"addlayer",this.handleLayerAdd_,this),G(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;let t=this.frameState_.layerStatesArray;for(let e=0,i=t.length;e<i;++e){let r=t[e].layer;r.hasRenderer()&&r.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){gf(t.layer)}removeOverlay(t){return this.getOverlays().remove(t)}renderFrame_(t){let e=this.getSize(),i=this.getView(),r=this.frameState_,s=null;if(e!==void 0&&Ll(e)&&i&&i.isDef()){let o=i.getHints(this.frameState_?this.frameState_.viewHints:void 0),a=i.getState();if(s={animate:!1,coordinateToPixelTransform:this.coordinateToPixelTransform_,declutter:null,extent:oi(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:U(this),renderTargets:{}},a.nextCenter&&a.nextResolution){let l=isNaN(a.nextRotation)?a.rotation:a.nextRotation;s.nextExtent=oi(a.nextCenter,a.nextResolution,l,e)}}this.frameState_=s,this.renderer_.renderFrame(s),s&&(s.animate&&this.render(),Array.prototype.push.apply(this.postRenderFunctions_,s.postRenderFunctions),r&&(!this.previousExtent_||!Yt(this.previousExtent_)&&!we(s.extent,this.previousExtent_))&&(this.dispatchEvent(new wi(Xe.MOVESTART,this,r)),this.previousExtent_=si(this.previousExtent_)),this.previousExtent_&&!s.viewHints[dt.ANIMATING]&&!s.viewHints[dt.INTERACTING]&&!we(s.extent,this.previousExtent_)&&(this.dispatchEvent(new wi(Xe.MOVEEND,this,s)),Ss(s.extent,this.previousExtent_))),this.dispatchEvent(new wi(Xe.POSTRENDER,this,s)),this.renderComplete_=(this.hasListener(Xe.LOADSTART)||this.hasListener(Xe.LOADEND)||this.hasListener(Lt.RENDERCOMPLETE))&&!this.tileQueue_.getTilesLoading()&&!this.tileQueue_.getCount()&&!this.getLoadingOrNotReady(),this.postRenderTimeoutHandle_||(this.postRenderTimeoutHandle_=setTimeout(()=>{this.postRenderTimeoutHandle_=void 0,this.handlePostRender()},0))}setLayerGroup(t){let e=this.getLayerGroup();e&&this.handleLayerRemove_(new be("removelayer",e)),this.set(_t.LAYERGROUP,t)}setSize(t){this.set(_t.SIZE,t)}setTarget(t){this.set(_t.TARGET,t)}setView(t){if(!t||t instanceof Bt){this.set(_t.VIEW,t);return}this.set(_t.VIEW,new Bt);let e=this;t.then(function(i){e.setView(new Bt(i))})}updateSize(){let t=this.getTargetElement(),e;if(t){let r,s;if(Me(t)){let o=t.getContext("2d").getTransform();r=t.width/o.a,s=t.height/o.d}else{let o=getComputedStyle(t);r=t.offsetWidth-parseFloat(o.borderLeftWidth)-parseFloat(o.paddingLeft)-parseFloat(o.paddingRight)-parseFloat(o.borderRightWidth),s=t.offsetHeight-parseFloat(o.borderTopWidth)-parseFloat(o.paddingTop)-parseFloat(o.paddingBottom)-parseFloat(o.borderBottomWidth)}!isNaN(r)&&!isNaN(s)&&(e=[Math.max(0,r),Math.max(0,s)],!Ll(e)&&(t.offsetWidth||t.offsetHeight||t.getClientRects().length)&&bs("No map visible because the map container's width or height are 0."))}let i=this.getSize();e&&(!i||!Ot(e,i))&&(this.setSize(e),this.updateViewportSize_(e))}updateViewportSize_(t){let e=this.getView();e&&e.setViewportSize(t)}};function Cp(n){let t=null;n.keyboardEventTarget!==void 0&&(t=typeof n.keyboardEventTarget=="string"?document.getElementById(n.keyboardEventTarget):n.keyboardEventTarget);let e={},i=n.layers&&typeof n.layers.getLayers=="function"?n.layers:new Ar({layers:n.layers});e[_t.LAYERGROUP]=i,e[_t.TARGET]=n.target,e[_t.VIEW]=n.view instanceof Bt?n.view:new Bt;let r;n.controls!==void 0&&(Array.isArray(n.controls)?r=new Mt(n.controls.slice()):(V(typeof n.controls.getArray=="function","Expected `controls` to be an array or an `ol/Collection.js`"),r=n.controls));let s;n.interactions!==void 0&&(Array.isArray(n.interactions)?s=new Mt(n.interactions.slice()):(V(typeof n.interactions.getArray=="function","Expected `interactions` to be an array or an `ol/Collection.js`"),s=n.interactions));let o;return n.overlays!==void 0?Array.isArray(n.overlays)?o=new Mt(n.overlays.slice()):(V(typeof n.overlays.getArray=="function","Expected `overlays` to be an array or an `ol/Collection.js`"),o=n.overlays):o=new Mt,{controls:r,interactions:s,keyboardEventTarget:t,overlays:o,values:e}}var ah=oh;var lh=class extends je{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(L.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(){F()}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;let r=e-i+1e3/60;return r>=this.transition_?1:ya(r/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()}},Kn=lh;function wo(n){return n instanceof Image||n instanceof HTMLCanvasElement||n instanceof HTMLVideoElement||n instanceof ImageBitmap?n:null}var Rp=new Error("disposed");var wp=[256,256],hh=class extends Kn{constructor(t){let 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_;let t=wo(this.data_);return t?[t.width,t.height]:wp}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();let 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(Rp),this.controller_=null),super.disposeInternal()}},ch=hh;var uh=class extends Kn{constructor(t,e,i,r,s,o){super(t,e,o),this.crossOrigin_=r?.crossOrigin,this.referrerPolicy_=r?.referrerPolicy,this.src_=i,this.key=i,this.image_,xt?this.image_=new OffscreenCanvas(1,1):(this.image_=new Image,this.crossOrigin_!==null&&(this.image_.crossOrigin=this.crossOrigin_),this.referrerPolicy_!==void 0&&(this.image_.referrerPolicy=this.referrerPolicy_)),this.unlisten_=null,this.tileLoadFunction_=s}getImage(){return this.image_}setImage(t){this.image_=t,this.state=O.LOADED,this.unlistenImage_(),this.changed()}getCrossOrigin(){return this.crossOrigin_}getReferrerPolicy(){return this.referrerPolicy_}handleImageError_(){this.state=O.ERROR,this.unlistenImage_(),this.image_=Sp(),this.changed()}handleImageLoad_(){if(xt)this.state=O.LOADED;else{let 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.referrerPolicy_!==void 0&&(this.image_.referrerPolicy=this.referrerPolicy_)),this.state==O.IDLE&&(this.state=O.LOADING,this.changed(),this.tileLoadFunction_(this,this.src_),this.unlisten_=Ud(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 Sp(){let n=nt(1,1);return n.fillStyle="rgba(0,0,0,0)",n.fillRect(0,0,1,1),n.canvas}var So=uh;var To=class{constructor(t,e,i,r){this.minX=t,this.maxX=e,this.minY=i,this.maxY=r}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 dn(n,t,e,i,r){return r!==void 0?(r.minX=n,r.maxX=t,r.minY=e,r.maxY=i,r):new To(n,t,e,i)}var vo=To;var dh,fn=[];function pf(n,t,e,i,r){n.beginPath(),n.moveTo(0,0),n.lineTo(t,e),n.lineTo(i,r),n.closePath(),n.save(),n.clip(),n.fillRect(0,0,Math.max(t,i)+1,Math.max(e,r)),n.restore()}function fh(n,t){return Math.abs(n[t*4]-210)>2||Math.abs(n[t*4+3]-.75*255)>2}function Tp(){if(dh===void 0){let n=nt(6,6,fn);n.globalCompositeOperation="lighter",n.fillStyle="rgba(210, 0, 0, 0.75)",pf(n,4,5,4,0),pf(n,4,5,0,5);let t=n.getImageData(0,0,3,3).data;dh=fh(t,0)||fh(t,4)||fh(t,8),on(n),fn.push(n.canvas)}return dh}function Vi(n,t,e,i){let r=de(e,t,n),s=An(t,i,e),o=t.getMetersPerUnit();o!==void 0&&(s*=o);let a=n.getMetersPerUnit();a!==void 0&&(s/=a);let l=n.getExtent();if(!l||Jt(l,r)){let h=An(n,s,r)/s;isFinite(h)&&h>0&&(s/=h)}return s}function _f(n,t,e,i){let r=St(e),s=Vi(n,t,r,i);return(!isFinite(s)||s<=0)&&Is(e,function(o){return s=Vi(n,t,o,i),isFinite(s)&&s>0}),s}function Io(n,t,e,i,r,s,o,a,l,h,c,u,d,f){let g=nt(Math.round(e*n),Math.round(e*t),fn);if(u||(g.imageSmoothingEnabled=!1),l.length===0)return g.canvas;g.scale(e,e);function p(C){return Math.round(C*e)/e}g.globalCompositeOperation="lighter";let m=ct();l.forEach(function(C,T,I){vs(m,C.extent)});let _,y=e/i,E=(u?1:1+Math.pow(2,-24))/y;if(!d||l.length!==1||h!==0){if(_=nt(Math.round(W(m)*y),Math.round(et(m)*y),fn),u||(_.imageSmoothingEnabled=!1),r&&f){let C=(r[0]-m[0])*y,T=-(r[3]-m[3])*y,I=W(r)*y,S=et(r)*y;_.rect(C,T,I,S),_.clip()}l.forEach(function(C,T,I){if(C.image.width>0&&C.image.height>0){if(C.clipExtent){_.save();let z=(C.clipExtent[0]-m[0])*y,A=-(C.clipExtent[3]-m[3])*y,H=W(C.clipExtent)*y,$=et(C.clipExtent)*y;_.rect(u?z:Math.round(z),u?A:Math.round(A),u?H:Math.round(z+H)-Math.round(z),u?$:Math.round(A+$)-Math.round(A)),_.clip()}let S=(C.extent[0]-m[0])*y,w=-(C.extent[3]-m[3])*y,M=W(C.extent)*y,N=et(C.extent)*y;_.drawImage(C.image,h,h,C.image.width-2*h,C.image.height-2*h,u?S:Math.round(S),u?w:Math.round(w),u?M:Math.round(S+M)-Math.round(S),u?N:Math.round(w+N)-Math.round(w)),C.clipExtent&&_.restore()}})}let x=he(o);return a.getTriangles().forEach(function(C,T,I){let S=C.source,w=C.target,M=S[0][0],N=S[0][1],z=S[1][0],A=S[1][1],H=S[2][0],$=S[2][1],P=p((w[0][0]-x[0])/s),j=p(-(w[0][1]-x[1])/s),k=p((w[1][0]-x[0])/s),K=p(-(w[1][1]-x[1])/s),X=p((w[2][0]-x[0])/s),tt=p(-(w[2][1]-x[1])/s),it=M,ot=N;M=0,N=0,z-=it,A-=ot,H-=it,$-=ot;let kt=[[z,A,0,0,k-P],[H,$,0,0,X-P],[0,0,z,A,K-j],[0,0,H,$,tt-j]],v=lu(kt);if(!v)return;if(g.save(),g.beginPath(),Tp()||!u){g.moveTo(k,K);let Rt=4,ye=P-k,De=j-K;for(let ne=0;ne<Rt;ne++)g.lineTo(k+p((ne+1)*ye/Rt),K+p(ne*De/(Rt-1))),ne!=Rt-1&&g.lineTo(k+p((ne+1)*ye/Rt),K+p((ne+1)*De/(Rt-1)));g.lineTo(X,tt)}else g.moveTo(k,K),g.lineTo(P,j),g.lineTo(X,tt);g.clip(),g.transform(v[0],v[2],v[1],v[3],P,j),g.translate(m[0]-it,m[3]-ot);let ie;if(_)ie=_.canvas,g.scale(E,-E);else{let Rt=l[0],ye=Rt.extent;ie=Rt.image,g.scale(W(ye)/ie.width,-et(ye)/ie.height)}g.drawImage(ie,0,0),g.restore()}),_&&(on(_),fn.push(_.canvas)),c&&(g.save(),g.globalCompositeOperation="source-over",g.strokeStyle="black",g.lineWidth=1,a.getTriangles().forEach(function(C,T,I){let S=C.target,w=(S[0][0]-x[0])/s,M=-(S[0][1]-x[1])/s,N=(S[1][0]-x[0])/s,z=-(S[1][1]-x[1])/s,A=(S[2][0]-x[0])/s,H=-(S[2][1]-x[1])/s;g.beginPath(),g.moveTo(N,z),g.lineTo(w,M),g.lineTo(A,H),g.closePath(),g.stroke()}),g.restore()),g.canvas}var vp=10,yf=.25,gh=class{constructor(t,e,i,r,s,o,a){this.sourceProj_=t,this.targetProj_=e;let l={},h=a?ju(E=>ht(a,de(E,this.targetProj_,this.sourceProj_))):li(this.targetProj_,this.sourceProj_);this.transformInv_=function(E){let x=E[0]+"/"+E[1];return l[x]||(l[x]=h(E)),l[x]},this.maxSourceExtent_=r,this.errorThresholdSquared_=s*s,this.triangles_=[],this.wrapsXInSource_=!1,this.canWrapXInSource_=this.sourceProj_.canWrapX()&&!!r&&!!this.sourceProj_.getExtent()&&W(r)>=W(this.sourceProj_.getExtent()),this.sourceWorldWidth_=this.sourceProj_.getExtent()?W(this.sourceProj_.getExtent()):null,this.targetWorldWidth_=this.targetProj_.getExtent()?W(this.targetProj_.getExtent()):null;let c=he(i),u=wn(i),d=Rn(i),f=Cn(i),g=this.transformInv_(c),p=this.transformInv_(u),m=this.transformInv_(d),_=this.transformInv_(f),y=vp+(o?Math.max(0,Math.ceil(Math.log2(cr(i)/(o*o*256*256)))):0);if(this.addQuad_(c,u,d,f,g,p,m,_,y),this.wrapsXInSource_){let E=1/0;this.triangles_.forEach(function(x,C,T){E=Math.min(E,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])-E>this.sourceWorldWidth_/2){let C=[[x.source[0][0],x.source[0][1]],[x.source[1][0],x.source[1][1]],[x.source[2][0],x.source[2][1]]];C[0][0]-E>this.sourceWorldWidth_/2&&(C[0][0]-=this.sourceWorldWidth_),C[1][0]-E>this.sourceWorldWidth_/2&&(C[1][0]-=this.sourceWorldWidth_),C[2][0]-E>this.sourceWorldWidth_/2&&(C[2][0]-=this.sourceWorldWidth_);let T=Math.min(C[0][0],C[1][0],C[2][0]);Math.max(C[0][0],C[1][0],C[2][0])-T<this.sourceWorldWidth_/2&&(x.source=C)}})}l={}}addTriangle_(t,e,i,r,s,o){this.triangles_.push({source:[r,s,o],target:[t,e,i]})}addQuad_(t,e,i,r,s,o,a,l,h){let c=ga([s,o,a,l]),u=this.sourceWorldWidth_?W(c)/this.sourceWorldWidth_:null,d=this.sourceWorldWidth_,f=this.sourceProj_.canWrapX()&&u>.5&&u<1,g=!1;if(h>0){if(this.targetProj_.isGlobal()&&this.targetWorldWidth_){let m=ga([t,e,i,r]);g=W(m)/this.targetWorldWidth_>yf||g}!f&&this.sourceProj_.isGlobal()&&u&&(g=u>yf||g)}if(!g&&this.maxSourceExtent_&&isFinite(c[0])&&isFinite(c[1])&&isFinite(c[2])&&isFinite(c[3])&&!lt(c,this.maxSourceExtent_))return;let p=0;if(!g&&(!isFinite(s[0])||!isFinite(s[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(p=(!isFinite(s[0])||!isFinite(s[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),p!=1&&p!=2&&p!=4&&p!=8)return}if(h>0){if(!g){let m=[(t[0]+i[0])/2,(t[1]+i[1])/2],_=this.transformInv_(m),y;f?y=(Wt(s[0],d)+Wt(a[0],d))/2-Wt(_[0],d):y=(s[0]+a[0])/2-_[0];let E=(s[1]+a[1])/2-_[1];g=y*y+E*E>this.errorThresholdSquared_}if(g){if(Math.abs(t[0]-i[0])<=Math.abs(t[1]-i[1])){let m=[(e[0]+i[0])/2,(e[1]+i[1])/2],_=this.transformInv_(m),y=[(r[0]+t[0])/2,(r[1]+t[1])/2],E=this.transformInv_(y);this.addQuad_(t,e,m,y,s,o,_,E,h-1),this.addQuad_(y,m,i,r,E,_,a,l,h-1)}else{let m=[(t[0]+e[0])/2,(t[1]+e[1])/2],_=this.transformInv_(m),y=[(i[0]+r[0])/2,(i[1]+r[1])/2],E=this.transformInv_(y);this.addQuad_(t,m,y,r,s,_,E,l,h-1),this.addQuad_(m,e,i,y,_,o,a,E,h-1)}return}}if(f){if(!this.canWrapXInSource_)return;this.wrapsXInSource_=!0}(p&11)==0&&this.addTriangle_(t,i,r,s,a,l),(p&14)==0&&this.addTriangle_(t,i,e,s,a,o),p&&((p&13)==0&&this.addTriangle_(e,r,t,o,l,s),(p&7)==0&&this.addTriangle_(e,r,i,o,l,a))}calculateSourceExtent(){let t=ct();return this.triangles_.forEach(function(e,i,r){let s=e.source;Qi(t,s[0]),Qi(t,s[1]),Qi(t,s[2])}),t}getTriangles(){return this.triangles_}},Mo=gh;var mh=class extends Kn{constructor(t,e,i,r,s,o,a,l,h,c,u,d){super(s,O.IDLE,d),this.renderEdges_=u!==void 0?u:!1,this.pixelRatio_=a,this.gutter_=l,this.canvas_=null,this.sourceTileGrid_=e,this.targetTileGrid_=r,this.wrappedTileCoord_=o||s,this.sourceTiles_=[],this.sourcesListenerKeys_=null,this.sourceZ_=0,this.clipExtent_=t.canWrapX()?t.getExtent():void 0;let f=r.getTileCoordExtent(this.wrappedTileCoord_),g=this.targetTileGrid_.getExtent(),p=this.sourceTileGrid_.getExtent(),m=g?Ut(f,g):f;if(cr(m)===0){this.state=O.EMPTY;return}let _=t.getExtent();_&&(p?p=Ut(p,_):p=_);let y=r.getResolution(this.wrappedTileCoord_[0]),E=_f(t,i,m,y);if(!isFinite(E)||E<=0){this.state=O.EMPTY;return}let x=c!==void 0?c:.5;if(this.triangulation_=new Mo(t,i,m,p,E*x,y),this.triangulation_.getTriangles().length===0){this.state=O.EMPTY;return}this.sourceZ_=e.getZForResolution(E);let C=this.triangulation_.calculateSourceExtent();if(p&&(t.canWrapX()?(C[1]=Q(C[1],p[1],p[3]),C[3]=Q(C[3],p[1],p[3])):C=Ut(C,p)),!cr(C))this.state=O.EMPTY;else{let T=0,I=0;t.canWrapX()&&(T=W(_),I=Math.floor((C[0]-_[0])/T)),Ms(C.slice(),t,!0).forEach(w=>{let M=e.getTileRangeForExtentAndZ(w,this.sourceZ_);for(let N=M.minX;N<=M.maxX;N++)for(let z=M.minY;z<=M.maxY;z++){let A=I*T;this.sourceTiles_.push({getTile:()=>h(this.sourceZ_,N,z,a),offset:A})}++I}),this.sourceTiles_.length===0&&(this.state=O.EMPTY)}}getImage(){return this.canvas_}reproject_(){let t=[];if(this.sourceTiles_.forEach(e=>{let i=e.tile;if(i&&i.getState()==O.LOADED){let r=this.sourceTileGrid_.getTileCoordExtent(i.tileCoord);r[0]+=e.offset,r[2]+=e.offset;let s=this.clipExtent_?.slice();s&&(s[0]+=e.offset,s[2]+=e.offset),t.push({extent:r,clipExtent:s,image:i.getImage()})}}),this.sourceTiles_.length=0,t.length===0)this.state=O.ERROR;else{let e=this.wrappedTileCoord_[0],i=this.targetTileGrid_.getTileSize(e),r=typeof i=="number"?i:i[0],s=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_=Io(r,s,this.pixelRatio_,a,this.sourceTileGrid_.getExtent(),o,l,this.triangulation_,t,this.gutter_,this.renderEdges_,this.interpolate),this.state=O.LOADED}this.changed()}load(){for(let t of this.sourceTiles_)t.tile=t.getTile();if(this.state==O.IDLE){this.state=O.LOADING,this.changed();let t=0;this.sourcesListenerKeys_=[],this.sourceTiles_.forEach(({tile:e})=>{let i=e.getState();if(i==O.IDLE||i==O.LOADING){t++;let r=G(e,L.CHANGE,s=>{let o=e.getState();(o==O.LOADED||o==O.ERROR||o==O.EMPTY)&&(B(r),t--,t===0&&(this.unlistenSources_(),this.reproject_()))});this.sourcesListenerKeys_.push(r)}}),t===0?setTimeout(this.reproject_.bind(this),0):this.sourceTiles_.forEach(function({tile:e},i,r){e.getState()==O.IDLE&&e.load()})}}unlistenSources_(){this.sourcesListenerKeys_.forEach(B),this.sourcesListenerKeys_=null}release(){this.canvas_&&(on(this.canvas_.getContext("2d")),fn.push(this.canvas_),this.canvas_=null),this.sourceTiles_.length=0,super.release()}},bo=mh;var ph=class{constructor(t){this.highWaterMark=t!==void 0?t:2048,this.count_=0,this.entries_={},this.oldest_=null,this.newest_=null}deleteOldest(){let t=this.pop();t instanceof Ci&&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){let i=this.entries_[t];return V(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){let e=this.entries_[t];return V(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(){let t=new Array(this.count_),e=0,i;for(i=this.newest_;i;i=i.older)t[e++]=i.key_;return t}getValues(){let t=new Array(this.count_),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(){let 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){V(!(t in this.entries_),"Tried to set a value for a key that is used already");let 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}},_h=ph;function Vn(n,t,e,i){return i!==void 0?(i[0]=n,i[1]=t,i[2]=e,i):[n,t,e]}function Mp(n,t,e){return n+"/"+t+"/"+e}function Bn(n,t,e,i,r){return`${U(n)},${t},${Mp(e,i,r)}`}function Lo(n){return bp(n[0],n[1],n[2])}function bp(n,t,e){return(t<<n)+e}function xf(n,t){let e=n[0],i=n[1],r=n[2];if(t.getMinZoom()>e||e>t.getMaxZoom())return!1;let s=t.getFullTileRange(e);return s?s.containsXY(i,r):!0}var yh=class{constructor(){this.instructions_=[],this.zIndex=0,this.offset_=0,this.context_=new Proxy(Fn(),{get:(t,e)=>{if(typeof Fn()[e]=="function")return this.push_(e),this.pushMethodArgs_},set:(t,e,i)=>(this.push_(e,i),!0)})}push_(...t){let 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,r=e.length;i<r;++i){let s=e[i];if(typeof s=="function"){s(t);continue}let o=e[++i];if(typeof t[s]=="function")t[s](...o);else{if(typeof o=="function"){t[s]=o(t);continue}t[s]=o}}})}clear(){this.instructions_.length=0,this.zIndex=0,this.offset_=0}offset(){this.offset_=this.instructions_.length,this.zIndex=0}},Ao=yh;var Lp=5,xh=class extends _s{constructor(t){super(),this.ready=!0,this.boundHandleImageChange_=this.handleImageChange_.bind(this),this.layer_=t,this.staleKeys_=new Array,this.maxStaleKeys=Lp}getStaleKeys(){return this.staleKeys_}prependStaleKey(t){this.staleKeys_.unshift(t),this.staleKeys_.length>this.maxStaleKeys&&(this.staleKeys_.length=this.maxStaleKeys)}getFeatures(t){return F()}getData(t){return null}prepareFrame(t){return F()}renderFrame(t,e){return F()}forEachFeatureAtCoordinate(t,e,i,r,s){}getLayer(){return this.layer_}handleFontsChanged(){}handleImageChange_(t){let e=t.target;(e.getState()===b.LOADED||e.getState()===b.ERROR)&&this.renderIfReadyAndVisible()}loadImage(t){let e=t.getState();return e!=b.LOADED&&e!=b.ERROR&&t.addEventListener(L.CHANGE,this.boundHandleImageChange_),e==b.IDLE&&(t.load(),e=t.getState()),e==b.LOADED}renderIfReadyAndVisible(){let t=this.getLayer();t&&t.getVisible()&&t.getSourceState()==="ready"&&t.changed()}renderDeferred(t){}disposeInternal(){delete this.layer_,super.disposeInternal()}},Ef=xh;var Ch=[],Zn=null;function Ap(){Zn=nt(1,1,void 0,{willReadFrequently:!0})}var Eh=class extends Ef{constructor(t){super(t),this.container=null,this.renderedResolution,this.tempTransform=Tt(),this.pixelTransform=Tt(),this.inversePixelTransform=Tt(),this.context=null,this.deferredContext_=null,this.containerReused=!1,this.frameState=null}getImageData(t,e,i){Zn||Ap(),Zn.clearRect(0,0,1,1);let r;try{Zn.drawImage(t,e,i,1,1,0,0,1,1),r=Zn.getImageData(0,0,1,1).data}catch{return Zn=null,null}return r}getBackground(t){let i=this.getLayer().getBackground();return typeof i=="function"&&(i=i(t.viewState.resolution)),i||void 0}useContainer(t,e,i){let r=this.getLayer().getClassName(),s,o;if(t&&t.className===r&&(!i||t&&t.style.backgroundColor&&Ot(_e(t.style.backgroundColor),_e(i)))){let a=t.firstElementChild;Me(a)&&(o=a.getContext("2d"))}if(o&&Ku(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){s=xt?qs():document.createElement("div"),s.className=r;let a=s.style;a.position="absolute",a.width="100%",a.height="100%",o=nt();let l=o.canvas;s.appendChild(l),a=l.style,a.position="absolute",a.left="0",a.transformOrigin="top left",this.container=s,this.context=o}!this.containerReused&&i&&!this.container.style.backgroundColor&&(this.container.style.backgroundColor=i)}clipUnrotated(t,e,i){let r=he(i),s=wn(i),o=Rn(i),a=Cn(i);ht(e.coordinateToPixelTransform,r),ht(e.coordinateToPixelTransform,s),ht(e.coordinateToPixelTransform,o),ht(e.coordinateToPixelTransform,a);let l=this.inversePixelTransform;ht(l,r),ht(l,s),ht(l,o),ht(l,a),t.save(),t.beginPath(),t.moveTo(Math.round(r[0]),Math.round(r[1])),t.lineTo(Math.round(s[0]),Math.round(s[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){let i=t.extent,r=t.viewState.resolution,s=t.viewState.rotation,o=t.pixelRatio,a=Math.round(W(i)/r*o),l=Math.round(et(i)/r*o);Et(this.pixelTransform,t.size[0]/2,t.size[1]/2,1/o,1/o,s,-a/2,-l/2),Gs(this.inversePixelTransform,this.pixelTransform);let h=Yu(this.pixelTransform);if(this.useContainer(e,h,this.getBackground(t)),!this.containerReused){let 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){let r=this.getLayer();if(r.hasListener(t)){let s=new Ro(t,this.inversePixelTransform,i,e);r.dispatchEvent(s)}}preRender(t,e){this.frameState=e,!e.declutter&&this.dispatchRenderEvent_(Lt.PRERENDER,t,e)}postRender(t,e){e.declutter||this.dispatchRenderEvent_(Lt.POSTRENDER,t,e)}renderDeferredInternal(t){}getRenderContext(t){return t.declutter&&!this.deferredContext_&&(this.deferredContext_=new Ao),t.declutter?this.deferredContext_.getContext():this.context}renderDeferred(t){t.declutter&&(this.dispatchRenderEvent_(Lt.PRERENDER,this.context,t),t.declutter&&this.deferredContext_&&(this.deferredContext_.draw(this.context),this.deferredContext_.clear()),this.renderDeferredInternal(t),this.dispatchRenderEvent_(Lt.POSTRENDER,this.context,t))}getRenderTransform(t,e,i,r,s,o,a){let l=s/2,h=o/2,c=r/e,u=-c,d=-t[0]+a,f=-t[1];return Et(this.tempTransform,l,h,c,u,-i,d,f)}disposeInternal(){delete this.frameState,super.disposeInternal()}},Hn=Eh;function Rh(n,t,e){if(!(e in n))return n[e]=new Set([t]),!0;let i=n[e],r=i.has(t);return r||i.add(t),!r}function Pp(n,t,e){let i=n[e];return i?i.delete(t):!1}function Cf(n,t){let e=n.layerStatesArray[n.layerIndex];e.extent&&(t=Ut(t,Gt(e.extent,n.viewState.projection)));let i=e.layer.getRenderSource();if(!i.getWrapX()){let r=i.getTileGridForProjection(n.viewState.projection).getExtent();r&&(t=Ut(t,r))}return t}var wh=class extends Hn{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=ct(),this.tempTileRange_=new vo(0,0,0,0),this.tempTileCoord_=Vn(0,0,0);let i=e.cacheSize!==void 0?e.cacheSize:512;this.tileCache_=new _h(i),this.sourceTileCache_=null,this.maxStaleKeys=i*.5}getTileCache(){return this.tileCache_}getSourceTileCache(){return this.sourceTileCache_||(this.sourceTileCache_=new _h(512)),this.sourceTileCache_}getOrCreateTile(t,e,i,r){let s=this.tileCache_,a=this.getLayer().getSource(),l=Bn(a,a.getKey(),t,e,i),h;if(s.containsKey(l))h=s.get(l);else{let c=r.viewState.projection,u=a.getProjection();if(h=a.getTile(t,e,i,r.pixelRatio,c,!u||ve(u,c)?void 0:this.getSourceTileCache()),!h)return null;s.set(l,h)}return h}getTile(t,e,i,r){let s=this.getOrCreateTile(t,e,i,r);return s||null}getData(t){let e=this.frameState;if(!e)return null;let i=this.getLayer(),r=ht(e.pixelToCoordinateTransform,t.slice()),s=i.getExtent();if(s&&!Jt(s,r))return null;let 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){let u=l.getTileCoordForCoordAndZ(r,c),d=this.getTile(c,u[1],u[2],e);if(!d||d.getState()!==O.LOADED)continue;let f=l.getOrigin(c),g=ft(l.getTileSize(c)),p=l.getResolution(c),m;if(d instanceof So||d instanceof bo)m=d.getImage();else if(d instanceof ch){if(m=wo(d.getData()),!m)continue}else continue;let _=Math.floor(h*((r[0]-f[0])/p-u[1]*g[0])),y=Math.floor(h*((f[1]-r[1])/p-u[2]*g[1])),E=Math.round(h*a.getGutterForProjection(o.projection));return this.getImageData(m,_+E,y+E)}return null}prepareFrame(t){this.renderedProjection?t.viewState.projection!==this.renderedProjection&&(this.tileCache_.clear(),this.renderedProjection=t.viewState.projection):this.renderedProjection=t.viewState.projection;let e=this.getLayer().getSource();if(!e)return!1;let 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,r,s){let o=t.viewState,a=this.getLayer(),l=a.getRenderSource(),h=l.getTileGridForProjection(o.projection),c=U(l);c in t.wantedTiles||(t.wantedTiles[c]={});let u=t.wantedTiles[c],d=a.getMapInternal(),f=Math.max(i-s,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,p=g?pa(o.center,o.resolution,g,t.size):void 0;for(let m=i;m>=f;--m){let _=h.getTileRangeForExtentAndZ(e,m,this.tempTileRange_),y=h.getResolution(m);for(let E=_.minX;E<=_.maxX;++E)for(let x=_.minY;x<=_.maxY;++x){if(g&&!h.tileCoordIntersectsViewport([m,E,x],p))continue;let C=this.getTile(m,E,x,t);if(!C||!Rh(r,C,m))continue;let I=C.getKey();if(u[I]=!0,C.getState()===O.IDLE&&!t.tileQueue.isKeyQueued(I)){let S=Vn(m,E,x,this.tempTileCoord_);t.tileQueue.enqueue([C,c,h.getTileCoordCenter(S),y])}}}}findStaleTile_(t,e){let i=this.tileCache_,r=t[0],s=t[1],o=t[2],a=this.getStaleKeys();for(let l=0;l<a.length;++l){let h=Bn(this.getLayer().getSource(),a[l],r,s,o);if(i.containsKey(h)){let c=i.peek(h);if(c.getState()===O.LOADED)return c.endTransition(U(this)),Rh(e,c,r),!0}}return!1}findAltTiles_(t,e,i,r){let s=t.getTileRangeForTileCoordAndZ(e,i,this.tempTileRange_);if(!s)return!1;let o=!0,a=this.tileCache_,l=this.getLayer().getRenderSource(),h=l.getKey();for(let c=s.minX;c<=s.maxX;++c)for(let u=s.minY;u<=s.maxY;++u){let d=Bn(l,h,i,c,u),f=!1;if(a.containsKey(d)){let g=a.peek(d);g.getState()===O.LOADED&&(Rh(r,g,i),f=!0)}f||(o=!1)}return o}renderFrame(t,e){this.renderComplete=!0;let i=t.layerStatesArray[t.layerIndex],r=t.viewState,s=r.projection,o=r.resolution,a=r.center,l=t.pixelRatio,h=this.getLayer(),c=h.getSource(),u=c.getTileGridForProjection(s),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 p=t.extent,m=c.getTilePixelRatio(l);this.prepareContainer(t,e);let _=this.context.canvas.width,y=this.context.canvas.height,E=i.extent&&Gt(i.extent,s);E&&(p=Ut(p,Gt(i.extent,s)));let x=f*_/2/m,C=f*y/2/m,T=[a[0]-x,a[1]-C,a[0]+x,a[1]+C],I={};this.renderedTiles.length=0;let S=h.getPreload();if(t.nextExtent&&this.enqueueTilesForNextExtent()){let k=u.getZForResolution(r.nextResolution,c.zDirection),K=Cf(t,t.nextExtent);this.enqueueTiles(t,K,k,I,S)}let w=Cf(t,p);if(this.enqueueTiles(t,w,d,I,0),S>0&&setTimeout(()=>{this.enqueueTiles(t,w,d-1,I,S-1)},0),!(d in I))return this.container;let M=U(this),N=t.time;for(let k of I[d]){let K=k.getState();if(K===O.EMPTY)continue;let X=k.tileCoord;if(K===O.LOADED&&k.getAlpha(M,N)===1){k.endTransition(M);continue}if(K!==O.ERROR&&(this.renderComplete=!1),this.findStaleTile_(X,I)){Pp(I,k,d),t.animate=!0;continue}if(this.findAltTiles_(u,X,d+1,I))continue;let ot=u.getMinZoom();for(let kt=d-1;kt>=ot&&!this.findAltTiles_(u,X,kt,I);--kt);}let z=f/o*l/m,A=this.getRenderContext(t);Et(this.tempTransform,_/2,y/2,z,z,0,-_/2,-y/2),i.extent&&this.clipUnrotated(A,t,E),c.getInterpolate()||(A.imageSmoothingEnabled=!1),this.preRender(A,t);let H=Object.keys(I).map(Number);H.sort(jt);let $,P=[],j=[];for(let k=H.length-1;k>=0;--k){let K=H[k],X=c.getTilePixelSize(K,l,s),it=u.getResolution(K)/f,ot=X[0]*it*z,kt=X[1]*it*z,v=u.getTileCoordForCoordAndZ(he(T),K),ie=u.getTileCoordExtent(v),Rt=ht(this.tempTransform,[m*(ie[0]-T[0])/f,m*(T[3]-ie[3])/f]),ye=m*c.getGutterForProjection(s);for(let De of I[K]){if(De.getState()!==O.LOADED)continue;let ne=De.tileCoord,er=v[1]-ne[1],hs=Math.round(Rt[0]-(er-1)*ot),ir=v[2]-ne[2],Zo=Math.round(Rt[1]-(ir-1)*kt),ke=Math.round(Rt[0]-er*ot),xe=Math.round(Rt[1]-ir*kt),Ne=hs-ke,Ei=Zo-xe,cs=H.length===1,nr=!1;$=[ke,xe,ke+Ne,xe,ke+Ne,xe+Ei,ke,xe+Ei];for(let pn=0,us=P.length;pn<us;++pn)if(!cs&&K<j[pn]){let Pt=P[pn];lt([ke,xe,ke+Ne,xe+Ei],[Pt[0],Pt[3],Pt[4],Pt[7]])&&(nr||(A.save(),nr=!0),A.beginPath(),A.moveTo($[0],$[1]),A.lineTo($[2],$[3]),A.lineTo($[4],$[5]),A.lineTo($[6],$[7]),A.moveTo(Pt[6],Pt[7]),A.lineTo(Pt[4],Pt[5]),A.lineTo(Pt[2],Pt[3]),A.lineTo(Pt[0],Pt[1]),A.clip())}P.push($),j.push(K),this.drawTile(De,t,ke,xe,Ne,Ei,ye,cs),nr&&A.restore(),this.renderedTiles.unshift(De),this.updateUsedTiles(t.usedTiles,c,De)}}if(this.renderedResolution=f,this.extentChanged=!this.renderedExtent_||!we(this.renderedExtent_,T),this.renderedExtent_=T,this.renderedPixelRatio=l,this.postRender(this.context,t),i.extent&&A.restore(),A.imageSmoothingEnabled=!0,this.renderComplete){let k=(K,X)=>{let tt=U(c),it=X.wantedTiles[tt],ot=it?Object.keys(it).length:0;this.updateCacheSize(ot),this.tileCache_.expireCache(),this.sourceTileCache_?.expireCache()};t.postRenderFunctions.push(k)}return this.container}updateCacheSize(t){this.tileCache_.highWaterMark=Math.max(this.tileCache_.highWaterMark,t*2)}drawTile(t,e,i,r,s,o,a,l){let h;if(t instanceof ch){if(h=wo(t.getData()),!h)throw new Error("Rendering array data is not yet supported")}else h=this.getTileImage(t);if(!h)return;let c=this.getRenderContext(e),u=U(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,r,s,o),g&&c.restore(),f!==d.opacity?e.animate=!0:l&&t.endTransition(u)}getImage(){let t=this.context;return t?t.canvas:null}getTileImage(t){return t.getImage()}updateUsedTiles(t,e,i){let r=U(e);r in t||(t[r]={}),t[r][i.getKey()]=!0}},Rf=wh;var qr={PRELOAD:"preload",USE_INTERIM_TILES_ON_ERROR:"useInterimTilesOnError"};var Sh=class extends ci{constructor(t){t=t||{};let 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(qr.PRELOAD)}setPreload(t){this.set(qr.PRELOAD,t)}getUseInterimTilesOnError(){return this.get(qr.USE_INTERIM_TILES_ON_ERROR)}setUseInterimTilesOnError(t){this.set(qr.USE_INTERIM_TILES_ON_ERROR,t)}getData(t){return super.getData(t)}},wf=Sh;var Th=class extends wf{constructor(t){super(t)}createRenderer(){return new Rf(this,{cacheSize:this.getCacheSize()})}},Po=Th;var vh=class{drawCustom(t,e,i,r,s){}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){}},Oo=vh;var $r={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},Jr=[$r.FILL],He=[$r.STROKE],_i=[$r.BEGIN_PATH],Ih=[$r.CLOSE_PATH],D=$r;var Mh=class extends Oo{constructor(t,e,i,r){super(),this.tolerance=t,this.maxExtent=e,this.pixelRatio=r,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){let e=this.pixelRatio;return e==1?t:t.map(function(i){return i*e})}appendFlatPointCoordinates(t,e){let i=this.getBufferedMaxExtent(),r=this.tmpCoordinate_,s=this.coordinates,o=s.length;for(let a=0,l=t.length;a<l;a+=e)r[0]=t[a],r[1]=t[a+1],Jt(i,r)&&(s[o++]=r[0],s[o++]=r[1]);return o}appendFlatLineCoordinates(t,e,i,r,s,o){let a=this.coordinates,l=a.length,h=this.getBufferedMaxExtent();o&&(e+=r);let c=t[e],u=t[e+1],d=this.tmpCoordinate_,f=!0,g,p,m;for(g=e+r;g<i;g+=r)d[0]=t[g],d[1]=t[g+1],m=ws(h,d),m!==p?(f&&(a[l++]=c,a[l++]=u,f=!1),a[l++]=d[0],a[l++]=d[1]):m===yt.INTERSECTING?(a[l++]=d[0],a[l++]=d[1],f=!1):f=!0,c=d[0],u=d[1],p=m;return(s&&f||g===e+r)&&(a[l++]=c,a[l++]=u),l}drawCustomCoordinates_(t,e,i,r,s){for(let o=0,a=i.length;o<a;++o){let l=i[o],h=this.appendFlatLineCoordinates(t,e,l,r,!1,!1);s.push(h),e=l}return e}drawCustom(t,e,i,r,s){this.beginGeometry(t,e,s);let o=t.getType(),a=t.getStride(),l=this.coordinates.length,h,c,u,d,f;switch(o){case"MultiPolygon":h=t.getOrientedFlatCoordinates(),d=[];let g=t.getEndss();f=0;for(let p=0,m=g.length;p<m;++p){let _=[];f=this.drawCustomCoordinates_(h,f,g[p],a,_),d.push(_)}this.instructions.push([D.CUSTOM,l,d,t,i,xr,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,d,t,r||i,xr,s]);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([D.CUSTOM,l,u,t,i,Ai,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,u,t,r||i,Ai,s]);break;case"LineString":case"Circle":h=t.getFlatCoordinates(),c=this.appendFlatLineCoordinates(h,0,h.length,a,!1,!1),this.instructions.push([D.CUSTOM,l,c,t,i,fe,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,c,t,r||i,fe,s]);break;case"MultiPoint":h=t.getFlatCoordinates(),c=this.appendFlatPointCoordinates(h,a),c>l&&(this.instructions.push([D.CUSTOM,l,c,t,i,fe,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,c,t,r||i,fe,s]));break;case"Point":h=t.getFlatCoordinates(),this.coordinates.push(h[0],h[1]),c=this.coordinates.length,this.instructions.push([D.CUSTOM,l,c,t,i,void 0,s]),this.hitDetectionInstructions.push([D.CUSTOM,l,c,t,r||i,void 0,s]);break;default:}this.endGeometry(e)}beginGeometry(t,e,i){this.beginGeometryInstruction1_=[D.BEGIN_GEOMETRY,e,0,t,i],this.instructions.push(this.beginGeometryInstruction1_),this.beginGeometryInstruction2_=[D.BEGIN_GEOMETRY,e,0,t,i],this.hitDetectionInstructions.push(this.beginGeometryInstruction2_)}finish(){return{instructions:this.instructions,hitDetectionInstructions:this.hitDetectionInstructions,coordinates:this.coordinates}}reverseHitDetectionInstructions(){let t=this.hitDetectionInstructions;t.reverse();let e,i=t.length,r,s,o=-1;for(e=0;e<i;++e)r=t[e],s=r[0],s==D.END_GEOMETRY?o=e:s==D.BEGIN_GEOMETRY&&(r[2]=e,Jc(this.hitDetectionInstructions,o,e),o=-1)}fillStyleToState(t,e={}){if(t){let i=t.getColor();e.fillPatternScale=i&&typeof i=="object"&&"src"in i?this.pixelRatio:1,e.fillStyle=Zt(i||Ct)}else e.fillStyle=void 0;return e}strokeStyleToState(t,e={}){if(t){let i=t.getColor();e.strokeStyle=Zt(i||di);let r=t.getLineCap();e.lineCap=r!==void 0?r:Ve;let s=t.getLineDash();e.lineDash=s?s.slice():Ht;let o=t.getLineDashOffset();e.lineDashOffset=o||qt;let a=t.getLineJoin();e.lineJoin=a!==void 0?a:Be;let l=t.getWidth();e.lineWidth=l!==void 0?l:gi;let h=t.getMiterLimit();e.miterLimit=h!==void 0?h:ui;let c=t.getOffset();e.strokeOffset=c??Vd,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,e.strokeOffset=void 0;return e}setFillStrokeStyle(t,e){let i=this.state;this.fillStyleToState(t,i),this.strokeStyleToState(e,i)}createFill(t){let e=t.fillStyle,i=[D.SET_FILL_STYLE,e];return typeof e!="string"&&i.push(t.fillPatternScale),i}applyStroke(t){this.instructions.push(this.createStroke(t))}createStroke(t){return[D.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){let i=t.fillStyle;(typeof i!="string"||t.currentFillStyle!=i)&&(this.instructions.push(e.call(this,t)),t.currentFillStyle=i)}updateStrokeStyle(t,e){let i=t.strokeStyle,r=t.lineCap,s=t.lineDash,o=t.lineDashOffset,a=t.lineJoin,l=t.lineWidth,h=t.miterLimit,c=t.strokeOffset;(t.currentStrokeStyle!=i||t.currentLineCap!=r||s!=t.currentLineDash&&!Ot(t.currentLineDash,s)||t.currentLineDashOffset!=o||t.currentLineJoin!=a||t.currentLineWidth!=l||t.currentMiterLimit!=h||t.currentStrokeOffset!=c)&&(e.call(this,t),t.currentStrokeStyle=i,t.currentLineCap=r,t.currentLineDash=s,t.currentLineDashOffset=o,t.currentLineJoin=a,t.currentLineWidth=l,t.currentMiterLimit=h,t.currentStrokeOffset=c)}endGeometry(t){this.beginGeometryInstruction1_[2]=this.instructions.length,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_[2]=this.hitDetectionInstructions.length,this.beginGeometryInstruction2_=null;let e=[D.END_GEOMETRY,t];this.instructions.push(e),this.hitDetectionInstructions.push(e)}getBufferedMaxExtent(){if(!this.bufferedMaxExtent_&&(this.bufferedMaxExtent_=Ss(this.maxExtent),this.maxLineWidth>0)){let t=this.resolution*(this.maxLineWidth+1)/2;ri(this.bufferedMaxExtent_,t,this.bufferedMaxExtent_)}return this.bufferedMaxExtent_}},qe=Mh;var bh=class extends qe{constructor(t,e,i,r){super(t,e,i,r),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&&!Jt(this.maxExtent,t.getFlatCoordinates()))return;this.beginGeometry(t,e,i);let r=t.getFlatCoordinates(),s=t.getStride(),o=this.coordinates.length,a=this.appendFlatPointCoordinates(r,s);this.instructions.push([D.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([D.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);let r=t.getFlatCoordinates(),s=[];for(let l=0,h=r.length;l<h;l+=t.getStride())(!this.maxExtent||Jt(this.maxExtent,r.slice(l,l+2)))&&s.push(r[l],r[l+1]);let o=this.coordinates.length,a=this.appendFlatPointCoordinates(s,2);this.instructions.push([D.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([D.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){let i=t.getAnchor(),r=t.getSize(),s=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_=r[1],this.opacity_=t.getOpacity(),this.originX_=s[0],this.originY_=s[1],this.rotateWithView_=t.getRotateWithView(),this.rotation_=t.getRotation(),this.scale_=t.getScaleArray(),this.width_=r[0],this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}},Sf=bh;var Lh=class extends qe{constructor(t,e,i,r){super(t,e,i,r)}drawFlatCoordinates_(t,e,i,r,s){let o=this.coordinates.length,a=this.appendFlatLineCoordinates(t,e,i,r,!1,!1);return this.instructions.push([D.MOVE_TO_LINE_TO,o,a,s*this.pixelRatio]),this.hitDetectionInstructions.push([D.MOVE_TO_LINE_TO,o,a,s]),i}drawLineString(t,e,i){let r=this.state,s=r.strokeStyle,o=r.lineWidth,a=r.strokeOffset;if(s===void 0||o===void 0)return;this.updateStrokeStyle(r,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt],_i);let l=t.getFlatCoordinates(),h=t.getStride();this.drawFlatCoordinates_(l,0,l.length,h,a),this.hitDetectionInstructions.push(He),this.endGeometry(e)}drawMultiLineString(t,e,i){let r=this.state,s=r.strokeStyle,o=r.lineWidth,a=r.strokeOffset;if(s===void 0||o===void 0)return;this.updateStrokeStyle(r,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt],_i);let l=t.getEnds(),h=t.getFlatCoordinates(),c=t.getStride(),u=0;for(let d=0,f=l.length;d<f;++d)u=this.drawFlatCoordinates_(h,u,l[d],c,a);this.hitDetectionInstructions.push(He),this.endGeometry(e)}finish(){let t=this.state;return t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&this.instructions.push(He),this.reverseHitDetectionInstructions(),this.state=null,super.finish()}applyStroke(t){t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&(this.instructions.push(He),t.lastStroke=this.coordinates.length),t.lastStroke=0,super.applyStroke(t),this.instructions.push(_i)}},Tf=Lh;var Ah=class extends qe{constructor(t,e,i,r){super(t,e,i,r)}drawFlatCoordinatess_(t,e,i,r,s){let o=this.state,a=o.fillStyle!==void 0,l=o.strokeStyle!==void 0,h=i.length;this.instructions.push(_i),this.hitDetectionInstructions.push(_i);for(let c=0;c<h;++c){let u=i[c],d=this.coordinates.length,f=this.appendFlatLineCoordinates(t,e,u,r,!0,!l);this.instructions.push([D.MOVE_TO_LINE_TO,d,f,s*this.pixelRatio,!0]),this.hitDetectionInstructions.push([D.MOVE_TO_LINE_TO,d,f,s,!0]),l&&(this.instructions.push(Ih),this.hitDetectionInstructions.push(Ih)),e=u}return a&&(this.instructions.push(Jr),this.hitDetectionInstructions.push(Jr)),l&&(this.instructions.push(He),this.hitDetectionInstructions.push(He)),e}drawCircle(t,e,i){let r=this.state,s=r.fillStyle,o=r.strokeStyle,a=r.strokeOffset;if(s===void 0&&o===void 0||this.handleStrokeOffset_(()=>this.drawCircle(t,e,i)))return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),r.fillStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_FILL_STYLE,Ct]),r.strokeStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt]);let l=t.getFlatCoordinates(),h=t.getStride(),c=this.coordinates.length;this.appendFlatLineCoordinates(l,0,l.length,h,!1,!1);let u=[D.CIRCLE,c,a];this.instructions.push(_i,u),this.hitDetectionInstructions.push(_i,u),r.fillStyle!==void 0&&(this.instructions.push(Jr),this.hitDetectionInstructions.push(Jr)),r.strokeStyle!==void 0&&(this.instructions.push(He),this.hitDetectionInstructions.push(He)),this.endGeometry(e)}drawPolygon(t,e,i){let r=this.state,s=r.fillStyle,o=r.strokeStyle,a=r.strokeOffset;if(s===void 0&&o===void 0||this.handleStrokeOffset_(()=>this.drawPolygon(t,e,i)))return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),r.fillStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_FILL_STYLE,Ct]),r.strokeStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt]);let l=t.getEnds(),h=t.getOrientedFlatCoordinates(),c=t.getStride();this.drawFlatCoordinatess_(h,0,l,c,a),this.endGeometry(e)}drawMultiPolygon(t,e,i){let r=this.state,s=r.fillStyle,o=r.strokeStyle,a=r.strokeOffset;if(s===void 0&&o===void 0||this.handleStrokeOffset_(()=>this.drawMultiPolygon(t,e,i)))return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),r.fillStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_FILL_STYLE,Ct]),r.strokeStyle!==void 0&&this.hitDetectionInstructions.push([D.SET_STROKE_STYLE,r.strokeStyle,r.lineWidth,r.lineCap,r.lineJoin,r.miterLimit,Ht,qt]);let l=t.getEndss(),h=t.getOrientedFlatCoordinates(),c=t.getStride(),u=0;for(let d=0,f=l.length;d<f;++d)u=this.drawFlatCoordinatess_(h,u,l[d],c,a);this.endGeometry(e)}finish(){this.reverseHitDetectionInstructions(),this.state=null;let t=this.tolerance;if(t!==0){let e=this.coordinates;for(let i=0,r=e.length;i<r;++i)e[i]=Pi(e[i],t)}return super.finish()}setFillStrokeStyles_(){let t=this.state;this.updateFillStyle(t,this.createFill),this.updateStrokeStyle(t,this.applyStroke)}handleStrokeOffset_(t){let e=this.state,i=e.fillStyle,r=e.strokeStyle,s=e.strokeOffset;return Math.abs(s)>0&&i!==void 0&&r!==void 0?(e.strokeStyle=void 0,e.strokeOffset=0,t(),e.fillStyle=void 0,e.strokeStyle=r,e.strokeOffset=s,t(),e.fillStyle=i,!0):!1}},Ph=Ah;function vf(n,t,e,i,r){let s=[],o=e,a=0,l=t.slice(e,2);for(;a<n&&o+r<i;){let[h,c]=l.slice(-2),u=t[o+r],d=t[o+r+1],f=Math.sqrt((u-h)*(u-h)+(d-c)*(d-c));if(a+=f,a>=n){let g=(n-a+f)/f,p=bt(h,u,g),m=bt(c,d,g);l.push(p,m),s.push(l),l=[p,m],a==n&&(o+=r),a=0}else if(a<n)l.push(t[o+r],t[o+r+1]),o+=r;else{let g=f-a,p=bt(h,u,g/f),m=bt(c,d,g/f);l.push(p,m),s.push(l),l=[p,m],a=0,o+=r}}return a>0&&s.push(l),s}function If(n,t,e,i,r){let s=e,o=e,a=0,l=0,h=e,c,u,d,f,g,p,m,_,y,E;for(u=e;u<i;u+=r){let x=t[u],C=t[u+1];g!==void 0&&(y=x-g,E=C-p,f=Math.sqrt(y*y+E*E),m!==void 0&&(l+=d,c=Math.acos((m*y+_*E)/(d*f)),c>n&&(l>a&&(a=l,s=h,o=u),l=0,h=u-r)),d=f,m=y,_=E),g=x,p=C}return l+=f,l>a?[h,u]:[s,o]}var Qr={left:0,center:.5,right:1,top:0,middle:.5,hanging:.2,alphabetic:.8,ideographic:.8,bottom:1},Oh=class extends qe{constructor(t,e,i,r){super(t,e,i,r),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[Ct]={fillStyle:Ct},this.textStrokeState_=null,this.strokeStates={},this.textState_={},this.textStates={},this.textKey_="",this.fillKey_="",this.strokeKey_="",this.declutterMode_=void 0,this.declutterImageWithText_=void 0}finish(){let t=super.finish();return t.textStates=this.textStates,t.fillStates=this.fillStates,t.strokeStates=this.strokeStates,t}drawText(t,e,i){let r=this.textFillState_,s=this.textStrokeState_,o=this.textState_;if(this.text_===""||!o||!r&&!s)return;let a=this.coordinates,l=a.length,h=t.getType(),c=null,u=t.getStride();if(o.placement==="line"&&(h=="LineString"||h=="MultiLineString"||h=="Polygon"||h=="MultiPolygon")){if(!lt(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"){let m=t.getEndss();d=[];for(let _=0,y=m.length;_<y;++_)d.push(m[_][0])}this.beginGeometry(t,e,i);let f=o.repeat,g=f?void 0:o.textAlign,p=0;for(let m=0,_=d.length;m<_;++m){let y;f?y=vf(f*this.resolution,c,p,d[m],u):y=[c.slice(p,d[m])];for(let E=0,x=y.length;E<x;++E){let C=y[E],T=0,I=C.length;if(g==null){let w=If(o.maxAngle,C,0,C.length,2);T=w[0],I=w[1]}for(let w=T;w<I;w+=u)a.push(C[w],C[w+1]);let S=a.length;p=d[m],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":let x=t.getFlatInteriorPoints();c=[];for(let C=0,T=x.length;C<T;C+=3)o.overflow||d.push(x[C+2]/this.resolution),c.push(x[C],x[C+1]);if(c.length===0)return;u=2;break;default:}let f=this.appendFlatPointCoordinates(c,u);if(f===l)return;if(d&&(f-l)/2!==c.length/u){let x=l/2;d=d.filter((C,T)=>{let I=a[(x+T)*2]===c[T*u]&&a[(x+T)*2+1]===c[T*u+1];return I||--x,I})}this.saveTextStates_();let g=o.backgroundFill?this.createFill(this.fillStyleToState(o.backgroundFill)):null,p=o.backgroundStroke?this.createStroke(this.strokeStyleToState(o.backgroundStroke)):null;this.beginGeometry(t,e,i);let m=o.padding;if(m!=fi&&(o.scale[0]<0||o.scale[1]<0)){let x=o.padding[0],C=o.padding[1],T=o.padding[2],I=o.padding[3];o.scale[0]<0&&(C=-C,I=-I),o.scale[1]<0&&(x=-x,T=-T),m=[x,C,T,I]}let _=this.pixelRatio;this.instructions.push([D.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[1,1],NaN,this.declutterMode_,this.declutterImageWithText_,m==fi?fi:m.map(function(x){return x*_}),g,p,this.text_,this.textKey_,this.strokeKey_,this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]);let y=1/_,E=g?g.slice(0):null;E&&(E[1]=Ct),this.hitDetectionInstructions.push([D.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[y,y],NaN,this.declutterMode_,this.declutterImageWithText_,m,E,p,this.text_,this.textKey_,this.strokeKey_,this.fillKey_?Ct:this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]),this.endGeometry(e)}}saveTextStates_(){let t=this.textStrokeState_,e=this.textState_,i=this.textFillState_,r=this.strokeKey_;t&&(r in this.strokeStates||(this.strokeStates[r]={strokeStyle:t.strokeStyle,lineCap:t.lineCap,lineDashOffset:t.lineDashOffset,lineWidth:t.lineWidth,lineJoin:t.lineJoin,miterLimit:t.miterLimit,lineDash:t.lineDash}));let s=this.textKey_;s in this.textStates||(this.textStates[s]={font:e.font,textAlign:e.textAlign||Ui,justify:e.justify,textBaseline:e.textBaseline||un,scale:e.scale});let o=this.fillKey_;i&&(o in this.fillStates||(this.fillStates[o]={fillStyle:i.fillStyle}))}drawChars_(t,e){let i=this.textStrokeState_,r=this.textState_,s=this.strokeKey_,o=this.textKey_,a=this.fillKey_;this.saveTextStates_();let l=this.pixelRatio,h=Qr[r.textBaseline],c=this.textOffsetY_*l,u=this.text_,d=i?i.lineWidth*Math.abs(r.scale[0])/2:0;this.instructions.push([D.DRAW_CHARS,t,e,h,r.overflow,a,r.maxAngle,l,c,s,d*l,u,o,1,this.declutterMode_,this.textKeepUpright_]),this.hitDetectionInstructions.push([D.DRAW_CHARS,t,e,h,r.overflow,a&&Ct,r.maxAngle,l,c,s,d*l,u,o,1/l,this.declutterMode_,this.textKeepUpright_])}setTextStyle(t,e){let i,r,s;if(!t)this.text_="";else{let o=t.getFill();o?(r=this.textFillState_,r||(r={},this.textFillState_=r),r.fillStyle=Zt(o.getColor()||Ct)):(r=null,this.textFillState_=r);let a=t.getStroke();if(!a)s=null,this.textStrokeState_=s;else{s=this.textStrokeState_,s||(s={},this.textStrokeState_=s);let p=a.getLineDash(),m=a.getLineDashOffset(),_=a.getWidth(),y=a.getMiterLimit();s.lineCap=a.getLineCap()||Ve,s.lineDash=p?p.slice():Ht,s.lineDashOffset=m===void 0?qt:m,s.lineJoin=a.getLineJoin()||Be,s.lineWidth=_===void 0?gi:_,s.miterLimit=y===void 0?ui:y,s.strokeStyle=Zt(a.getColor()||di)}i=this.textState_;let l=t.getFont()||fo;Bd(l);let 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()||un,i.backgroundFill=t.getBackgroundFill(),i.backgroundStroke=t.getBackgroundStroke(),i.padding=t.getPadding()||fi,i.scale=h===void 0?[1,1]:h;let 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_=s?(typeof s.strokeStyle=="string"?s.strokeStyle:U(s.strokeStyle))+s.lineCap+s.lineDashOffset+"|"+s.lineWidth+s.lineJoin+s.miterLimit+"["+s.lineDash.join()+"]":"",this.textKey_=i.font+i.scale+(i.textAlign||"?")+(i.repeat||"?")+(i.justify||"?")+(i.textBaseline||"?"),this.fillKey_=r&&r.fillStyle?typeof r.fillStyle=="string"?r.fillStyle:"|"+U(r.fillStyle):""}this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}},Mf=Oh;var Op={Circle:Ph,Default:qe,Image:Sf,LineString:Tf,Polygon:Ph,Text:Mf},Fh=class{constructor(t,e,i,r){this.tolerance_=t,this.maxExtent_=e,this.pixelRatio_=r,this.resolution_=i,this.buildersByZIndex_={}}finish(){let t={};for(let e in this.buildersByZIndex_){t[e]=t[e]||{};let i=this.buildersByZIndex_[e];for(let r in i){let s=i[r].finish();t[e][r]=s}}return t}getBuilder(t,e){let i=t!==void 0?t.toString():"0",r=this.buildersByZIndex_[i];r===void 0&&(r={},this.buildersByZIndex_[i]=r);let s=r[e];if(s===void 0){let o=Op[e];s=new o(this.tolerance_,this.maxExtent_,this.resolution_,this.pixelRatio_),r[e]=s}return s}},bf=Fh;function qn(n,t,e,i){let r=n[t],s=n[t+1],o=0;for(let a=t+i;a<e;a+=i){let l=n[a],h=n[a+1];o+=Math.sqrt((l-r)*(l-r)+(h-s)*(h-s)),r=l,s=h}return o}function Lf(n,t,e,i,r,s){r=r??[],s=s??t;let o=n[0],a=n[1],l=n[n.length-4],h=n[n.length-3],c,u,d,f,g,p,m,_,y=0;for(let E=0;E<n.length;E+=t){d=c,f=u,g=void 0,p=void 0,E+t<n.length&&(g=n[E+t],p=n[E+t+1]),i&&E===0&&(d=l,f=h),i&&E===n.length-2&&(g=o,p=a),c=n[E],u=n[E+1],[m,_]=ts(c,u,d,f,g,p,e),r[y++]=m,r[y++]=_;for(let x=2;x<s;x++)r[y++]=n[E+x]}return r.length!=y&&(r.length=y),r}function ts(n,t,e,i,r,s,o){let a,l;e!==void 0&&i!==void 0?(a=n-e,l=t-i):r!==void 0&&s!==void 0?(a=r-n,l=s-t):(a=1,l=0);let h=Math.hypot(a,l),c=a/h,u=l/h;if(a=-u,l=c,e===void 0||i===void 0)return[n+a*o,t+l*o];if(r===void 0||s===void 0)return[n+a*o,t+l*o];let d=yu([n,t],[e,i],[r,s]);if(Math.cos(d)>.998)return[n+c*o,t+u*o];let f=Math.cos(d/2),g=Math.sin(d/2),p=g*a+f*l,m=-f*a+g*l,_=p*(1/g),y=m*(1/g);return[n+_*o,t+y*o]}function Af(n,t,e,i,r,s,o,a,l,h,c,u,d=!0){let f=n[t],g=n[t+1],p=0,m=0,_=0,y=0;function E(){p=f,m=g,t+=i,f=n[t],g=n[t+1],y+=_,_=Math.sqrt((f-p)*(f-p)+(g-m)*(g-m))}do E();while(t<e-i&&y+_<s);let x=_===0?0:(s-y)/_,C=bt(p,f,x),T=bt(m,g,x),I=t-i,S=y,w=s+a*l(h,r,c);for(;t<e-i&&y+_<w;)E();x=_===0?0:(w-y)/_;let M=bt(p,f,x),N=bt(m,g,x),z=!1;if(d)if(u){let j=[C,T,M,N];zs(j,0,4,2,u,j,j),z=j[0]>j[2]}else z=C>M;let A=Math.PI,H=[],$=I+i===t;t=I,_=0,y=S,f=n[t],g=n[t+1];let P;if($){E(),P=Math.atan2(g-m,f-p),z&&(P+=P>0?-A:A);let j=(M+C)/2,k=(N+T)/2;return H[0]=[j,k,(w-s)/2,P,r],H}r=r.replace(/\n/g," ");for(let j=0,k=r.length;j<k;){E();let K=Math.atan2(g-m,f-p);if(z&&(K+=K>0?-A:A),P!==void 0){let v=K-P;if(v+=v>A?-2*A:v<-A?2*A:0,Math.abs(v)>o)return null}P=K;let X=j,tt=0;for(;j<k;++j){let v=z?k-j-1:j,ie=a*l(h,r[v],c);if(t+i<e&&y+_<s+tt+ie/2)break;tt+=ie}if(j===X)continue;let it=z?r.substring(k-X,k-j):r.substring(X,j);x=_===0?0:(s+tt/2-y)/_;let ot=bt(p,f,x),kt=bt(m,g,x);H.push([ot,kt,tt/2,K,it]),s+=tt}return H}var $n=ct(),Bi=[],yi=[],xi=[],Zi=[];function Pf(n){return n[3].declutterBox}var Of=new RegExp("[\u0591-\u08FF\uFB1D-\uFDFF\uFE70-\uFEFC\u0800-\u0FFF\uE800-\uEFFF]");function Dh(n,t){return t==="start"?t=Of.test(n)?"right":"left":t==="end"&&(t=Of.test(n)?"left":"right"),Qr[t]}function Fp(n,t,e){return e>0&&n.push(`
|
|
4
|
+
`,""),n.push(t,""),n}function Dp(n,t,e){return e%2===0&&(n+=t),n}var kh=class{constructor(t,e,i,r,s){this.overlaps=i,this.pixelRatio=e,this.resolution=t,this.alignAndScaleFill_,this.instructions=r.instructions,this.coordinates=r.coordinates,this.coordinateCache_={},this.renderedTransform_=Tt(),this.hitDetectionInstructions=r.hitDetectionInstructions,this.pixelCoordinates_=null,this.viewRotation_=0,this.fillStates=r.fillStates||{},this.strokeStates=r.strokeStates||{},this.textStates=r.textStates||{},this.widths_={},this.labels_={},this.zIndexContext_=s?new Ao:null}getZIndexContext(){return this.zIndexContext_}createLabel(t,e,i,r){let s=t+e+i+r;if(this.labels_[s])return this.labels_[s];let o=r?this.strokeStates[r]: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?Qr[l.justify]:Dh(Array.isArray(t)?t[0]:t,l.textAlign||Ui),d=r&&o.lineWidth?o.lineWidth:0,f=Array.isArray(t)?t:String(t).split(`
|
|
5
|
+
`).reduce(Fp,[]),{width:g,height:p,widths:m,heights:_,lineWidths:y}=qd(l,f),E=g+d,x=[],C=(E+2)*c[0],T=(p+d)*c[1],I={width:C<0?Math.floor(C):Math.ceil(C),height:T<0?Math.floor(T):Math.ceil(T),contextInstructions:x};(c[0]!=1||c[1]!=1)&&x.push("scale",c),r&&(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");let S=.5-u,w=u*E+S*d,M=[],N=[],z=0,A=0,H=0,$=0,P;for(let j=0,k=f.length;j<k;j+=2){let K=f[j];if(K===`
|
|
6
|
+
`){A+=z,z=0,w=u*E+S*d,++$;continue}let X=f[j+1]||l.font;X!==P&&(r&&M.push("font",X),i&&N.push("font",X),P=X),z=Math.max(z,_[H]);let tt=[K,w+S*m[H]+u*(m[H]-y[$]),.5*(d+z)+A];w+=m[H],r&&M.push("strokeText",tt),i&&N.push("fillText",tt),++H}return Array.prototype.push.apply(x,M),Array.prototype.push.apply(x,N),this.labels_[s]=I,I}replayTextBackground_(t,e,i,r,s,o,a){t.beginPath(),t.moveTo.apply(t,e),t.lineTo.apply(t,i),t.lineTo.apply(t,r),t.lineTo.apply(t,s),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,r,s,o,a,l,h,c,u,d,f,g,p,m){a*=d[0],l*=d[1];let _=i-a,y=r-l,E=s+h>t?t-h:s,x=o+c>e?e-c:o,C=g[3]+E*d[0]+g[1],T=g[0]+x*d[1]+g[2],I=_-g[3],S=y-g[0];(p||u!==0)&&(Bi[0]=I,Zi[0]=I,Bi[1]=S,yi[1]=S,yi[0]=I+C,xi[0]=yi[0],xi[1]=S+T,Zi[1]=xi[1]);let w;return u!==0?(w=Et(Tt(),i,r,1,1,u,-i,-r),ht(w,Bi),ht(w,yi),ht(w,xi),ht(w,Zi),Qt(Math.min(Bi[0],yi[0],xi[0],Zi[0]),Math.min(Bi[1],yi[1],xi[1],Zi[1]),Math.max(Bi[0],yi[0],xi[0],Zi[0]),Math.max(Bi[1],yi[1],xi[1],Zi[1]),$n)):Qt(Math.min(I,I+C),Math.min(S,S+T),Math.max(I,I+C),Math.max(S,S+T),$n),f&&(_=Math.round(_),y=Math.round(y)),{drawImageX:_,drawImageY:y,drawImageW:E,drawImageH:x,originX:h,originY:c,declutterBox:{minX:$n[0],minY:$n[1],maxX:$n[2],maxY:$n[3],value:m},canvasTransform:w,scale:d}}replayImageOrLabel_(t,e,i,r,s,o,a){let l=!!(o||a),h=r.declutterBox,c=a?a[2]*r.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,Bi,yi,xi,Zi,o,a),$d(t,r.canvasTransform,s,i,r.originX,r.originY,r.drawImageW,r.drawImageH,r.drawImageX,r.drawImageY,r.scale)),!0}fill_(t){let e=this.alignAndScaleFill_;if(e){let i=ht(this.renderedTransform_,[0,0]),r=512*this.pixelRatio;t.save(),t.translate(i[0]%r,i[1]%r),e!==1&&t.scale(e,e)}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,r){let s=this.textStates[e],o=this.createLabel(t,e,r,i),a=this.strokeStates[i],l=this.pixelRatio,h=Dh(Array.isArray(t)?t[0]:t,s.textAlign||Ui),c=Qr[s.textBaseline||un],u=a&&a.lineWidth?a.lineWidth:0,d=o.width/l-2*s.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,r,s,o,a,l){let h=this.zIndexContext_,c;this.pixelCoordinates_&&Ot(i,this.renderedTransform_)?c=this.pixelCoordinates_:(this.pixelCoordinates_||(this.pixelCoordinates_=[]),c=Kt(this.coordinates,0,this.coordinates.length,2,i,this.pixelCoordinates_),Uu(this.renderedTransform_,i));let u=0,d=r.length,f=0,g,p,m,_,y,E,x,C,T,I,S,w,M,N,z,A,H=0,$=0,P=this.coordinateCache_,j=this.viewRotation_,k=Math.round(Math.atan2(-i[1],i[0])*1e12)/1e12,K={context:t,pixelRatio:this.pixelRatio,resolution:this.resolution,rotation:j},X=this.instructions!=r||this.overlaps?0:200,tt,it,ot,kt;for(;u<d;){let v=r[u];switch(v[0]){case D.BEGIN_GEOMETRY:tt=v[1],kt=v[3],tt.getGeometry()?a!==void 0&&!lt(a,kt.getExtent())?u=v[2]+1:++u:u=v[2],h&&(h.zIndex=v[4]);break;case D.BEGIN_PATH:H>X&&(this.fill_(t),H=0),$>X&&(t.stroke(),$=0),!H&&!$&&(t.beginPath(),C=NaN,T=NaN),++u;break;case D.CIRCLE:f=v[1],_=v[2]??0;let Rt=c[f],ye=c[f+1],De=c[f+2]-_,ne=c[f+3]-_,er=De-Rt,hs=ne-ye,ir=Math.sqrt(er*er+hs*hs);t.moveTo(Rt+ir,ye),t.arc(Rt,ye,ir,0,2*Math.PI,!0),++u;break;case D.CLOSE_PATH:t.closePath(),++u;break;case D.CUSTOM:f=v[1],g=v[2];let Zo=v[3],ke=v[4],xe=v[5];K.geometry=Zo,K.feature=tt,u in P||(P[u]=[]);let Ne=P[u];xe?xe(c,f,g,2,Ne):(Ne[0]=c[f],Ne[1]=c[f+1],Ne.length=2),h&&(h.zIndex=v[6]),ke(Ne,K),++u;break;case D.DRAW_IMAGE:f=v[1],g=v[2],w=v[3],p=v[4],m=v[5];let Ei=v[6],cs=v[7],nr=v[8],pn=v[9],us=v[10],Pt=v[11],Tg=v[12],ds=v[13];x=v[14]||"declutter";let rr=v[15];if(!w&&v.length>=20){M=v[19],N=v[20],z=v[21],A=v[22];let re=this.drawLabelWithPointPlacement_(M,N,z,A);w=re.label,v[3]=w;let $i=v[23];p=(re.anchorX-$i)*this.pixelRatio,v[4]=p;let se=v[24];m=(re.anchorY-se)*this.pixelRatio,v[5]=m,Ei=w.height,v[6]=Ei,ds=w.width,v[13]=ds}let Ho;v.length>25&&(Ho=v[25]);let qo,fs,gs;v.length>17?(qo=v[16],fs=v[17],gs=v[18]):(qo=fi,fs=null,gs=null),us&&k?Pt+=j:!us&&!k&&(Pt-=j);let vg=0;for(;f<g;f+=2){if(Ho&&Ho[vg++]<ds/this.pixelRatio)continue;let re=this.calculateImageOrLabelDimensions_(w.width,w.height,c[f],c[f+1],ds,Ei,p,m,nr,pn,Pt,Tg,s,qo,!!fs||!!gs,tt),$i=[t,e,w,re,cs,fs,gs];if(l){let se,Ge,oe;if(rr){let ut=g-f;if(!rr[ut]){rr[ut]={args:$i,declutterMode:x};continue}let Nt=rr[ut];se=Nt.args,Ge=Nt.declutterMode,delete rr[ut],oe=Pf(se)}let Je,Qe;if(se&&(Ge!=="declutter"||!l.collides(oe))&&(Je=!0),(x!=="declutter"||!l.collides(re.declutterBox))&&(Qe=!0),Ge==="declutter"&&x==="declutter"){let ut=Je&&Qe;Je=ut,Qe=ut}Je&&(Ge!=="none"&&l.insert(oe),this.replayImageOrLabel_.apply(this,se)),Qe&&(x!=="none"&&l.insert(re.declutterBox),this.replayImageOrLabel_.apply(this,$i))}else this.replayImageOrLabel_.apply(this,$i)}++u;break;case D.DRAW_CHARS:let Uc=v[1],Yc=v[2],$o=v[3],Ig=v[4];A=v[5];let Mg=v[6],Kc=v[7],Vc=v[8];z=v[9];let Jo=v[10];M=v[11],Array.isArray(M)&&(M=M.reduce(Dp,"")),N=v[12];let Bc=[v[13],v[13]];x=v[14]||"declutter";let bg=v[15],Qo=this.textStates[N],sr=Qo.font,or=[Qo.scale[0]*Kc,Qo.scale[1]*Kc],ar;sr in this.widths_?ar=this.widths_[sr]:(ar={},this.widths_[sr]=ar);let Zc=qn(c,Uc,Yc,2),Hc=Math.abs(or[0])*Xl(sr,M,ar);if(Ig||Hc<=Zc){let re=this.textStates[N].textAlign,$i=(Zc-Hc)*Dh(M,re),se=Af(c,Uc,Yc,2,M,$i,Mg,Math.abs(or[0]),Xl,sr,ar,k?0:this.viewRotation_,bg);t:if(se){let Ge=[],oe,Je,Qe,ut,Nt;if(z)for(oe=0,Je=se.length;oe<Je;++oe){Nt=se[oe],Qe=Nt[4],ut=this.createLabel(Qe,N,"",z),p=Nt[2]+(or[0]<0?-Jo:Jo),m=$o*ut.height+(.5-$o)*2*Jo*or[1]/or[0]-Vc;let ti=this.calculateImageOrLabelDimensions_(ut.width,ut.height,Nt[0],Nt[1],ut.width,ut.height,p,m,0,0,Nt[3],Bc,!1,fi,!1,tt);if(l&&x==="declutter"&&l.collides(ti.declutterBox))break t;Ge.push([t,e,ut,ti,1,null,null])}if(A)for(oe=0,Je=se.length;oe<Je;++oe){Nt=se[oe],Qe=Nt[4],ut=this.createLabel(Qe,N,A,""),p=Nt[2],m=$o*ut.height-Vc;let ti=this.calculateImageOrLabelDimensions_(ut.width,ut.height,Nt[0],Nt[1],ut.width,ut.height,p,m,0,0,Nt[3],Bc,!1,fi,!1,tt);if(l&&x==="declutter"&&l.collides(ti.declutterBox))break t;Ge.push([t,e,ut,ti,1,null,null])}l&&x!=="none"&&l.load(Ge.map(Pf));for(let ti=0,Lg=Ge.length;ti<Lg;++ti)this.replayImageOrLabel_.apply(this,Ge[ti])}}++u;break;case D.END_GEOMETRY:if(o!==void 0){tt=v[1];let re=o(tt,kt,x);if(re)return re}++u;break;case D.FILL:X?H++:this.fill_(t),++u;break;case D.MOVE_TO_LINE_TO:for(f=v[1],g=v[2],_=v[3],y=v[4]??!1,it=c[f],ot=c[f+1],_&&(E=f,[it,ot]=ts(it,ot,y?c[g-4]:void 0,y?c[g-3]:void 0,c[f+2],c[f+3],_)),t.moveTo(it,ot),C=it+.5|0,T=ot+.5|0,f+=2;f<g;f+=2)it=c[f],ot=c[f+1],I=it+.5|0,S=ot+.5|0,(f==g-2||I!==C||S!==T)&&(_&&(f==g-2?[it,ot]=ts(it,ot,c[f-2],c[f-1],y?c[E+2]:void 0,y?c[E+3]:void 0,_):[it,ot]=ts(it,ot,c[f-2],c[f-1],c[f+2],c[f+3],_)),t.lineTo(it,ot),C=I,T=S);++u;break;case D.SET_FILL_STYLE:this.alignAndScaleFill_=v[2],H&&(this.fill_(t),H=0,$&&(t.stroke(),$=0)),t.fillStyle=v[1],++u;break;case D.SET_STROKE_STYLE:$&&(t.stroke(),$=0),this.setStrokeStyle_(t,v),++u;break;case D.STROKE:X?$++:t.stroke(),++u;break;default:++u;break}}H&&this.fill_(t),$&&t.stroke()}execute(t,e,i,r,s,o){this.viewRotation_=r,this.execute_(t,e,i,this.instructions,s,void 0,void 0,o)}executeHitDetection(t,e,i,r,s){return this.viewRotation_=i,this.execute_(t,[t.canvas.width,t.canvas.height],e,this.hitDetectionInstructions,!0,r,s)}},Ff=kh;var Hi=["Polygon","Circle","LineString","Image","Text","Default"],zh=["Image","Text"],Df=Hi.filter(n=>!zh.includes(n)),kf=!1,Nf=!1;function kp(){let n=0,t=i=>{let r=nt(1,1,null,{willReadFrequently:i}),s=0,o=performance.now();for(;performance.now()-o<50;++s)r.fillStyle=`rgba(255,0,${s%256},1)`,r.fillRect(0,0,1,1),r.getImageData(0,0,1,1);return n=s>n?s:n,s};kf={[t(!0)]:!0,[t(!1)]:!1,[t(void 0)]:void 0}[n],Nf=!0}var Gh=class{constructor(t,e,i,r,s,o,a){this.maxExtent_=t,this.overlaps_=r,this.pixelRatio_=i,this.resolution_=e,this.renderBuffer_=o,this.executorsByZIndex_={},this.hitDetectionContext_=null,this.hitDetectionTransform_=Tt(),this.renderedContext_=null,this.deferredZIndexContexts_={},this.createExecutors_(s,a)}clip(t,e){let 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(let i in t){let r=this.executorsByZIndex_[i];r===void 0&&(r={},this.executorsByZIndex_[i]=r);let s=t[i];for(let o in s){let a=s[o];r[o]=new Ff(this.resolution_,this.pixelRatio_,this.overlaps_,a,e)}}}hasExecutors(t){for(let e in this.executorsByZIndex_){let i=this.executorsByZIndex_[e];for(let r=0,s=t.length;r<s;++r)if(t[r]in i)return!0}return!1}forEachFeatureAtCoordinate(t,e,i,r,s,o){Nf===!1&&kp(),r=Math.round(r);let a=r*2+1,l=Et(this.hitDetectionTransform_,r+.5,r+.5,1/e,-1/e,-i,-t[0],-t[1]),h=!this.hitDetectionContext_;h&&(this.hitDetectionContext_=nt(a,a,null,{willReadFrequently:kf}));let 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=ct(),Qi(u,t),ri(u,e*(this.renderBuffer_+r),u));let d=Np(r),f;function g(C,T,I){let S=c.getImageData(0,0,a,a).data;for(let w=0,M=d.length;w<M;w++)if(S[d[w]]>0){if(!o||I==="none"||f!=="Image"&&f!=="Text"||o.includes(C)){let N=(d[w]-3)/4,z=r-N%a,A=r-(N/a|0),H=s(C,T,z*z+A*A);if(H)return H}c.clearRect(0,0,a,a);break}}let p=Object.keys(this.executorsByZIndex_).map(Number);p.sort(jt);let m,_,y,E,x;for(m=p.length-1;m>=0;--m){let C=p[m].toString();for(y=this.executorsByZIndex_[C],_=Hi.length-1;_>=0;--_)if(f=Hi[_],E=y[f],E!==void 0&&(x=E.executeHitDetection(c,l,i,g,u),x))return x}}getClipCoords(t){let e=this.maxExtent_;if(!e)return null;let i=e[0],r=e[1],s=e[2],o=e[3],a=[i,r,i,o,s,o,s,r];return Kt(a,0,8,2,t,a),a}isEmpty(){return $t(this.executorsByZIndex_)}execute(t,e,i,r,s,o,a){let l=Object.keys(this.executorsByZIndex_).map(Number);l.sort(a?$c:jt),o=o||Hi;let h=Hi.length;for(let c=0,u=l.length;c<u;++c){let d=l[c].toString(),f=this.executorsByZIndex_[d];for(let g=0,p=o.length;g<p;++g){let m=o[g],_=f[m];if(_!==void 0){let y=a===null?void 0:_.getZIndexContext(),E=y?y.getContext():t,x=this.maxExtent_&&m!=="Image"&&m!=="Text";if(x&&(E.save(),this.clip(E,i)),!y||m==="Text"||m==="Image"?_.execute(E,e,i,r,s,a):y.pushFunction(C=>_.execute(C,e,i,r,s,a)),x&&E.restore(),y){y.offset();let C=l[c]*h+Hi.indexOf(m);this.deferredZIndexContexts_[C]||(this.deferredZIndexContexts_[C]=[]),this.deferredZIndexContexts_[C].push(y)}}}}this.renderedContext_=t}getDeferredZIndexContexts(){return this.deferredZIndexContexts_}getRenderedContext(){return this.renderedContext_}renderDeferred(){let t=this.deferredZIndexContexts_,e=Object.keys(t).map(Number).sort(jt);for(let i=0,r=e.length;i<r;++i)t[e[i]].forEach(s=>{s.draw(this.renderedContext_),s.clear()}),t[e[i]].length=0}},Nh={};function Np(n){if(Nh[n]!==void 0)return Nh[n];let t=n*2+1,e=n*n,i=new Array(e+1);for(let s=0;s<=n;++s)for(let o=0;o<=n;++o){let a=s*s+o*o;if(a>e)break;let l=i[a];l||(l=[],i[a]=l),l.push(((n+s)*t+(n+o))*4+3),s>0&&l.push(((n-s)*t+(n+o))*4+3),o>0&&(l.push(((n+s)*t+(n-o))*4+3),s>0&&l.push(((n-s)*t+(n-o))*4+3))}let r=[];for(let s=0,o=i.length;s<o;++s)i[s]&&r.push(...i[s]);return Nh[n]=r,r}var Gf=Gh;var jh=class extends Oo{constructor(t,e,i,r,s,o,a){super(),this.context_=t,this.pixelRatio_=e,this.extent_=i,this.transform_=r,this.transformRotation_=r?Ti(Math.atan2(r[1],r[0]),10):0,this.viewRotation_=s,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_=Tt()}drawImages_(t,e,i,r){if(!this.image_)return;let s=Kt(t,e,i,r,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=s.length;c<u;c+=2){let d=s[c]-this.imageAnchorX_,f=s[c+1]-this.imageAnchorY_;if(h!==0||this.imageScale_[0]!=1||this.imageScale_[1]!=1){let g=d+this.imageAnchorX_,p=f+this.imageAnchorY_;Et(a,g,p,1,1,h,-g,-p),o.save(),o.transform.apply(o,a),o.translate(g,p),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,r){if(!this.textState_||this.text_==="")return;this.textFillState_&&this.setContextFillState_(this.textFillState_),this.textStrokeState_&&this.setContextStrokeState_(this.textStrokeState_),this.setContextTextState_(this.textState_);let s=Kt(t,e,i,r,this.transform_,this.pixelCoordinates_),o=this.context_,a=this.textRotation_;for(this.transformRotation_===0&&(a-=this.viewRotation_),this.textRotateWithView_&&(a+=this.viewRotation_);e<i;e+=r){let l=s[e]+this.textOffsetX_,h=s[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,r,s,o){let a=this.context_,l=Kt(t,e,i,r,this.transform_,this.pixelCoordinates_);Math.abs(o)>0&&(l=Lf(l,r,o,s,l)),a.moveTo(l[0],l[1]);let h=l.length;s&&(h-=2);for(let c=2;c<h;c+=2)a.lineTo(l[c],l[c+1]);return s&&a.closePath(),i}drawRings_(t,e,i,r,s){for(let o=0,a=i.length;o<a;++o)e=this.moveToLineTo_(t,e,i[o],r,!0,s);return e}drawCircle(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!lt(this.extent_,t.getExtent())){if(this.fillState_||this.strokeState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);let e=qu(t,this.transform_,this.pixelCoordinates_),i=e[2]-e[0],r=e[3]-e[1],s=Math.sqrt(i*i+r*r),o=this.context_;o.beginPath(),o.arc(e[0],e[1],s,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;default:}}drawFeature(t,e){let i=e.getGeometryFunction()(t);i&&(this.setStyle(e),this.drawGeometry(i))}drawGeometryCollection(t){let e=t.getGeometriesArray();for(let i=0,r=e.length;i<r;++i)this.drawGeometry(e[i])}drawPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));let 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_));let 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_)),!!lt(this.extent_,t.getExtent())){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);let e=this.context_,i=t.getFlatCoordinates();e.beginPath(),this.moveToLineTo_(i,0,i.length,t.getStride(),!1,this.strokeState_.strokeOffset),e.stroke()}if(this.text_!==""){let e=t.getFlatMidpoint();this.drawText_(e,0,2,2)}}}drawMultiLineString(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));let e=t.getExtent();if(lt(this.extent_,e)){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);let i=this.context_,r=t.getFlatCoordinates(),s=0,o=t.getEnds(),a=t.getStride();i.beginPath();for(let l=0,h=o.length;l<h;++l)s=this.moveToLineTo_(r,s,o[l],a,!1,this.strokeState_.strokeOffset);i.stroke()}if(this.text_!==""){let i=t.getFlatMidpoints();this.drawText_(i,0,i.length,2)}}}drawPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!lt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);let e=this.context_;e.beginPath(),this.drawRings_(t.getOrientedFlatCoordinates(),0,t.getEnds(),t.getStride(),this.strokeState_?.strokeOffset),this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){let e=t.getFlatInteriorPoint();this.drawText_(e,0,2,2)}}}drawMultiPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!lt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);let e=this.context_,i=t.getOrientedFlatCoordinates(),r=0,s=t.getEndss(),o=t.getStride();e.beginPath();for(let a=0,l=s.length;a<l;++a){let h=s[a];r=this.drawRings_(i,r,h,o,this.strokeState_?.strokeOffset)}this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){let e=t.getFlatInteriorPoints();this.drawText_(e,0,e.length,2)}}}setContextFillState_(t){let 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){let e=this.context_,i=this.contextStrokeState_;i?(i.lineCap!=t.lineCap&&(i.lineCap=t.lineCap,e.lineCap=t.lineCap),Ot(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){let e=this.context_,i=this.contextTextState_,r=t.textAlign?t.textAlign:Ui;i?(i.font!=t.font&&(i.font=t.font,e.font=t.font),i.textAlign!=r&&(i.textAlign=r,e.textAlign=r),i.textBaseline!=t.textBaseline&&(i.textBaseline=t.textBaseline,e.textBaseline=t.textBaseline)):(e.font=t.font,e.textAlign=r,e.textBaseline=t.textBaseline,this.contextTextState_={font:t.font,textAlign:r,textBaseline:t.textBaseline})}setFillStrokeStyle(t,e){if(!t)this.fillState_=null;else{let i=t.getColor();this.fillState_={fillStyle:Zt(i||Ct)}}if(!e)this.strokeState_=null;else{let i=e.getColor(),r=e.getLineCap(),s=e.getLineDash(),o=e.getLineDashOffset(),a=e.getLineJoin(),l=e.getWidth(),h=e.getMiterLimit(),c=s||Ht,u=e.getOffset();this.strokeState_={lineCap:r!==void 0?r:Ve,lineDash:this.pixelRatio_===1?c:c.map(d=>d*this.pixelRatio_),lineDashOffset:(o||qt)*this.pixelRatio_,lineJoin:a!==void 0?a:Be,lineWidth:(l!==void 0?l:gi)*this.pixelRatio_,miterLimit:h!==void 0?h:ui,strokeStyle:Zt(i||di),strokeOffset:(u??0)*this.pixelRatio_}}}setImageStyle(t){let e;if(!t||!(e=t.getSize())){this.image_=null;return}let i=t.getPixelRatio(this.pixelRatio_),r=t.getAnchor(),s=t.getOrigin();this.image_=t.getImage(this.pixelRatio_),this.imageAnchorX_=r[0]*i,this.imageAnchorY_=r[1]*i,this.imageHeight_=e[1]*i,this.imageOpacity_=t.getOpacity(),this.imageOriginX_=s[0],this.imageOriginY_=s[1],this.imageRotateWithView_=t.getRotateWithView(),this.imageRotation_=t.getRotation();let 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{let e=t.getFill();if(!e)this.textFillState_=null;else{let f=e.getColor();this.textFillState_={fillStyle:Zt(f||Ct)}}let i=t.getStroke();if(!i)this.textStrokeState_=null;else{let f=i.getColor(),g=i.getLineCap(),p=i.getLineDash(),m=i.getLineDashOffset(),_=i.getLineJoin(),y=i.getWidth(),E=i.getMiterLimit();this.textStrokeState_={lineCap:g!==void 0?g:Ve,lineDash:p||Ht,lineDashOffset:m||qt,lineJoin:_!==void 0?_:Be,lineWidth:y!==void 0?y:gi,miterLimit:E!==void 0?E:ui,strokeStyle:Zt(f||di)}}let r=t.getFont(),s=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:r!==void 0?r:fo,textAlign:u!==void 0?u:Ui,textBaseline:d!==void 0?d:un},this.text_=c!==void 0?Array.isArray(c)?c.reduce((f,g,p)=>f+=p%2?" ":g,""):c:"",this.textOffsetX_=s!==void 0?this.pixelRatio_*s: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]]}}},zf=jh;var Oe=.5;function jf(n,t,e,i,r,s,o,a,l){let h=l?Mi(r,l):r,c=n[0]*Oe,u=n[1]*Oe,d=nt(c,u);d.imageSmoothingEnabled=!1;let f=d.canvas,g=new zf(d,Oe,r,null,o,a,l?Ye(hi(),l):null),p=e.length,m=Math.floor((256*256*256-1)/p),_={};for(let E=1;E<=p;++E){let x=e[E-1],C=x.getStyleFunction()||i;if(!C)continue;let T=C(x,s);if(!T)continue;Array.isArray(T)||(T=[T]);let S=(E*m).toString(16).padStart(7,"#00000");for(let w=0,M=T.length;w<M;++w){let N=T[w],z=N.getGeometryFunction()(x);if(!z||!lt(h,z.getExtent()))continue;let A=N.clone(),H=A.getFill();H&&H.setColor(S);let $=A.getStroke();$&&($.setColor(S),$.setLineDash(null)),A.setText(void 0);let P=N.getImage();if(P){let X=P.getImageSize();if(!X)continue;let tt=nt(X[0],X[1],void 0,{alpha:!1}),it=tt.canvas;tt.fillStyle=S,tt.fillRect(0,0,it.width,it.height),A.setImage(new Vr({img:it,anchor:P.getAnchor(),anchorXUnits:"pixels",anchorYUnits:"pixels",offset:P.getOrigin(),opacity:1,size:P.getSize(),scale:P.getScale(),rotation:P.getRotation(),rotateWithView:P.getRotateWithView()}))}let j=A.getZIndex()||0,k=_[j];k||(k={},_[j]=k,k.Polygon=[],k.Circle=[],k.LineString=[],k.Point=[]);let K=z.getType();if(K==="GeometryCollection"){let X=z.getGeometriesArrayRecursive();for(let tt=0,it=X.length;tt<it;++tt){let ot=X[tt];k[ot.getType().replace("Multi","")].push(ot,A)}}else k[K.replace("Multi","")].push(z,A)}}let y=Object.keys(_).map(Number).sort(jt);for(let E=0,x=y.length;E<x;++E){let C=_[y[E]];for(let T in C){let I=C[T];for(let S=0,w=I.length;S<w;S+=2){g.setStyle(I[S+1]);for(let M=0,N=t.length;M<N;++M)g.setTransform(t[M]),g.drawGeometry(I[S])}}}return d.getImageData(0,0,f.width,f.height)}function Wf(n,t,e){let i=[];if(e){let r=Math.floor(Math.round(n[0])*Oe),s=Math.floor(Math.round(n[1])*Oe),o=(Q(r,0,e.width-1)+Q(s,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}var Gp=.5,Xf={Point:Kp,LineString:Xp,Polygon:Bp,MultiPoint:Vp,MultiLineString:Up,MultiPolygon:Yp,GeometryCollection:Wp,Circle:zp};function Uf(n,t){return parseInt(U(n),10)-parseInt(U(t),10)}function Wh(n,t){let e=Xh(n,t);return e*e}function Xh(n,t){return Gp*n/t}function zp(n,t,e,i,r){let s=e.getFill(),o=e.getStroke();if(s||o){let l=n.getBuilder(e.getZIndex(),"Circle");l.setFillStrokeStyle(s,o),l.drawCircle(t,i,r)}let a=e.getText();if(a&&a.getText()){let l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i)}}function Uh(n,t,e,i,r,s,o,a){let l=[],h=e.getImage();if(h){let d=!0,f=h.getImageState();f==b.LOADED||f==b.ERROR?d=!1:f==b.IDLE&&h.load(),d&&l.push(h.ready())}let c=e.getFill();c&&c.loading()&&l.push(c.ready());let u=l.length>0;return u&&Promise.all(l).then(()=>r(null)),jp(n,t,e,i,s,o,a),u}function jp(n,t,e,i,r,s,o){let a=e.getGeometryFunction()(t);if(!a)return;let l=a.simplifyTransformed(i,r);if(e.getRenderer())Yf(n,l,e,t,o);else{let c=Xf[l.getType()];c(n,l,e,t,o,s)}}function Yf(n,t,e,i,r){if(t.getType()=="GeometryCollection"){let o=t.getGeometries();for(let a=0,l=o.length;a<l;++a)Yf(n,o[a],e,i,r);return}n.getBuilder(e.getZIndex(),"Default").drawCustom(t,i,e.getRenderer(),e.getHitDetectionRenderer(),r)}function Wp(n,t,e,i,r,s){let o=t.getGeometriesArray(),a,l;for(a=0,l=o.length;a<l;++a){let h=Xf[o[a].getType()];h(n,o[a],e,i,r,s)}}function Xp(n,t,e,i,r){let s=e.getStroke();if(s){let a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,s),a.drawLineString(t,i,r)}let o=e.getText();if(o&&o.getText()){let a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,r)}}function Up(n,t,e,i,r){let s=e.getStroke();if(s){let a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,s),a.drawMultiLineString(t,i,r)}let o=e.getText();if(o&&o.getText()){let a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,r)}}function Yp(n,t,e,i,r){let s=e.getFill(),o=e.getStroke();if(o||s){let l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(s,o),l.drawMultiPolygon(t,i,r)}let a=e.getText();if(a&&a.getText()){let l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,r)}}function Kp(n,t,e,i,r,s){let o=e.getImage(),a=e.getText(),l=a&&a.getText(),h=s&&o&&l?{}:void 0;if(o){if(o.getImageState()!=b.LOADED)return;let c=n.getBuilder(e.getZIndex(),"Image");c.setImageStyle(o,h),c.drawPoint(t,i,r)}if(l){let c=n.getBuilder(e.getZIndex(),"Text");c.setTextStyle(a,h),c.drawText(t,i,r)}}function Vp(n,t,e,i,r,s){let o=e.getImage(),a=o&&o.getOpacity()!==0,l=e.getText(),h=l&&l.getText(),c=s&&a&&h?{}:void 0;if(a){if(o.getImageState()!=b.LOADED)return;let u=n.getBuilder(e.getZIndex(),"Image");u.setImageStyle(o,c),u.drawMultiPoint(t,i,r)}if(h){let u=n.getBuilder(e.getZIndex(),"Text");u.setTextStyle(l,c),u.drawText(t,i,r)}}function Bp(n,t,e,i,r){let s=e.getFill(),o=e.getStroke();if(s||o){let l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(s,o),l.drawPolygon(t,i,r)}let a=e.getText();if(a&&a.getText()){let l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,r)}}var Yh=class extends Hn{constructor(t){super(t),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.animatingOrInteracting_,this.hitDetectionImageData_=null,this.clipExtent_=null,this.extendX_=!1,this.renderedFeatures_=null,this.renderedRevision_=-1,this.renderedResolution_=NaN,this.renderedExtent_=ct(),this.wrappedRenderedExtent_=ct(),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){let r=e.extent,s=e.viewState,o=s.center,a=s.resolution,l=s.projection,h=s.rotation,c=l.getExtent(),u=this.getLayer().getSource(),d=this.getLayer().getDeclutter(),f=e.pixelRatio,g=e.viewHints,p=!(g[dt.ANIMATING]||g[dt.INTERACTING]),m=this.context,_=Math.round(W(r)/a*f),y=Math.round(et(r)/a*f),E=u.getWrapX()&&l.canWrapX(),x=E?W(c):null,C=E?Math.ceil((r[2]-c[2])/x)+(this.extendX_?2:1):1,T=E?Math.floor((r[0]-c[0])/x)-(this.extendX_?1:0):0;do{let I=this.getRenderTransform(o,a,0,f,_,y,T*x);e.declutter&&(I=I.slice(0)),t.execute(m,[m.canvas.width,m.canvas.height],I,h,p,i===void 0?Hi:i?zh:Df,i?d&&e.declutter[d]:void 0)}while(++T<C)}setDrawContext_(){this.opacity_!==1&&(this.targetContext_=this.context,this.context=nt(this.context.canvas.width,this.context.canvas.height,Ch))}resetDrawContext_(){if(this.opacity_!==1&&this.targetContext_){let t=this.targetContext_.globalAlpha;this.targetContext_.globalAlpha=this.opacity_,this.targetContext_.drawImage(this.context.canvas,0,0),this.targetContext_.globalAlpha=t,on(this.context),Ch.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.clipExtent_&&this.clipUnrotated(this.context,t,this.clipExtent_),this.replayGroup_.renderDeferred(),this.clipExtent_&&(this.context.restore(),this.clipExtent_=null),this.resetDrawContext_())}renderFrame(t,e){let i=t.layerStatesArray[t.layerIndex];this.opacity_=i.opacity;let r=t.viewState;this.prepareContainer(t,e);let s=this.context,o=this.replayGroup_,a=o&&!o.isEmpty();if(!a&&!(this.getLayer().hasListener(Lt.PRERENDER)||this.getLayer().hasListener(Lt.POSTRENDER)))return this.container;this.setDrawContext_(),this.preRender(s,t);let l=r.projection;this.clipExtent_=null;let h=!1;if(a&&i.extent&&this.clipping){let c=Gt(i.extent,l);a=lt(c,t.extent),a&&!le(c,t.extent)&&(t.declutter?this.clipExtent_=c:(this.clipUnrotated(s,t,c),h=!0))}return a&&this.renderWorlds(o,t,this.getLayer().getDeclutter()?!1:void 0),h&&s.restore(),this.postRender(s,t),this.renderedRotation_!==r.rotation&&(this.renderedRotation_=r.rotation,this.hitDetectionImageData_=null),t.declutter||this.resetDrawContext_(),this.container}getFeatures(t){return new Promise(e=>{if(this.frameState&&!this.hitDetectionImageData_&&!this.animatingOrInteracting_){let i=this.frameState.size.slice(),r=this.renderedCenter_,s=this.renderedResolution_,o=this.renderedRotation_,a=this.renderedProjection_,l=this.wrappedRenderedExtent_,h=this.getLayer(),c=[],u=i[0]*Oe,d=i[1]*Oe;c.push(this.getRenderTransform(r,s,o,Oe,u,d,0).slice());let f=h.getSource(),g=a.getExtent();if(f.getWrapX()&&a.canWrapX()&&!le(g,l)){let m=l[0],_=W(g),y=0,E;for(;m<g[0];)--y,E=_*y,c.push(this.getRenderTransform(r,s,o,Oe,u,d,E).slice()),m+=_;for(y=0,m=l[2];m>g[2];)++y,E=_*y,c.push(this.getRenderTransform(r,s,o,Oe,u,d,E).slice()),m-=_}let p=hi();this.hitDetectionImageData_=jf(i,c,this.renderedFeatures_,h.getStyleFunction(),l,s,o,Wh(s,this.renderedPixelRatio_),p?a:null)}e(Wf(t,this.renderedFeatures_,this.hitDetectionImageData_))})}forEachFeatureAtCoordinate(t,e,i,r,s){if(!this.replayGroup_)return;let o=e.viewState.resolution,a=e.viewState.rotation,l=this.getLayer(),h={},c=function(d,f,g){let p=U(d),m=h[p];if(m){if(m!==!0&&g<m.distanceSq){if(g===0)return h[p]=!0,s.splice(s.lastIndexOf(m),1),r(d,l,f);m.geometry=f,m.distanceSq=g}}else{if(g===0)return h[p]=!0,r(d,l,f);s.push(h[p]={feature:d,layer:l,geometry:f,distanceSq:g,callback:r})}},u=this.getLayer().getDeclutter();return this.replayGroup_.forEachFeatureAtCoordinate(t,o,a,i,c,u?e.declutter?.[u]?.all().map(d=>d.value):null)}handleFontsChanged(){let t=this.getLayer();t.getVisible()&&this.replayGroup_&&t.changed()}handleStyleImageChange_(t){this.renderIfReadyAndVisible()}prepareFrame(t){let e=this.getLayer(),i=e.getSource();if(!i)return!1;let r=t.viewHints[dt.ANIMATING],s=t.viewHints[dt.INTERACTING],o=e.getUpdateWhileAnimating(),a=e.getUpdateWhileInteracting();if(this.ready&&!o&&r||!a&&s)return this.animatingOrInteracting_=!0,!0;this.animatingOrInteracting_=!1;let l=t.extent,h=t.viewState,c=h.projection,u=h.resolution,d=t.pixelRatio,f=e.getRevision(),g=e.getRenderBuffer(),p=e.getRenderOrder();p===void 0&&(p=Uf);let m=h.center.slice(),_=ri(l,g*u),y=_.slice(),E=[_.slice()],x=c.getExtent(),C=i.getWrapX()&&c.canWrapX();if(this.extendX_=!1,C){let P=i.getExtent();P&&!Yt(P)&&(this.extendX_=P[0]<x[0]||P[2]>x[2])}if(C&&(!le(x,t.extent)||this.extendX_)){let P=W(x),j=Math.max(W(_)/2,P),k=x[0],K=x[2];this.extendX_&&(k-=P,K+=P),_[0]=k-j,_[2]=K+j,Tn(m,c);let X=_a(E[0],c);X[0]<x[0]&&X[2]<x[2]?E.push([X[0]+P,X[1],X[2]+P,X[3]]):X[0]>x[0]&&X[2]>x[2]&&E.push([X[0]-P,X[1],X[2]-P,X[3]])}if(this.ready&&this.renderedResolution_==u&&this.renderedPixelRatio_===d&&this.renderedRevision_==f&&this.renderedRenderOrder_==p&&this.renderedFrameDeclutter_===!!t.declutter&&le(this.wrappedRenderedExtent_,_))return Ot(this.renderedExtent_,y)||(this.hitDetectionImageData_=null,this.renderedExtent_=y),this.renderedCenter_=m,this.replayGroupChanged=!1,!0;this.replayGroup_=null;let T=new bf(Xh(u,d),_,u,d),I=hi(),S;if(I){for(let P=0,j=E.length;P<j;++P){let k=E[P],K=Mi(k,c);i.loadFeatures(K,Xu(u,c),I)}S=Ye(I,c)}else for(let P=0,j=E.length;P<j;++P)i.loadFeatures(E[P],u,c);let w=Wh(u,d),M=!0,N=(P,j)=>{let k,K=P.getStyleFunction()||e.getStyleFunction();if(K&&(k=K(P,u)),k){let X=this.renderFeature(P,w,k,T,S,this.getLayer().getDeclutter(),j);M=M&&!X}},z=Mi(_,c),A=i.getFeaturesInExtent(z);p&&A.sort(p);for(let P=0,j=A.length;P<j;++P)N(A[P],P);this.renderedFeatures_=A,this.ready=M;let H=T.finish(),$=new Gf(_,u,d,i.getOverlaps(),H,e.getRenderBuffer(),!!t.declutter);return this.renderedResolution_=u,this.renderedRevision_=f,this.renderedRenderOrder_=p,this.renderedFrameDeclutter_=!!t.declutter,this.renderedExtent_=y,this.wrappedRenderedExtent_=_,this.renderedCenter_=m,this.renderedProjection_=c,this.renderedPixelRatio_=d,this.replayGroup_=$,this.hitDetectionImageData_=null,this.replayGroupChanged=!0,!0}renderFeature(t,e,i,r,s,o,a){if(!i)return!1;let l=!1;if(Array.isArray(i))for(let h=0,c=i.length;h<c;++h)l=Uh(r,t,i[h],e,this.boundHandleStyleImageChange_,s,o,a)||l;else l=Uh(r,t,i,e,this.boundHandleStyleImageChange_,s,o,a);return l}},Kf=Yh;var Kh=class extends Co{constructor(t){super(t)}createRenderer(){return new Kf(this)}},Vh=Kh;var Bh=class extends Hn{constructor(t){super(t),this.image=null,this.renderedSourceRevision_=0}getImage(){return this.image?this.image.getImage():null}prepareFrame(t){let e=t.layerStatesArray[t.layerIndex],i=t.pixelRatio,r=t.viewState,s=r.resolution,o=this.getLayer().getSource(),a=t.viewHints,l=t.extent;if(e.extent!==void 0&&(l=Ut(l,Gt(e.extent,r.projection))),!a[dt.ANIMATING]&&!a[dt.INTERACTING]&&!Yt(l))if(o){!this.getLayer().rendered&&this.renderedSourceRevision_!==o.getRevision()&&(this.image=null),this.renderedSourceRevision_=o.getRevision();let h=r.projection,c=o.getImage(l,s,i,h);c&&(this.loadImage(c)?this.image=c:c.getState()===b.EMPTY&&(this.image=null))}else this.image=null;return!!this.image}getData(t){let e=this.frameState;if(!e)return null;let i=this.getLayer(),r=ht(e.pixelToCoordinateTransform,t.slice()),s=i.getExtent();if(s&&!Jt(s,r))return null;let o=this.image.getExtent(),a=this.image.getImage(),l=W(o),h=Math.floor(a.width*((r[0]-o[0])/l));if(h<0||h>=a.width)return null;let c=et(o),u=Math.floor(a.height*((o[3]-r[1])/c));return u<0||u>=a.height?null:this.getImageData(a,h,u)}renderFrame(t,e){let i=this.image,r=i.getExtent(),s=i.getResolution(),[o,a]=Array.isArray(s)?s:[s,s],l=i.getPixelRatio(),h=t.layerStatesArray[t.layerIndex],c=t.pixelRatio,u=t.viewState,d=u.center,f=u.resolution,g=c*o/(f*l),p=c*a/(f*l);this.prepareContainer(t,e);let m=this.context.canvas.width,_=this.context.canvas.height,y=this.getRenderContext(t),E=!1,x=!0;if(h.extent){let w=Gt(h.extent,u.projection);x=lt(w,t.extent),E=x&&!le(w,t.extent),E&&this.clipUnrotated(y,t,w)}let C=i.getImage(),T=Et(this.tempTransform,m/2,_/2,g,p,0,l*(r[0]-d[0])/o,l*(d[1]-r[3])/a);this.renderedResolution=a*c/l;let I=C.width*T[0],S=C.height*T[3];if(this.getLayer().getSource().getInterpolate()||(y.imageSmoothingEnabled=!1),this.preRender(y,t),x&&I>=.5&&S>=.5){let w=T[4],M=T[5],N=h.opacity;N!==1&&(y.save(),y.globalAlpha=N),y.drawImage(C,0,0,+C.width,+C.height,w,M,I,S),N!==1&&y.restore()}return this.postRender(this.context,t),E&&y.restore(),y.imageSmoothingEnabled=!0,this.container}},Vf=Bh;var Zh=class extends ci{constructor(t){t=t||{},super(t)}},Bf=Zh;var Hh=class extends Bf{constructor(t){super(t)}createRenderer(){return new Vf(this)}getData(t){return super.getData(t)}},Zf=Hh;var Jn=[0,0,0],qi=5,qh=class{constructor(t){this.minZoom=t.minZoom!==void 0?t.minZoom:0,this.resolutions_=t.resolutions,V(Qc(this.resolutions_,(r,s)=>s-r,!0),"`resolutions` must be sorted in descending order");let e;if(!t.origins){for(let r=0,s=this.resolutions_.length-1;r<s;++r)if(!e)e=this.resolutions_[r]/this.resolutions_[r+1];else if(this.resolutions_[r]/this.resolutions_[r+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,V(this.origins_.length==this.resolutions_.length,"Number of `origins` and `resolutions` must be equal"));let i=t.extent;i!==void 0&&!this.origin_&&!this.origins_&&(this.origin_=he(i)),V(!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,V(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:256,V(!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((r,s)=>{let o=new vo(Math.min(0,r[0]),Math.max(r[0]-1,-1),Math.min(0,r[1]),Math.max(r[1]-1,-1));if(i){let a=this.getTileRangeForExtentAndZ(i,s);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){let r=this.getTileRangeForExtentAndZ(t,e);for(let s=r.minX,o=r.maxX;s<=o;++s)for(let a=r.minY,l=r.maxY;a<=l;++a)i([e,s,a])}forEachTileCoordParentTileRange(t,e,i,r){let s,o,a,l=null,h=t[0]-1;for(this.zoomFactor_===2?(o=t[1],a=t[2]):l=this.getTileCoordExtent(t,r);h>=this.minZoom;){if(o!==void 0&&a!==void 0?(o=Math.floor(o/2),a=Math.floor(a/2),s=dn(o,o,a,a,i)):s=this.getTileRangeForExtentAndZ(l,h,i),e(h,s))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]}getOrigins(){return this.origins_}getResolution(t){return this.resolutions_[t]}getResolutions(){return this.resolutions_}getTileCoordChildTileRange(t,e,i){if(t[0]<this.maxZoom){if(this.zoomFactor_===2){let s=t[1]*2,o=t[2]*2;return dn(s,s+1,o,o+1,e)}let r=this.getTileCoordExtent(t,i||this.tmpExtent_);return this.getTileRangeForExtentAndZ(r,t[0]+1,e)}return null}getTileRangeForTileCoordAndZ(t,e,i){if(e>this.maxZoom||e<this.minZoom)return null;let r=t[0],s=t[1],o=t[2];if(e===r)return dn(s,o,s,o,i);if(this.zoomFactor_){let l=Math.pow(this.zoomFactor_,e-r),h=Math.floor(s*l),c=Math.floor(o*l);if(e<r)return dn(h,h,c,c,i);let u=Math.floor(l*(s+1))-1,d=Math.floor(l*(o+1))-1;return dn(h,u,c,d,i)}let a=this.getTileCoordExtent(t,this.tmpExtent_);return this.getTileRangeForExtentAndZ(a,e,i)}getTileRangeForExtentAndZ(t,e,i){this.getTileCoordForXYAndZ_(t[0],t[3],e,!1,Jn);let r=Jn[1],s=Jn[2];this.getTileCoordForXYAndZ_(t[2],t[1],e,!0,Jn);let o=Jn[1],a=Jn[2];return dn(r,o,s,a,i)}getTileCoordCenter(t){let e=this.getOrigin(t[0]),i=this.getResolution(t[0]),r=ft(this.getTileSize(t[0]),this.tmpSize_);return[e[0]+(t[1]+.5)*r[0]*i,e[1]-(t[2]+.5)*r[1]*i]}getTileCoordExtent(t,e){let i=this.getOrigin(t[0]),r=this.getResolution(t[0]),s=ft(this.getTileSize(t[0]),this.tmpSize_),o=i[0]+t[1]*s[0]*r,a=i[1]-(t[2]+1)*s[1]*r,l=o+s[0]*r,h=a+s[1]*r;return Qt(o,a,l,h,e)}getTileCoordForCoordAndResolution(t,e,i){return this.getTileCoordForXYAndResolution_(t[0],t[1],e,!1,i)}getTileCoordForXYAndResolution_(t,e,i,r,s){let o=this.getZForResolution(i),a=i/this.getResolution(o),l=this.getOrigin(o),h=ft(this.getTileSize(o),this.tmpSize_),c=a*(t-l[0])/i/h[0],u=a*(l[1]-e)/i/h[1];return r?(c=Ue(c,qi)-1,u=Ue(u,qi)-1):(c=vi(c,qi),u=vi(u,qi)),Vn(o,c,u,s)}getTileCoordForXYAndZ_(t,e,i,r,s){let o=this.getOrigin(i),a=this.getResolution(i),l=ft(this.getTileSize(i),this.tmpSize_),h=(t-o[0])/a/l[0],c=(o[1]-e)/a/l[1];return r?(h=Ue(h,qi)-1,c=Ue(c,qi)-1):(h=vi(h,qi),c=vi(c,qi)),Vn(i,h,c,s)}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){let i=Ri(this.resolutions_,t,e||0);return Q(i,this.minZoom,this.maxZoom)}tileCoordIntersectsViewport(t,e){return Ga(e,0,e.length,2,this.getTileCoordExtent(t))}calculateTileRanges_(t){let e=this.resolutions_.length,i=new Array(e);for(let r=this.minZoom;r<e;++r)i[r]=this.getTileRangeForExtentAndZ(t,r);this.fullTileRanges_=i}},$h=qh;function Fo(n){let t=n.getDefaultTileGrid();return t||(t=Hp(n),n.setDefaultTileGrid(t)),t}function Hf(n,t,e){let i=t[0],r=n.getTileCoordCenter(t),s=Do(e);if(!Jt(s,r)){let o=W(s),a=Math.ceil((s[0]-r[0])/o);return r[0]+=o*a,n.getTileCoordForCoordAndZ(r,i)}return t}function Zp(n,t,e,i){i=i!==void 0?i:"top-left";let r=$f(n,t,e);return new $h({extent:n,origin:cu(n,i),resolutions:r,tileSize:e})}function qf(n){let t=n||{},e=t.extent||q("EPSG:3857").getExtent(),i={extent:e,minZoom:t.minZoom,tileSize:t.tileSize,resolutions:$f(e,t.maxZoom,t.tileSize,t.maxResolution)};return new $h(i)}function $f(n,t,e,i){t=t!==void 0?t:42,e=ft(e!==void 0?e:256);let r=et(n),s=W(n);i=i>0?i:Math.max(s/e[0],r/e[1]);let o=t+1,a=new Array(o);for(let l=0;l<o;++l)a[l]=i/Math.pow(2,l);return a}function Hp(n,t,e,i){let r=Do(n);return Zp(r,t,e,i)}function Do(n){n=q(n);let t=n.getExtent();if(!t){let e=180*Se.degrees/n.getMetersPerUnit();t=Qt(-e,-e,e,e)}return t}function es(n,t){let e=[];Object.keys(t).forEach(function(r){t[r]!==null&&t[r]!==void 0&&e.push(r+"="+encodeURIComponent(t[r]))});let i=e.join("&");return n=n.replace(/[?&]$/,""),n+=n.includes("?")?"&":"?",n+i}var qp=/\{z\}/g,$p=/\{x\}/g,Jp=/\{y\}/g,Qp=/\{-y\}/g;function Jf(n,t,e,i,r){return n.replace(qp,t.toString()).replace($p,e.toString()).replace(Jp,i.toString()).replace(Qp,function(){if(r===void 0)throw new Error("If the URL template has a {-y} placeholder, the grid extent must be known");return(r-i).toString()})}function Qf(n){let t=[],e=/\{([a-z])-([a-z])\}/.exec(n);if(e){let i=e[1].charCodeAt(0),r=e[2].charCodeAt(0),s;for(s=i;s<=r;++s)t.push(n.replace(e[0],String.fromCharCode(s)));return t}if(e=/\{(\d+)-(\d+)\}/.exec(n),e){let i=parseInt(e[2],10);for(let r=parseInt(e[1],10);r<=i;r++)t.push(n.replace(e[0],r.toString()));return t}return t.push(n),t}function t_(n,t){return(function(e,i,r){if(!e)return;let s,o=e[0];if(t){let a=t.getFullTileRange(o);a&&(s=a.getHeight()-1)}return Jf(n,o,e[1],e[2],s)})}function tg(n,t){let e=n.length,i=new Array(e);for(let r=0;r<e;++r)i[r]=t_(n[r],t);return e_(i)}function e_(n){return n.length===1?n[0]:(function(t,e,i){if(!t)return;let r=Lo(t),s=Wt(r,n.length);return n[s](t,e,i)})}var Jh=class extends pt{constructor(t){super(),this.projection=q(t.projection),this.attributions_=eg(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;let e=this;this.viewPromise_=new Promise(function(i,r){e.viewResolver=i,e.viewRejector=r})}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_=eg(t),this.changed()}setState(t){this.state_=t,this.changed()}};function eg(n){return n?typeof n=="function"?n:(Array.isArray(n)||(n=[n]),t=>n):null}var Qn=Jh;var Qh=class extends Qn{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;let e=[256,256];this.tileGrid&&ft(this.tileGrid.getTileSize(this.tileGrid.getMinZoom()),e),this.tmpSize=[0,0],this.key_=t.key||U(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){let e=t?this.getTileGridForProjection(t):this.tileGrid;return e?e.getResolutions():null}getTile(t,e,i,r,s,o){return F()}getTileGrid(){return this.tileGrid}getTileGridForProjection(t){return this.tileGrid?this.tileGrid:Fo(t)}getTilePixelRatio(t){return this.tilePixelRatio_}getTilePixelSize(t,e,i){let r=this.getTileGridForProjection(i),s=this.getTilePixelRatio(e),o=ft(r.getTileSize(t),this.tmpSize);return s==1?o:zd(o,s,this.tmpSize)}getTileCoordForTileUrlFunction(t,e){let i=e!==void 0?e:this.getProjection(),r=e!==void 0?this.getTileGridForProjection(i):this.tileGrid||this.getTileGridForProjection(i);return this.getWrapX()&&i.isGlobal()&&(t=Hf(r,t,i)),xf(t,r)?t:null}clear(){}refresh(){this.clear(),super.refresh()}},ko=class extends mt{constructor(t,e){super(t),this.tile=e}},ig=Qh;var No={TILELOADSTART:"tileloadstart",TILELOADEND:"tileloadend",TILELOADERROR:"tileloaderror"};var tc=class n extends ig{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===n.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){let e=t.target,i=U(e),r=e.getState(),s;r==O.LOADING?(this.tileLoadingKeys_[i]=!0,s=No.TILELOADSTART):i in this.tileLoadingKeys_&&(delete this.tileLoadingKeys_[i],s=r==O.ERROR?No.TILELOADERROR:r==O.LOADED?No.TILELOADEND:void 0),s!=null&&this.dispatchEvent(new ko(s,e))}setTileLoadFunction(t){this.tileLoadFunction=t,this.changed()}setTileUrlFunction(t,e){this.tileUrlFunction=t,typeof e<"u"?this.setKey(e):this.changed()}setUrl(t){let e=Qf(t);this.urls=e,this.setUrls(e)}setUrls(t){this.urls=t;let e=t.join(`
|
|
7
|
+
`);this.generateTileUrlFunction_?this.setTileUrlFunction(tg(t,this.tileGrid),e):this.setKey(e)}tileUrlFunction(t,e,i){}},ng=tc;var ec=class extends ng{constructor(t){super({attributions:t.attributions,cacheSize:t.cacheSize,projection:t.projection,state:t.state,tileGrid:t.tileGrid,tileLoadFunction:t.tileLoadFunction?t.tileLoadFunction:i_,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.referrerPolicy=t.referrerPolicy,this.tileClass=t.tileClass!==void 0?t.tileClass:So,this.tileGridForProjection={},this.reprojectionErrorThreshold_=t.reprojectionErrorThreshold,this.renderReprojectionEdges_=!1}getGutterForProjection(t){return this.getProjection()&&t&&!ve(this.getProjection(),t)?0:this.getGutter()}getGutter(){return 0}getKey(){let t=super.getKey();return this.getInterpolate()||(t+=":disable-interpolation"),t}getTileGridForProjection(t){let e=this.getProjection();if(this.tileGrid&&(!e||ve(e,t)))return this.tileGrid;let i=U(t);return i in this.tileGridForProjection||(this.tileGridForProjection[i]=Fo(t)),this.tileGridForProjection[i]}createTile_(t,e,i,r,s,o){let a=[t,e,i],l=this.getTileCoordForTileUrlFunction(a,s),h=l?this.tileUrlFunction(l,r,s):void 0,c=new this.tileClass(a,h!==void 0?O.IDLE:O.EMPTY,h!==void 0?h:"",{crossOrigin:this.crossOrigin,referrerPolicy:this.referrerPolicy},this.tileLoadFunction,this.tileOptions);return c.key=o,c.addEventListener(L.CHANGE,this.handleTileChange.bind(this)),c}getTile(t,e,i,r,s,o){let a=this.getProjection();if(!a||!s||ve(a,s))return this.getTileInternal(t,e,i,r,a||s);let l=[t,e,i],h=this.getKey(),c=this.getTileGridForProjection(a),u=this.getTileGridForProjection(s),d=this.getTileCoordForTileUrlFunction(l,s),f=new bo(a,c,s,u,l,d,this.getTilePixelRatio(r),this.getGutter(),(g,p,m,_)=>this.getTileInternal(g,p,m,_,a,o),this.reprojectionErrorThreshold_,this.renderReprojectionEdges_,this.tileOptions);return f.key=h,f}getTileInternal(t,e,i,r,s,o){let a=this.getKey(),l=Bn(this,a,t,e,i);if(o&&o.containsKey(l))return o.get(l);let h=this.createTile_(t,e,i,r,s,a);return o?.set(l,h),h}setRenderReprojectionEdges(t){this.renderReprojectionEdges_!=t&&(this.renderReprojectionEdges_=t,this.changed())}setTileGridForProjection(t,e){let i=q(t);if(i){let r=U(i);r in this.tileGridForProjection||(this.tileGridForProjection[r]=e)}}};function i_(n,t){if(xt){let e=n.getCrossOrigin(),i="same-origin",r="same-origin";e==="anonymous"||e===""?(i="cors",r="omit"):e==="use-credentials"&&(i="cors",r="include");let s={mode:i,credentials:r,referrerPolicy:n.getReferrerPolicy()};fetch(t,s).then(o=>{if(!o.ok)throw new Error(`HTTP ${o.status}`);return o.blob()}).then(o=>createImageBitmap(o)).then(o=>{let a=n.getImage();a.width=o.width,a.height=o.height,a.getContext("2d").drawImage(o,0,0),o.close?.(),a.dispatchEvent(new Event("load"))}).catch(()=>{n.getImage().dispatchEvent(new Event("error"))});return}n.getImage().src=t}var Go=ec;var ic=class extends Go{constructor(t){t=t||{};let e=t.projection!==void 0?t.projection:"EPSG:3857",i=t.tileGrid!==void 0?t.tileGrid:qf({extent:Do(e),maxResolution:t.maxResolution,maxZoom:t.maxZoom,minZoom:t.minZoom,tileSize:t.tileSize});super({attributions:t.attributions,cacheSize:t.cacheSize,crossOrigin:t.crossOrigin,referrerPolicy:t.referrerPolicy,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_}},nc=ic;function is(n){return Array.isArray(n)?Math.min(...n):n}var rc=class extends co{constructor(t,e,i,r,s,o,a){let l=t.getExtent();l&&t.canWrapX()&&(l=l.slice(),l[0]=-1/0,l[2]=1/0);let h=e.getExtent();h&&e.canWrapX()&&(h=h.slice(),h[0]=-1/0,h[2]=1/0);let c=h?Ut(i,h):i,u=St(c),d=Vi(t,e,u,r),f=.5,g=new Mo(t,e,c,l,d*f,r),p=g.calculateSourceExtent(),m=Yt(p)?null:o(p,d,s),_=m?b.IDLE:b.EMPTY,y=m?m.getPixelRatio():1;super(i,r,y,_),this.targetProj_=e,this.maxSourceExtent_=l,this.triangulation_=g,this.targetResolution_=r,this.targetExtent_=i,this.sourceImage_=m,this.sourcePixelRatio_=y,this.interpolate_=a,this.canvas_=null,this.sourceListenerKey_=null}disposeInternal(){this.state==b.LOADING&&this.unlistenSource_(),super.disposeInternal()}getImage(){return this.canvas_}getProjection(){return this.targetProj_}reproject_(){let t=this.sourceImage_.getState();if(t==b.LOADED){let e=W(this.targetExtent_)/this.targetResolution_,i=et(this.targetExtent_)/this.targetResolution_;this.canvas_=Io(e,i,this.sourcePixelRatio_,is(this.sourceImage_.getResolution()),this.maxSourceExtent_,this.targetResolution_,this.targetExtent_,this.triangulation_,[{extent:this.sourceImage_.getExtent(),image:this.sourceImage_.getImage()}],0,void 0,this.interpolate_,!0)}this.state=t,this.changed()}load(){if(this.state==b.IDLE){this.state=b.LOADING,this.changed();let t=this.sourceImage_.getState();t==b.LOADED||t==b.ERROR?this.reproject_():(this.sourceListenerKey_=G(this.sourceImage_,L.CHANGE,e=>{let i=this.sourceImage_.getState();(i==b.LOADED||i==b.ERROR)&&(this.unlistenSource_(),this.reproject_())}),this.sourceImage_.load())}}unlistenSource_(){B(this.sourceListenerKey_),this.sourceListenerKey_=null}},rg=rc;var sc={IMAGELOADSTART:"imageloadstart",IMAGELOADEND:"imageloadend",IMAGELOADERROR:"imageloaderror"},oc=class extends mt{constructor(t,e){super(t),this.image=e}},ac=class extends Qn{constructor(t){super({attributions:t.attributions,projection:t.projection,state:t.state,interpolate:t.interpolate!==void 0?t.interpolate:!0}),this.on,this.once,this.un,this.loader=t.loader||null,this.resolutions_=t.resolutions!==void 0?t.resolutions:null,this.reprojectedImage_=null,this.reprojectedRevision_=0,this.image=null,this.wantedExtent_,this.wantedResolution_,this.static_=t.loader?t.loader.length===0:!1,this.wantedProjection_=null}getResolutions(){return this.resolutions_}setResolutions(t){this.resolutions_=t}findNearestResolution(t){let e=this.getResolutions();if(e){let i=Ri(e,t,0);t=e[i]}return t}getImage(t,e,i,r){let s=this.getProjection();if(!s||!r||ve(s,r))return s&&(r=s),this.getImageInternal(t,e,i,r);if(this.reprojectedImage_){if(this.reprojectedRevision_==this.getRevision()&&ve(this.reprojectedImage_.getProjection(),r)&&this.reprojectedImage_.getResolution()==e&&we(this.reprojectedImage_.getExtent(),t))return this.reprojectedImage_;this.reprojectedImage_.dispose(),this.reprojectedImage_=null}return this.reprojectedImage_=new rg(s,r,t,e,i,(o,a,l)=>this.getImageInternal(o,a,l,s),this.getInterpolate()),this.reprojectedRevision_=this.getRevision(),this.reprojectedImage_}getImageInternal(t,e,i,r){if(this.loader){let s=lc(t,e,i,1),o=this.findNearestResolution(e);if(this.image&&(this.static_||this.wantedProjection_===r&&(this.wantedExtent_&&le(this.wantedExtent_,s)||le(this.image.getExtent(),s))&&(this.wantedResolution_&&is(this.wantedResolution_)===o||is(this.image.getResolution())===o)))return this.image;this.wantedProjection_=r,this.wantedExtent_=s,this.wantedResolution_=o,this.image=new co(s,o,i,this.loader),this.image.addEventListener(L.CHANGE,this.handleImageChange.bind(this))}return this.image}handleImageChange(t){let e=t.target,i;switch(e.getState()){case b.LOADING:this.loading=!0,i=sc.IMAGELOADSTART;break;case b.LOADED:this.loading=!1,i=sc.IMAGELOADEND;break;case b.ERROR:this.loading=!1,i=sc.IMAGELOADERROR;break;default:return}this.hasListener(i)&&this.dispatchEvent(new oc(i,e))}};function sg(n,t){n.getImage().src=t}function lc(n,t,e,i){let r=t/e,s=St(n),o=Ue(W(n)/r,4),a=Ue(et(n)/r,4),l=Ue((i-1)*o/2,4),h=o+2*l,c=Ue((i-1)*a/2,4),u=a+2*c;return oi(s,r,0,[h,u])}var og=ac;var ns="1.3.0",ag=[101,101];function lg(n,t,e,i,r){r.WIDTH=e[0],r.HEIGHT=e[1];let s=i.getAxisOrientation(),o=ur(r.VERSION,"1.3")>=0;r[o?"CRS":"SRS"]=i.getCode();let a=o&&s.startsWith("ne")?[t[1],t[0],t[3],t[2]]:t;return r.BBOX=a.join(","),es(n,r)}function hc(n,t,e,i,r,s,o){s=Object.assign({REQUEST:"GetMap"},s);let a=t/e,l=[da(W(n)/a,4),da(et(n)/a,4)];if(e!=1)switch(o){case"geoserver":let c=90*e+.5|0;"FORMAT_OPTIONS"in s?s.FORMAT_OPTIONS+=";dpi:"+c:s.FORMAT_OPTIONS="dpi:"+c;break;case"mapserver":s.MAP_RESOLUTION=90*e;break;case"carmentaserver":case"qgis":s.DPI=90*e;break;default:throw new Error("Unknown `serverType` configured")}return lg(r,n,l,i,s)}function rs(n,t){return Object.assign({REQUEST:t,SERVICE:"WMS",VERSION:ns,FORMAT:"image/png",STYLES:"",TRANSPARENT:"TRUE"},n)}function hg(n){let t=n.hidpi===void 0?!0:n.hidpi,e=q(n.projection||"EPSG:3857"),i=n.ratio||1.5,r=n.load||ho,s=n.crossOrigin??null,o=n.referrerPolicy;return(a,l,h)=>{a=lc(a,l,h,i),h!=1&&(!t||n.serverType===void 0)&&(h=1);let c=hc(a,l,h,e,n.url,rs(n.params,"GetMap"),n.serverType),u=new Image;return u.crossOrigin=s,o!==void 0&&(u.referrerPolicy=o),r(u,c).then(d=>({image:d,extent:a,pixelRatio:h}))}}function cg(n,t,e){if(n.url===void 0)return;let i=q(n.projection||"EPSG:3857"),r=oi(t,e,0,ag),s={QUERY_LAYERS:n.params.LAYERS,INFO_FORMAT:"application/json"};Object.assign(s,rs(n.params,"GetFeatureInfo"),n.params);let o=vi((t[0]-r[0])/e,4),a=vi((r[3]-t[1])/e,4),l=ur(s.VERSION,"1.3")>=0;return s[l?"I":"X"]=o,s[l?"J":"Y"]=a,lg(n.url,r,ag,i,s)}function ug(n,t){if(n.url===void 0)return;let e={SERVICE:"WMS",VERSION:ns,REQUEST:"GetLegendGraphic",FORMAT:"image/png"};if(t!==void 0){let i=q(n.projection||"EPSG:3857").getMetersPerUnit()||1,r=28e-5;e.SCALE=t*i/r}if(Object.assign(e,n.params),n.params!==void 0&&e.LAYER===void 0){let i=e.LAYERS;if(!(!Array.isArray(i)||i.length!==1))return;e.LAYER=i}return es(n.url,e)}var cc=class extends Go{constructor(t){t=t||{};let e=Object.assign({},t.params);super({attributions:t.attributions,attributionsCollapsible:t.attributionsCollapsible,cacheSize:t.cacheSize,crossOrigin:t.crossOrigin,interpolate:t.interpolate,projection:t.projection,reprojectionErrorThreshold:t.reprojectionErrorThreshold,tileClass:t.tileClass,tileGrid:t.tileGrid,tileLoadFunction:t.tileLoadFunction,url:t.url,urls:t.urls,wrapX:t.wrapX!==void 0?t.wrapX:!0,transition:t.transition,zDirection:t.zDirection}),this.gutter_=t.gutter!==void 0?t.gutter:0,this.params_=e,this.v13_=!0,this.serverType_=t.serverType,this.hidpi_=t.hidpi!==void 0?t.hidpi:!0,this.tmpExtent_=ct(),this.updateV13_(),this.setKey(this.getKeyForParams_())}getFeatureInfoUrl(t,e,i,r){let s=q(i),o=this.getProjection()||s,a=this.getTileGrid();a||(a=this.getTileGridForProjection(o));let l=de(t,s,o),h=Vi(o,s,t,e),c=a.getZForResolution(h,this.zDirection),u=a.getResolution(c),d=a.getTileCoordForCoordAndZ(l,c);if(a.getResolutions().length<=d[0])return;let f=a.getTileCoordExtent(d,this.tmpExtent_),g=this.gutter_;g!==0&&(f=ri(f,u*g,f));let p={QUERY_LAYERS:this.params_.LAYERS};Object.assign(p,rs(this.params_,"GetFeatureInfo"),r);let m=Math.floor((l[0]-f[0])/u),_=Math.floor((f[3]-l[1])/u);return p[this.v13_?"I":"X"]=m,p[this.v13_?"J":"Y"]=_,this.getRequestUrl_(d,f,1,o||s,p)}getLegendUrl(t,e){if(this.urls[0]===void 0)return;let i={SERVICE:"WMS",VERSION:ns,REQUEST:"GetLegendGraphic",FORMAT:"image/png"};if(e===void 0||e.LAYER===void 0){let r=this.params_.LAYERS;if(!(!Array.isArray(r)||r.length===1))return;i.LAYER=r}if(t!==void 0){let r=this.getProjection()?this.getProjection().getMetersPerUnit():1,s=28e-5;i.SCALE=t*r/s}return Object.assign(i,e),es(this.urls[0],i)}getGutter(){return this.gutter_}getParams(){return this.params_}getRequestUrl_(t,e,i,r,s){let o=this.urls;if(!o)return;let a;if(o.length==1)a=o[0];else{let l=Wt(Lo(t),o.length);a=o[l]}return hc(e,(this.tileGrid||this.getTileGridForProjection(r)).getResolution(t[0]),i,r,a,s,this.serverType_)}getTilePixelRatio(t){return!this.hidpi_||this.serverType_===void 0?1:t}getKeyForParams_(){let t=0,e=[];for(let i in this.params_)e[t++]=i+"-"+this.params_[i];return e.join("/")}setParams_(t){this.params_=t,this.updateV13_(),this.setKey(this.getKeyForParams_())}setParams(t){this.setParams_(Object.assign({},t))}updateParams(t){this.setParams_(Object.assign(this.params_,t))}updateV13_(){let t=this.params_.VERSION||ns;this.v13_=ur(t,"1.3")>=0}tileUrlFunction(t,e,i){let r=this.getTileGrid();if(r||(r=this.getTileGridForProjection(i)),r.getResolutions().length<=t[0])return;e!=1&&(!this.hidpi_||this.serverType_===void 0)&&(e=1);let s=r.getResolution(t[0]),o=r.getTileCoordExtent(t,this.tmpExtent_),a=this.gutter_;a!==0&&(o=ri(o,s*a,o));let l=Object.assign({},rs(this.params_,"GetMap"));return this.getRequestUrl_(t,o,e,i,l)}},dg=cc;var uc=class extends og{constructor(t){t=t||{},super({attributions:t.attributions,interpolate:t.interpolate,projection:t.projection,resolutions:t.resolutions}),this.crossOrigin_=t.crossOrigin!==void 0?t.crossOrigin:null,this.referrerPolicy_=t.referrerPolicy,this.url_=t.url,this.imageLoadFunction_=t.imageLoadFunction!==void 0?t.imageLoadFunction:sg,this.params_=Object.assign({},t.params),this.serverType_=t.serverType,this.hidpi_=t.hidpi!==void 0?t.hidpi:!0,this.renderedRevision_=0,this.ratio_=t.ratio!==void 0?t.ratio:1.5,this.loaderProjection_=null}getFeatureInfoUrl(t,e,i,r){let s=q(i),o=this.getProjection();o&&o!==s&&(e=Vi(o,s,t,e),t=de(t,s,o));let a={url:this.url_,params:{...this.params_,...r},projection:o||s};return cg(a,t,e)}getLegendUrl(t,e){return ug({url:this.url_,params:{...this.params_,...e}},t)}getParams(){return this.params_}getImageInternal(t,e,i,r){return this.url_===void 0?null:((!this.loader||this.loaderProjection_!==r)&&(this.loaderProjection_=r,this.loader=hg({crossOrigin:this.crossOrigin_,referrerPolicy:this.referrerPolicy_,params:this.params_,projection:r,serverType:this.serverType_,hidpi:this.hidpi_,url:this.url_,ratio:this.ratio_,load:(s,o)=>(this.image.setImage(s),this.imageLoadFunction_(this.image,o),ho(s))})),super.getImageInternal(t,e,i,r))}getImageLoadFunction(){return this.imageLoadFunction_}getUrl(){return this.url_}setImageLoadFunction(t){this.imageLoadFunction_=t,this.changed()}setUrl(t){t!=this.url_&&(this.url_=t,this.loader=null,this.changed())}setParams(t){this.params_=Object.assign({},t),this.loader=null,this.changed()}updateParams(t){Object.assign(this.params_,t),this.changed()}changed(){this.image=null,super.changed()}},fg=uc;var n_=!1;function r_(n,t,e,i,r,s,o){let a=new XMLHttpRequest;a.open("GET",typeof n=="function"?n(e,i,r):n,!0),t.getType()=="arraybuffer"&&(a.responseType="arraybuffer"),a.withCredentials=n_,a.onload=function(l){if(!a.status||a.status>=200&&a.status<300){let 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?s(t.readFeatures(c,{extent:e,featureProjection:r}),t.readProjection(c)):o()}catch{o()}}else o()},a.onerror=o,a.send()}function dc(n,t){return function(e,i,r,s,o){r_(n,t,e,i,r,(a,l)=>{this.addFeatures(a),s!==void 0&&s(a)},()=>{this.changed(),o!==void 0&&o()})}}function gg(n,t){return[[-1/0,-1/0,1/0,1/0]]}var fc=class n extends pt{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"){let e=t;this.setGeometry(e)}else{let e=t;this.setProperties(e)}}clone(){let t=new n(this.hasProperties()?this.getProperties():null);t.setGeometryName(this.getGeometryName());let e=this.getGeometry();e&&t.setGeometry(e.clone());let 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_&&(B(this.geometryChangeKey_),this.geometryChangeKey_=null);let t=this.getGeometry();t&&(this.geometryChangeKey_=G(t,L.CHANGE,this.handleGeometryChange_,this)),this.changed()}setGeometry(t){this.set(this.geometryName_,t)}setStyle(t){this.style_=t,this.styleFunction_=t?s_(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 s_(n){if(typeof n=="function")return n;let t;return Array.isArray(n)?t=n:(V(typeof n.getZIndex=="function","Expected an `ol/style/Style` or an array of `ol/style/Style.js`"),t=[n]),function(){return t}}var zo=fc;function jo(n,t,e,i){let r=[],s=ct();for(let o=0,a=e.length;o<a;++o){let l=e[o];s=En(n,t,l[0],i),r.push((s[0]+s[2])/2,(s[1]+s[3])/2),t=l[l.length-1]}return r}function mn(n,t,e,i,r,s,o){let a,l,h=(e-t)/i;if(h===1)a=t;else if(h===2)a=t,l=r;else if(h!==0){let c=n[t],u=n[t+1],d=0,f=[0];for(let m=t+i;m<e;m+=i){let _=n[m],y=n[m+1];d+=Math.sqrt((_-c)*(_-c)+(y-u)*(y-u)),f.push(d),c=_,u=y}let g=r*d,p=qc(f,g);p<0?(l=(g-f[-p-2])/(f[-p-1]-f[-p-2]),a=t+(-p-2)*i):a=t+p*i}o=o>1?o:2,s=s||new Array(o);for(let c=0;c<o;++c)s[c]=a===void 0?NaN:l===void 0?n[a+c]:bt(n[a+c],n[a+i+c],l);return s}function Wo(n,t,e,i,r,s){if(e==t)return null;let o;if(r<n[t+i-1])return s?(o=n.slice(t,t+i),o[i-1]=r,o):null;if(n[e-1]<r)return s?(o=n.slice(e-i,e),o[i-1]=r,o):null;if(r==n[t+i-1])return n.slice(t,t+i);let a=t/i,l=e/i;for(;a<l;){let d=a+l>>1;r<n[(d+1)*i-1]?l=d:a=d+1}let h=n[a*i-1];if(r==h)return n.slice((a-1)*i,(a-1)*i+i);let c=n[(a+1)*i-1],u=(r-h)/(c-h);o=[];for(let d=0;d<i-1;++d)o.push(bt(n[(a-1)*i+d],n[a*i+d],u));return o.push(r),o}function mg(n,t,e,i,r,s,o){if(o)return Wo(n,t,e[e.length-1],i,r,s);let a;if(r<n[i-1])return s?(a=n.slice(0,i),a[i-1]=r,a):null;if(n[n.length-1]<r)return s?(a=n.slice(n.length-i),a[i-1]=r,a):null;for(let l=0,h=e.length;l<h;++l){let c=e[l];if(t!=c){if(r<n[t+i-1])return null;if(r<=n[c-1])return Wo(n,t,c,i,r,!1);t=c}}return null}var mc=class n extends js{constructor(t){super(),this.geometries_=t,this.changeEventsKeys_=[],this.listenGeometriesChange_()}unlistenGeometriesChange_(){this.changeEventsKeys_.forEach(B),this.changeEventsKeys_.length=0}listenGeometriesChange_(){let t=this.geometries_;for(let e=0,i=t.length;e<i;++e)this.changeEventsKeys_.push(G(t[e],L.CHANGE,this.changed,this))}clone(){let t=new n(gc(this.geometries_));return t.applyProperties(this),t}closestPointXY(t,e,i,r){if(r<Xt(this.getExtent(),t,e))return r;let s=this.geometries_;for(let o=0,a=s.length;o<a;++o)r=s[o].closestPointXY(t,e,i,r);return r}containsXY(t,e){let i=this.geometries_;for(let r=0,s=i.length;r<s;++r)if(i[r].containsXY(t,e))return!0;return!1}computeExtent(t){si(t);let e=this.geometries_;for(let i=0,r=e.length;i<r;++i)vs(t,e[i].getExtent());return t}getGeometries(){return gc(this.geometries_)}getGeometriesArray(){return this.geometries_}getGeometriesArrayRecursive(){let t=[],e=this.geometries_;for(let i=0,r=e.length;i<r;++i)e[i].getType()===this.getType()?t=t.concat(e[i].getGeometriesArrayRecursive()):t.push(e[i]);return t}getSimplifiedGeometry(t){if(this.simplifiedGeometryRevision!==this.getRevision()&&(this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=this.getRevision()),t<0||this.simplifiedGeometryMaxMinSquaredTolerance!==0&&t<this.simplifiedGeometryMaxMinSquaredTolerance)return this;let e=[],i=this.geometries_,r=!1;for(let s=0,o=i.length;s<o;++s){let a=i[s],l=a.getSimplifiedGeometry(t);e.push(l),l!==a&&(r=!0)}return r?new n(e):(this.simplifiedGeometryMaxMinSquaredTolerance=t,this)}getType(){return"GeometryCollection"}intersectsExtent(t){let e=this.geometries_;for(let i=0,r=e.length;i<r;++i)if(e[i].intersectsExtent(t))return!0;return!1}isEmpty(){return this.geometries_.length===0}rotate(t,e){let i=this.geometries_;for(let r=0,s=i.length;r<s;++r)i[r].rotate(t,e);this.changed()}scale(t,e,i){i||(i=St(this.getExtent()));let r=this.geometries_;for(let s=0,o=r.length;s<o;++s)r[s].scale(t,e,i);this.changed()}setGeometries(t){this.setGeometriesArray(gc(t))}setGeometriesArray(t){this.unlistenGeometriesChange_(),this.geometries_=t,this.listenGeometriesChange_(),this.changed()}applyTransform(t){let e=this.geometries_;for(let i=0,r=e.length;i<r;++i)e[i].applyTransform(t);this.changed()}translate(t,e){let i=this.geometries_;for(let r=0,s=i.length;r<s;++r)i[r].translate(t,e);this.changed()}disposeInternal(){this.unlistenGeometriesChange_(),super.disposeInternal()}};function gc(n){return n.map(t=>t.clone())}var pc=mc;var _c=class n extends Vt{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){It(this.flatCoordinates,t),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(mr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),_r(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!1,t,e,i,r))}forEachSegment(t){return Ys(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,Wo(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e))}getCoordinates(){return fe(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinateAt(t,e){return mn(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,this.stride)}getLength(){return qn(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){let e=[];return e.length=sn(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new n(e,"XY")}getType(){return"LineString"}intersectsExtent(t){return wr(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=rn(this.flatCoordinates,0,t,this.stride),this.changed()}},tr=_c;var yc=class n extends Vt{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{let r=t,s=[],o=[];for(let l=0,h=r.length;l<h;++l){let c=r[l];It(s,c.getFlatCoordinates()),o.push(s.length)}let a=r.length===0?this.getLayout():r[0].getLayout();this.setFlatCoordinates(a,s),this.ends_=o}}appendLineString(t){It(this.flatCoordinates,t.getFlatCoordinates().slice()),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(pr(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),yr(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!1,t,e,i,r))}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,mg(this.flatCoordinates,0,this.ends_,this.stride,t,e,i))}getCoordinates(){return Ai(this.flatCoordinates,0,this.ends_,this.stride)}getEnds(){return this.ends_}getLineString(t){return t<0||this.ends_.length<=t?null:new tr(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLineStrings(){let t=this.flatCoordinates,e=this.ends_,i=this.layout,r=[],s=0;for(let o=0,a=e.length;o<a;++o){let l=e[o],h=new tr(t.slice(s,l),i);r.push(h),s=l}return r}getLength(){let t=this.ends_,e=0,i=0;for(let r=0,s=t.length;r<s;++r)i+=qn(this.flatCoordinates,e,t[r],this.stride),e=t[r];return i}getFlatMidpoints(){let t=[],e=this.flatCoordinates,i=0,r=this.ends_,s=this.stride;for(let o=0,a=r.length;o<a;++o){let l=r[o],h=mn(e,i,l,s,.5);It(t,h),i=l}return t}getSimplifiedGeometryInternal(t){let e=[],i=[];return e.length=Xs(this.flatCoordinates,0,this.ends_,this.stride,t,e,0,i),new n(e,"XY",i)}getType(){return"MultiLineString"}intersectsExtent(t){return sd(this.flatCoordinates,0,this.ends_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,2),this.flatCoordinates||(this.flatCoordinates=[]);let i=Li(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}},xc=yc;var Ec=class n extends Vt{constructor(t,e){super(),e&&!Array.isArray(t[0])?this.setFlatCoordinates(e,t):this.setCoordinates(t,e)}appendPoint(t){It(this.flatCoordinates,t.getFlatCoordinates()),this.changed()}clone(){let t=new n(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,r){if(r<Xt(this.getExtent(),t,e))return r;let s=this.flatCoordinates,o=this.stride;for(let a=0,l=s.length;a<l;a+=o){let h=Ce(t,e,s[a],s[a+1]);if(h<r){r=h;for(let c=0;c<o;++c)i[c]=s[a+c];i.length=o}}return r}getCoordinates(){return fe(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getPoint(t){let e=this.flatCoordinates.length/this.stride;return t<0||e<=t?null:new Oi(this.flatCoordinates.slice(t*this.stride,(t+1)*this.stride),this.layout)}getPoints(){let t=this.flatCoordinates,e=this.layout,i=this.stride,r=[];for(let s=0,o=t.length;s<o;s+=i){let a=new Oi(t.slice(s,s+i),e);r.push(a)}return r}getType(){return"MultiPoint"}intersectsExtent(t){let e=this.flatCoordinates,i=this.stride;for(let r=0,s=e.length;r<s;r+=i){let o=e[r],a=e[r+1];if(hr(t,o,a))return!0}return!1}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=rn(this.flatCoordinates,0,t,this.stride),this.changed()}},ss=Ec;var Cc=class n extends Vt{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])){let r=t,s=[],o=[];for(let a=0,l=r.length;a<l;++a){let h=r[a],c=s.length,u=h.getEnds();for(let d=0,f=u.length;d<f;++d)u[d]+=c;It(s,h.getFlatCoordinates()),o.push(u)}e=r.length===0?this.getLayout():r[0].getLayout(),t=s,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{let i=this.flatCoordinates.length;It(this.flatCoordinates,t.getFlatCoordinates()),e=t.getEnds().slice();for(let r=0,s=e.length;r<s;++r)e[r]+=i}this.endss_.push(e),this.changed()}clone(){let t=this.endss_.length,e=new Array(t);for(let r=0;r<t;++r)e[r]=this.endss_[r].slice();let i=new n(this.flatCoordinates.slice(),this.layout,e);return i.applyProperties(this),i}closestPointXY(t,e,i,r){return r<Xt(this.getExtent(),t,e)?r:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(Qu(this.flatCoordinates,0,this.endss_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),td(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,this.maxDelta_,!0,t,e,i,r))}containsXY(t,e){return rd(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t,e)}getArea(){return $u(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),Tr(e,0,this.endss_,this.stride,t)):e=this.flatCoordinates,xr(e,0,this.endss_,this.stride)}getEndss(){return this.endss_}getFlatInteriorPoints(){if(this.flatInteriorPointsRevision_!=this.getRevision()){let t=jo(this.flatCoordinates,0,this.endss_,this.stride);this.flatInteriorPoints_=Us(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t),this.flatInteriorPointsRevision_=this.getRevision()}return this.flatInteriorPoints_}getInteriorPoints(){return new ss(this.getFlatInteriorPoints().slice(),"XYM")}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){let t=this.flatCoordinates;Ks(t,0,this.endss_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=Tr(this.orientedFlatCoordinates_,0,this.endss_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){let e=[],i=[];return e.length=id(this.flatCoordinates,0,this.endss_,this.stride,Math.sqrt(t),e,0,i),new n(e,"XY",i)}getPolygon(t){if(t<0||this.endss_.length<=t)return null;let e;if(t===0)e=0;else{let s=this.endss_[t-1];e=s[s.length-1]}let i=this.endss_[t].slice(),r=i[i.length-1];if(e!==0)for(let s=0,o=i.length;s<o;++s)i[s]-=e;return new Di(this.flatCoordinates.slice(e,r),this.layout,i)}getPolygons(){let t=this.layout,e=this.flatCoordinates,i=this.endss_,r=[],s=0;for(let o=0,a=i.length;o<a;++o){let l=i[o].slice(),h=l[l.length-1];if(s!==0)for(let u=0,d=l.length;u<d;++u)l[u]-=s;let c=new Di(e.slice(s,h),t,l);r.push(c),s=h}return r}getType(){return"MultiPolygon"}intersectsExtent(t){return od(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,3),this.flatCoordinates||(this.flatCoordinates=[]);let i=Ws(this.flatCoordinates,0,t,this.stride,this.endss_);if(i.length===0)this.flatCoordinates.length=0;else{let r=i[i.length-1];this.flatCoordinates.length=r.length===0?0:r[r.length-1]}this.changed()}},Rc=Cc;var pg=Tt(),os=class n{constructor(t,e,i,r,s,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_=s,this.squaredTolerance_,this.stride_=r,this.simplifiedGeometry_}get(t){return this.properties_[t]}getExtent(){return this.extent_||(this.extent_=this.type_==="Point"?Ts(this.flatCoordinates_):En(this.flatCoordinates_,0,this.flatCoordinates_.length,2)),this.extent_}getFlatInteriorPoint(){if(!this.flatInteriorPoints_){let t=St(this.getExtent());this.flatInteriorPoints_=Rr(this.flatCoordinates_,0,this.ends_,2,t,0)}return this.flatInteriorPoints_}getFlatInteriorPoints(){if(!this.flatInteriorPoints_){let t=ld(this.flatCoordinates_,this.ends_),e=jo(this.flatCoordinates_,0,t,2);this.flatInteriorPoints_=Us(this.flatCoordinates_,0,t,2,e)}return this.flatInteriorPoints_}getFlatMidpoint(){return this.flatMidpoints_||(this.flatMidpoints_=mn(this.flatCoordinates_,0,this.flatCoordinates_.length,2,.5)),this.flatMidpoints_}getFlatMidpoints(){if(!this.flatMidpoints_){this.flatMidpoints_=[];let t=this.flatCoordinates_,e=0,i=this.ends_;for(let r=0,s=i.length;r<s;++r){let o=i[r],a=mn(t,e,o,2,.5);It(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=q(t);let e=t.getExtent(),i=t.getWorldExtent();if(e&&i){let r=et(i)/et(e);Et(pg,i[0],i[3],r,-r,0,0,0),Kt(this.flatCoordinates_,0,this.flatCoordinates_.length,2,pg,this.flatCoordinates_)}}applyTransform(t){t(this.flatCoordinates_,this.flatCoordinates_,this.stride_)}clone(){return new n(this.type_,this.flatCoordinates_.slice(),this.ends_?.slice(),this.stride_,Object.assign({},this.properties_),this.id_)}getEnds(){return this.ends_}enableSimplifyTransformed(){return this.simplifyTransformed=ms((t,e)=>{if(t===this.squaredTolerance_)return this.simplifiedGeometry_;this.simplifiedGeometry_=this.clone(),e&&this.simplifiedGeometry_.applyTransform(e);let i=this.simplifiedGeometry_.getFlatCoordinates(),r;switch(this.type_){case"LineString":i.length=sn(i,0,this.simplifiedGeometry_.flatCoordinates_.length,this.simplifiedGeometry_.stride_,t,i,0),r=[i.length];break;case"MultiLineString":r=[],i.length=Xs(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,t,i,0,r);break;case"Polygon":r=[],i.length=Er(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,Math.sqrt(t),i,0,r);break;default:}return r&&(this.simplifiedGeometry_=new n(this.type_,i,r,2,this.properties_,this.id_)),this.squaredTolerance_=t,this.simplifiedGeometry_}),this}};os.prototype.getFlatCoordinates=os.prototype.getOrientedFlatCoordinates;var Fe=os;var wc=class{constructor(t){this.rbush_=new ln(t),this.items_={}}insert(t,e){let i={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3],value:e};this.rbush_.insert(i),this.items_[U(e)]=i}load(t,e){let i=new Array(e.length);for(let r=0,s=e.length;r<s;r++){let o=t[r],a=e[r],l={minX:o[0],minY:o[1],maxX:o[2],maxY:o[3],value:a};i[r]=l,this.items_[U(a)]=l}this.rbush_.load(i)}remove(t){let e=U(t),i=this.items_[e];return delete this.items_[e],this.rbush_.remove(i)!==null}update(t,e){let i=this.items_[U(e)],r=[i.minX,i.minY,i.maxX,i.maxY];we(r,t)||(this.remove(e),this.insert(t,e))}getAll(){return this.rbush_.all().map(function(e){return e.value})}getInExtent(t){let e={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3]};return this.rbush_.search(e).map(function(r){return r.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 r=0,s=t.length;r<s;r++)if(i=e(t[r]),i)return i;return i}isEmpty(){return $t(this.items_)}clear(){this.rbush_.clear(),this.items_={}}getExtent(t){let e=this.rbush_.toJSON();return Qt(e.minX,e.minY,e.maxX,e.maxY,t)}concat(t){this.rbush_.load(t.rbush_.all());for(let e in t.items_)this.items_[e]=t.items_[e]}},Sc=wc;var ee={ADDFEATURE:"addfeature",CHANGEFEATURE:"changefeature",CLEAR:"clear",REMOVEFEATURE:"removefeature",FEATURESLOADSTART:"featuresloadstart",FEATURESLOADEND:"featuresloadend",FEATURESLOADERROR:"featuresloaderror"};var $e=class extends mt{constructor(t,e,i){super(t),this.feature=e,this.features=i}},Tc=class extends Qn{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_=ni,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&&(V(this.format_,"`format` must be set when `url` is set"),this.loader_=dc(this.url_,this.format_)),this.strategy_=t.strategy!==void 0?t.strategy:gg;let e=t.useSpatialIndex!==void 0?t.useSpatialIndex:!0;this.featuresRtree_=e?new Sc:null,this.loadedExtentsRtree_=new Sc,this.loadingExtentsCount_=0,this.nullGeometryFeatures_={},this.idIndex_={},this.uidIndex_={},this.featureChangeKeys_={},this.featuresCollection_=null;let i,r;Array.isArray(t.features)?r=t.features:t.features&&(i=t.features,r=i.getArray()),!e&&i===void 0&&(i=new Mt(r)),r!==void 0&&this.addFeaturesInternal(r),i!==void 0&&this.bindFeaturesCollection_(i)}addFeature(t){this.addFeatureInternal(t),this.changed()}addFeatureInternal(t){let e=U(t);if(!this.addToIndex_(e,t)){this.featuresCollection_&&this.featuresCollection_.remove(t);return}this.setupChangeEvents_(e,t);let i=t.getGeometry();if(i){let r=i.getExtent();this.featuresRtree_&&this.featuresRtree_.insert(r,t)}else this.nullGeometryFeatures_[e]=t;this.dispatchEvent(new $e(ee.ADDFEATURE,t))}setupChangeEvents_(t,e){e instanceof Fe||(this.featureChangeKeys_[t]=[G(e,L.CHANGE,this.handleFeatureChange_,this),G(e,Ee.PROPERTYCHANGE,this.handleFeatureChange_,this)])}addToIndex_(t,e){let i=!0;if(e.getId()!==void 0){let r=String(e.getId());if(!(r in this.idIndex_))this.idIndex_[r]=e;else if(e instanceof Fe){let s=this.idIndex_[r];s instanceof Fe?Array.isArray(s)?s.push(e):this.idIndex_[r]=[s,e]:i=!1}else i=!1}return i&&(V(!(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){let e=[],i=[],r=[];for(let s=0,o=t.length;s<o;s++){let a=t[s],l=U(a);this.addToIndex_(l,a)&&i.push(a)}for(let s=0,o=i.length;s<o;s++){let a=i[s],l=U(a);this.setupChangeEvents_(l,a);let h=a.getGeometry();if(h){let c=h.getExtent();e.push(c),r.push(a)}else this.nullGeometryFeatures_[l]=a}if(this.featuresRtree_&&this.featuresRtree_.load(e,r),this.hasListener(ee.ADDFEATURE))for(let s=0,o=i.length;s<o;s++)this.dispatchEvent(new $e(ee.ADDFEATURE,i[s]))}bindFeaturesCollection_(t){let e=!1;this.addEventListener(ee.ADDFEATURE,function(i){e||(e=!0,t.push(i.feature),e=!1)}),this.addEventListener(ee.REMOVEFEATURE,function(i){e||(e=!0,t.remove(i.feature),e=!1)}),t.addEventListener(wt.ADD,i=>{e||(e=!0,this.addFeature(i.element),e=!1)}),t.addEventListener(wt.REMOVE,i=>{e||(e=!0,this.removeFeature(i.element),e=!1)}),this.featuresCollection_=t}clear(t){if(t){for(let i in this.featureChangeKeys_)this.featureChangeKeys_[i].forEach(B);this.featuresCollection_||(this.featureChangeKeys_={},this.idIndex_={},this.uidIndex_={})}else if(this.featuresRtree_){this.featuresRtree_.forEach(i=>{this.removeFeatureInternal(i)});for(let i in this.nullGeometryFeatures_)this.removeFeatureInternal(this.nullGeometryFeatures_[i])}this.featuresCollection_&&this.featuresCollection_.clear(),this.featuresRtree_&&this.featuresRtree_.clear(),this.nullGeometryFeatures_={};let e=new $e(ee.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){let i=[t[0],t[1],t[0],t[1]];return this.forEachFeatureInExtent(i,function(r){let s=r.getGeometry();if(s instanceof Fe||s.intersectsCoordinate(t))return e(r)})}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){let r=i.getGeometry();if(r instanceof Fe||r.intersectsExtent(t)){let s=e(i);if(s)return s}})}getFeaturesCollection(){return this.featuresCollection_}getFeatures(){let t;return this.featuresCollection_?t=this.featuresCollection_.getArray().slice(0):this.featuresRtree_&&(t=this.featuresRtree_.getAll(),$t(this.nullGeometryFeatures_)||It(t,Object.values(this.nullGeometryFeatures_))),t}getFeaturesAtCoordinate(t){let 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);let r=Ms(t,e);return[].concat(...r.map(s=>this.featuresRtree_.getInExtent(s)))}return this.featuresCollection_?this.featuresCollection_.getArray().slice(0):[]}getClosestFeatureToCoordinate(t,e){let i=t[0],r=t[1],s=null,o=[NaN,NaN],a=1/0,l=[-1/0,-1/0,1/0,1/0];return e=e||ei,this.featuresRtree_.forEachInExtent(l,function(h){if(e(h)){let c=h.getGeometry(),u=a;if(a=c instanceof Fe?0:c.closestPointXY(i,r,o,a),a<u){s=h;let d=Math.sqrt(a);l[0]=i-d,l[1]=r-d,l[2]=i+d,l[3]=r+d}}}),s}getExtent(t){return this.featuresRtree_?.getExtent(t)??null}getFeatureById(t){let e=this.idIndex_[t.toString()];return e!==void 0?e:null}getFeatureByUid(t){let e=this.uidIndex_[t];return e!==void 0?e:null}getFormat(){return this.format_}getOverlaps(){return this.overlaps_}getUrl(){return this.url_}handleFeatureChange_(t){let e=t.target,i=U(e),r=e.getGeometry();if(!r)i in this.nullGeometryFeatures_||(this.featuresRtree_&&this.featuresRtree_.remove(e),this.nullGeometryFeatures_[i]=e);else{let o=r.getExtent();i in this.nullGeometryFeatures_?(delete this.nullGeometryFeatures_[i],this.featuresRtree_&&this.featuresRtree_.insert(o,e)):this.featuresRtree_&&this.featuresRtree_.update(o,e)}let s=e.getId();if(s!==void 0){let o=s.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 $e(ee.CHANGEFEATURE,e))}hasFeature(t){let e=t.getId();return e!==void 0?e in this.idIndex_:U(t)in this.uidIndex_}isEmpty(){return this.featuresRtree_?this.featuresRtree_.isEmpty()&&$t(this.nullGeometryFeatures_):this.featuresCollection_?this.featuresCollection_.getLength()===0:!0}loadFeatures(t,e,i){let r=this.loadedExtentsRtree_,s=this.strategy_(t,e,i);for(let o=0,a=s.length;o<a;++o){let l=s[o];r.forEachInExtent(l,function(c){return le(c.extent,l)})||(++this.loadingExtentsCount_,this.dispatchEvent(new $e(ee.FEATURESLOADSTART)),this.loader_.call(this,l,e,i,c=>{--this.loadingExtentsCount_,this.dispatchEvent(new $e(ee.FEATURESLOADEND,void 0,c))},()=>{--this.loadingExtentsCount_,this.dispatchEvent(new $e(ee.FEATURESLOADERROR))}),r.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){let e=this.loadedExtentsRtree_,i=e.forEachInExtent(t,function(r){if(we(r.extent,t))return r});i&&e.remove(i)}removeFeatures(t){let e=!1;for(let i=0,r=t.length;i<r;++i)e=this.removeFeatureInternal(t[i])||e;e&&this.changed()}removeFeature(t){if(!t)return;this.removeFeatureInternal(t)&&this.changed()}removeFeatureInternal(t){let e=U(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(B),delete this.featureChangeKeys_[e];let r=t.getId();if(r!==void 0){let s=r.toString(),o=this.idIndex_[s];o===t?delete this.idIndex_[s]:Array.isArray(o)&&(o.splice(o.indexOf(t),1),o.length===1&&(this.idIndex_[s]=o[0]))}return delete this.uidIndex_[e],this.hasListener(ee.REMOVEFEATURE)&&this.dispatchEvent(new $e(ee.REMOVEFEATURE,t)),!0}removeFromIdIndex_(t){for(let e in this.idIndex_)if(this.idIndex_[e]===t){delete this.idIndex_[e];break}}setLoader(t){this.loader_=t}setUrl(t){V(this.format_,"`format` must be set when `url` is set"),this.url_=t,this.setLoader(dc(t,this.format_))}setOverlaps(t){this.overlaps_=t,this.changed()}},vc=Tc;var Ic=class{constructor(){this.dataProjection=void 0,this.defaultFeatureProjection=void 0,this.featureClass=zo,this.supportedMediaTypes=null}getReadOptions(t,e){if(e){let i=e.dataProjection?q(e.dataProjection):this.readProjection(t);e.extent&&i&&i.getUnits()==="tile-pixels"&&(i=q(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 F()}readFeature(t,e){return F()}readFeatures(t,e){return F()}readGeometry(t,e){return F()}readProjection(t){return F()}writeFeature(t,e){return F()}writeFeatures(t,e){return F()}writeGeometry(t,e){return F()}},_g=Ic;function Xo(n,t,e){let i=e?q(e.featureProjection):null,r=e?q(e.dataProjection):null,s=n;if(i&&r&&!ve(i,r)){t&&(s=n.clone());let o=t?i:r,a=t?r:i;o.getUnits()==="tile-pixels"?s.transform(o,a):s.applyTransform(li(o,a))}if(t&&e&&e.decimals!==void 0){let o=Math.pow(10,e.decimals),a=function(l){for(let h=0,c=l.length;h<c;++h)l[h]=Math.round(l[h]*o)/o;return l};s===n&&(s=n.clone()),s.applyTransform(a)}return s}var o_={Point:Oi,LineString:tr,Polygon:Di,MultiPoint:ss,MultiLineString:xc,MultiPolygon:Rc};function a_(n,t,e){return Array.isArray(t[0])?(Ks(n,0,t,e)||(n=n.slice(),Tr(n,0,t,e)),n):(Sr(n,0,t,e)||(n=n.slice(),Pn(n,0,t,e)),n)}function Mc(n,t){let e=n.geometry;if(!e)return[];if(Array.isArray(e))return e.map(s=>Mc({...n,geometry:s})).flat();let i=e.type==="MultiPolygon"?"Polygon":e.type;if(i==="GeometryCollection"||i==="Circle")throw new Error("Unsupported geometry type: "+i);let r=e.layout.length;return Xo(new Fe(i,i==="Polygon"?a_(e.flatCoordinates,e.ends,r):e.flatCoordinates,e.ends?.flat(),r,n.properties||{},n.id).enableSimplifyTransformed(),!1,t)}function Uo(n,t){if(!n)return null;if(Array.isArray(n)){let i=n.map(r=>Uo(r,t));return new pc(i)}let e=o_[n.type];return Xo(new e(n.flatCoordinates,n.layout||"XY",n.ends),!1,t)}var bc=class extends _g{constructor(){super()}getType(){return"json"}readFeature(t,e){return this.readFeatureFromObject(Yo(t),this.getReadOptions(t,e))}readFeatures(t,e){return this.readFeaturesFromObject(Yo(t),this.getReadOptions(t,e))}readFeatureFromObject(t,e){return F()}readFeaturesFromObject(t,e){return F()}readGeometry(t,e){return this.readGeometryFromObject(Yo(t),this.getReadOptions(t,e))}readGeometryFromObject(t,e){return F()}readProjection(t){return this.readProjectionFromObject(Yo(t))}readProjectionFromObject(t){return F()}writeFeature(t,e){return JSON.stringify(this.writeFeatureObject(t,e))}writeFeatureObject(t,e){return F()}writeFeatures(t,e){return JSON.stringify(this.writeFeaturesObject(t,e))}writeFeaturesObject(t,e){return F()}writeGeometry(t,e){return JSON.stringify(this.writeGeometryObject(t,e))}writeGeometryObject(t,e){return F()}};function Yo(n){if(typeof n=="string"){let t=JSON.parse(n);return t||null}return n!==null?n:null}var yg=bc;var Lc=class extends yg{constructor(t){t=t||{},super(),this.dataProjection=q(t.dataProjection?t.dataProjection:"EPSG:4326"),t.featureProjection&&(this.defaultFeatureProjection=q(t.featureProjection)),t.featureClass&&(this.featureClass=t.featureClass),this.geometryName_=t.geometryName,this.extractGeometryName_=t.extractGeometryName,this.supportedMediaTypes=["application/geo+json","application/vnd.geo+json"]}readFeatureFromObject(t,e){let i=null;t.type==="Feature"?i=t:i={type:"Feature",geometry:t,properties:null};let r=Pc(i.geometry,e);if(this.featureClass===Fe)return Mc({geometry:r,id:i.id,properties:i.properties},e);let s=new zo;return this.geometryName_?s.setGeometryName(this.geometryName_):this.extractGeometryName_&&i.geometry_name&&s.setGeometryName(i.geometry_name),s.setGeometry(Uo(r,e)),"id"in i&&s.setId(i.id),i.properties&&s.setProperties(i.properties,!0),s}readFeaturesFromObject(t,e){let i=t,r=null;if(i.type==="FeatureCollection"){let s=t;r=[];let o=s.features;for(let a=0,l=o.length;a<l;++a){let h=this.readFeatureFromObject(o[a],e);h&&r.push(h)}}else r=[this.readFeatureFromObject(t,e)];return r.flat()}readGeometryFromObject(t,e){return l_(t,e)}readProjectionFromObject(t){let e=t.crs,i;if(e)if(e.type=="name")i=q(e.properties.name);else if(e.type==="EPSG")i=q("EPSG:"+e.properties.code);else throw new Error("Unknown SRS type");else i=this.dataProjection;return i}writeFeatureObject(t,e){e=this.adaptOptions(e);let i={type:"Feature",geometry:null,properties:null},r=t.getId();if(r!==void 0&&(i.id=r),!t.hasProperties())return i;let s=t.getProperties(),o=t.getGeometry();return o&&(i.geometry=Ac(o,e),delete s[t.getGeometryName()]),$t(s)||(i.properties=s),i}writeFeaturesObject(t,e){e=this.adaptOptions(e);let i=[];for(let r=0,s=t.length;r<s;++r)i.push(this.writeFeatureObject(t[r],e));return{type:"FeatureCollection",features:i}}writeGeometryObject(t,e){return Ac(t,this.adaptOptions(e))}};function Pc(n,t){if(!n)return null;let e;switch(n.type){case"Point":{e=c_(n);break}case"LineString":{e=u_(n);break}case"Polygon":{e=m_(n);break}case"MultiPoint":{e=f_(n);break}case"MultiLineString":{e=d_(n);break}case"MultiPolygon":{e=g_(n);break}case"GeometryCollection":{e=h_(n);break}default:throw new Error("Unsupported GeoJSON type: "+n.type)}return e}function l_(n,t){let e=Pc(n,t);return Uo(e,t)}function h_(n,t){return n.geometries.map(function(i){return Pc(i,t)})}function c_(n){let t=n.coordinates;return{type:"Point",flatCoordinates:t,layout:bi(t.length)}}function u_(n){let t=n.coordinates,e=t.flat();return{type:"LineString",flatCoordinates:e,ends:[e.length],layout:bi(t[0]?.length||2)}}function d_(n){let t=n.coordinates,e=t[0]?.[0]?.length||2,i=[],r=Li(i,0,t,e);return{type:"MultiLineString",flatCoordinates:i,ends:r,layout:bi(e)}}function f_(n){let t=n.coordinates;return{type:"MultiPoint",flatCoordinates:t.flat(),layout:bi(t[0]?.length||2)}}function g_(n){let t=n.coordinates,e=[],i=t[0]?.[0]?.[0].length||2,r=Ws(e,0,t,i);return{type:"MultiPolygon",flatCoordinates:e,ends:r,layout:bi(i)}}function m_(n){let t=n.coordinates,e=[],i=t[0]?.[0]?.length,r=Li(e,0,t,i);return{type:"Polygon",flatCoordinates:e,ends:r,layout:bi(i)}}function Ac(n,t){n=Xo(n,!0,t);let e=n.getType(),i;switch(e){case"Point":{i=C_(n,t);break}case"LineString":{i=__(n,t);break}case"Polygon":{i=R_(n,t);break}case"MultiPoint":{i=x_(n,t);break}case"MultiLineString":{i=y_(n,t);break}case"MultiPolygon":{i=E_(n,t);break}case"GeometryCollection":{i=p_(n,t);break}case"Circle":{i={type:"GeometryCollection",geometries:[]};break}default:throw new Error("Unsupported geometry type: "+e)}return i}function p_(n,t){return t=Object.assign({},t),delete t.featureProjection,{type:"GeometryCollection",geometries:n.getGeometriesArray().map(function(i){return Ac(i,t)})}}function __(n,t){return{type:"LineString",coordinates:n.getCoordinates()}}function y_(n,t){return{type:"MultiLineString",coordinates:n.getCoordinates()}}function x_(n,t){return{type:"MultiPoint",coordinates:n.getCoordinates()}}function E_(n,t){let e;return t&&(e=t.rightHanded),{type:"MultiPolygon",coordinates:n.getCoordinates(e)}}function C_(n,t){return{type:"Point",coordinates:n.getCoordinates()}}function R_(n,t){let e;return t&&(e=t.rightHanded),{type:"Polygon",coordinates:n.getCoordinates(e)}}var Oc=Lc;var xg=["fullscreenchange","webkitfullscreenchange"],Eg={ENTERFULLSCREEN:"enterfullscreen",LEAVEFULLSCREEN:"leavefullscreen"},Fc=class extends me{constructor(t){t=t||{},super({element:document.createElement("div"),target:t.target}),this.on,this.once,this.un,this.keys_=t.keys!==void 0?t.keys:!1,this.source_=t.source,this.isInFullscreen_=!1,this.boundHandleMapTargetChange_=this.handleMapTargetChange_.bind(this),this.cssClassName_=t.className!==void 0?t.className:"ol-full-screen",this.documentListeners_=[],this.activeClassName_=t.activeClassName!==void 0?t.activeClassName.split(" "):[this.cssClassName_+"-true"],this.inactiveClassName_=t.inactiveClassName!==void 0?t.inactiveClassName.split(" "):[this.cssClassName_+"-false"];let e=t.label!==void 0?t.label:"\u2922";this.labelNode_=typeof e=="string"?document.createTextNode(e):e;let i=t.labelActive!==void 0?t.labelActive:"\xD7";this.labelActiveNode_=typeof i=="string"?document.createTextNode(i):i;let r=t.tipLabel?t.tipLabel:"Toggle full-screen";this.button_=document.createElement("button"),this.button_.title=r,this.button_.setAttribute("type","button"),this.button_.appendChild(this.labelNode_),this.button_.addEventListener(L.CLICK,this.handleClick_.bind(this),!1),this.setClassName_(this.button_,this.isInFullscreen_),this.element.className=`${this.cssClassName_} ${ge} ${ki}`,this.element.appendChild(this.button_)}handleClick_(t){t.preventDefault(),this.handleFullScreen_()}handleFullScreen_(){let t=this.getMap();if(!t)return;let e=t.getOwnerDocument();if(Cg(e))if(Rg(e))S_(e);else{let i;this.source_?i=typeof this.source_=="string"?e.getElementById(this.source_):this.source_:i=t.getTargetElement(),this.keys_?w_(i):wg(i)}}handleFullScreenChange_(){let t=this.getMap();if(!t)return;let e=this.isInFullscreen_;this.isInFullscreen_=Rg(t.getOwnerDocument()),e!==this.isInFullscreen_&&(this.setClassName_(this.button_,this.isInFullscreen_),this.isInFullscreen_?(Dn(this.labelActiveNode_,this.labelNode_),this.dispatchEvent(Eg.ENTERFULLSCREEN)):(Dn(this.labelNode_,this.labelActiveNode_),this.dispatchEvent(Eg.LEAVEFULLSCREEN)),t.updateSize())}setClassName_(t,e){e?(t.classList.remove(...this.inactiveClassName_),t.classList.add(...this.activeClassName_)):(t.classList.remove(...this.activeClassName_),t.classList.add(...this.inactiveClassName_))}setMap(t){let e=this.getMap();e&&e.removeChangeListener(_t.TARGET,this.boundHandleMapTargetChange_),super.setMap(t),this.handleMapTargetChange_(),t&&t.addChangeListener(_t.TARGET,this.boundHandleMapTargetChange_)}handleMapTargetChange_(){let t=this.documentListeners_;for(let i=0,r=t.length;i<r;++i)B(t[i]);t.length=0;let e=this.getMap();if(e){let i=e.getOwnerDocument();Cg(i)?this.element.classList.remove(Ha):this.element.classList.add(Ha);for(let r=0,s=xg.length;r<s;++r)t.push(G(i,xg[r],this.handleFullScreenChange_,this));this.handleFullScreenChange_()}}};function Cg(n){let t=n.body;return!!(t.webkitRequestFullscreen||t.requestFullscreen&&n.fullscreenEnabled)}function Rg(n){return!!(n.webkitIsFullScreen||n.fullscreenElement)}function wg(n){n.requestFullscreen?n.requestFullscreen():n.webkitRequestFullscreen&&n.webkitRequestFullscreen()}function w_(n){n.webkitRequestFullscreen?n.webkitRequestFullscreen():wg(n)}function S_(n){n.exitFullscreen?n.exitFullscreen():n.webkitExitFullscreen&&n.webkitExitFullscreen()}var Dc=Fc;var kc="projection",Sg="coordinateFormat",Nc=class extends me{constructor(t){t=t||{};let e=document.createElement("div");e.className=t.className!==void 0?t.className:"ol-mouse-position",super({element:e,render:t.render,target:t.target}),this.on,this.once,this.un,this.addChangeListener(kc,this.handleProjectionChanged_),t.coordinateFormat&&this.setCoordinateFormat(t.coordinateFormat),t.projection&&this.setProjection(t.projection),this.renderOnMouseOut_=t.placeholder!==void 0,this.placeholder_=this.renderOnMouseOut_?t.placeholder:" ",this.renderedHTML_=e.innerHTML,this.mapProjection_=null,this.transform_=null,this.wrapX_=t.wrapX!==!1}handleProjectionChanged_(){this.transform_=null}getCoordinateFormat(){return this.get(Sg)}getProjection(){return this.get(kc)}handleMouseMove(t){let e=this.getMap();this.updateHTML_(e.getEventPixel(t))}handleMouseOut(t){this.updateHTML_(null)}setMap(t){if(super.setMap(t),t){let e=t.getViewport();this.listenerKeys.push(G(e,Si.POINTERMOVE,this.handleMouseMove,this)),this.renderOnMouseOut_&&this.listenerKeys.push(G(e,Si.POINTEROUT,this.handleMouseOut,this)),this.updateHTML_(null)}}setCoordinateFormat(t){this.set(Sg,t)}setProjection(t){this.set(kc,q(t))}updateHTML_(t){let e=this.placeholder_;if(t&&this.mapProjection_){if(!this.transform_){let s=this.getProjection();s?this.transform_=Ye(this.mapProjection_,s):this.transform_=zu}let r=this.getMap().getCoordinateFromPixelInternal(t);if(r){let s=hi();if(s&&(this.transform_=Ye(this.mapProjection_,s)),this.transform_(r,r),this.wrapX_){let a=s||this.getProjection()||this.mapProjection_;Tn(r,a)}let o=this.getCoordinateFormat();o?e=o(r):e=r.toString()}}(!this.renderedHTML_||e!==this.renderedHTML_)&&(this.element.innerHTML=e,this.renderedHTML_=e)}render(t){let e=t.frameState;e?this.mapProjection_!=e.viewState.projection&&(this.mapProjection_=e.viewState.projection,this.transform_=null):this.mapProjection_=null}},Gc=Nc;var zc="units",T_=[1,2,5],as=25.4/.28,jc=class extends me{constructor(t){t=t||{};let e=document.createElement("div");e.style.pointerEvents="none",super({element:e,render:t.render,target:t.target}),this.on,this.once,this.un;let i=t.className!==void 0?t.className:t.bar?"ol-scale-bar":"ol-scale-line";this.innerElement_=document.createElement("div"),this.innerElement_.className=i+"-inner",this.element.className=i+" "+ge,this.element.appendChild(this.innerElement_),this.viewState_=null,this.minWidth_=t.minWidth!==void 0?t.minWidth:64,this.maxWidth_=t.maxWidth,this.renderedVisible_=!1,this.renderedWidth_=void 0,this.renderedHTML_="",this.addChangeListener(zc,this.handleUnitsChanged_),this.setUnits(t.units||"metric"),this.scaleBar_=t.bar||!1,this.scaleBarSteps_=t.steps||4,this.scaleBarText_=t.text||!1,this.dpi_=t.dpi||void 0}getUnits(){return this.get(zc)}handleUnitsChanged_(){this.updateElement_()}setUnits(t){this.set(zc,t)}setDpi(t){this.dpi_=t}updateElement_(){let t=this.viewState_;if(!t){this.renderedVisible_&&(this.element.style.display="none",this.renderedVisible_=!1);return}let e=t.center,i=t.projection,r=this.getUnits(),s=r=="degrees"?"degrees":"m",o=An(i,t.resolution,e,s),a=this.minWidth_*(this.dpi_||as)/as,l=this.maxWidth_!==void 0?this.maxWidth_*(this.dpi_||as)/as:void 0,h=a*o,c="";if(r=="degrees"){let E=Se.degrees;h*=E,h<E/60?(c="\u2033",o*=3600):h<E?(c="\u2032",o*=60):c="\xB0"}else if(r=="imperial")h<.9144?(c="in",o/=.0254):h<1609.344?(c="ft",o/=.3048):(c="mi",o/=1609.344);else if(r=="nautical")o/=1852,c="NM";else if(r=="metric")h<1e-6?(c="nm",o*=1e9):h<.001?(c="\u03BCm",o*=1e6):h<1?(c="mm",o*=1e3):h<1e3?c="m":(c="km",o/=1e3);else if(r=="us")h<.9144?(c="in",o*=39.37):h<1609.344?(c="ft",o/=.30480061):(c="mi",o/=1609.3472);else throw new Error("Invalid units");let u=3*Math.floor(Math.log(a*o)/Math.log(10)),d,f,g,p=0,m,_;for(;;){g=Math.floor(u/3);let E=Math.pow(10,g);if(d=T_[(u%3+3)%3]*E,f=Math.round(d/o),isNaN(f)){this.element.style.display="none",this.renderedVisible_=!1;return}if(l!==void 0&&f>=l){d=p,f=m,g=_;break}else if(f>=a)break;p=d,m=f,_=g,++u}let y=this.scaleBar_?this.createScaleBar(f,d,c):d.toFixed(g<0?-g:0)+" "+c;this.renderedHTML_!=y&&(this.innerElement_.innerHTML=y,this.renderedHTML_=y),this.renderedWidth_!=f&&(this.innerElement_.style.width=f+"px",this.renderedWidth_=f),this.renderedVisible_||(this.element.style.display="",this.renderedVisible_=!0)}createScaleBar(t,e,i){let r=this.getScaleForResolution(),s=r<1?Math.round(1/r).toLocaleString()+" : 1":"1 : "+Math.round(r).toLocaleString(),o=this.scaleBarSteps_,a=t/o,l=[this.createMarker("absolute")];for(let c=0;c<o;++c){let u=c%2===0?"ol-scale-singlebar-odd":"ol-scale-singlebar-even";l.push(`<div><div class="ol-scale-singlebar ${u}" style="width: ${a}px;"></div>`+this.createMarker("relative")+(c%2===0||o===2?this.createStepText(c,t,!1,e,i):"")+"</div>")}return l.push(this.createStepText(o,t,!0,e,i)),(this.scaleBarText_?`<div class="ol-scale-text" style="width: ${t}px;">`+s+"</div>":"")+l.join("")}createMarker(t){return`<div class="ol-scale-step-marker" style="position: ${t}; top: ${t==="absolute"?3:-10}px;"></div>`}createStepText(t,e,i,r,s){let a=(t===0?0:Math.round(r/this.scaleBarSteps_*t*100)/100)+(t===0?"":" "+s),l=t===0?-3:e/this.scaleBarSteps_*-1,h=t===0?0:e/this.scaleBarSteps_*2;return`<div class="ol-scale-step-text" style="margin-left: ${l}px;text-align: ${t===0?"left":"center"};min-width: ${h}px;left: ${i?e+"px":"unset"};">`+a+"</div>"}getScaleForResolution(){let t=An(this.viewState_.projection,this.viewState_.resolution,this.viewState_.center,"m"),e=this.dpi_||as,i=1e3/25.4;return t*i*e}render(t){let e=t.frameState;e?this.viewState_=e.viewState:this.viewState_=null,this.updateElement_()}},Wc=jc;var Xc=class extends pe{constructor(t){t=t||{},super(t),this.condition_=t.condition?t.condition:to,this.lastAngle_=void 0,this.lastMagnitude_=void 0,this.lastScaleDelta_=0,this.duration_=t.duration!==void 0?t.duration:400}handleDragEvent(t){if(!Ni(t))return;let e=t.map,i=e.getSize(),r=t.pixel,s=r[0]-i[0]/2,o=i[1]/2-r[1],a=Math.atan2(o,s),l=Math.sqrt(s*s+o*o),h=e.getView();if(this.lastAngle_!==void 0){let c=this.lastAngle_-a;h.adjustRotationInternal(c)}this.lastAngle_=a,this.lastMagnitude_!==void 0&&h.adjustResolutionInternal(this.lastMagnitude_/l),this.lastMagnitude_!==void 0&&(this.lastScaleDelta_=this.lastMagnitude_/l),this.lastMagnitude_=l}handleUpEvent(t){if(!Ni(t))return!0;let i=t.map.getView(),r=this.lastScaleDelta_>1?1:-1;return i.endInteraction(this.duration_,r),this.lastScaleDelta_=0,!1}handleDownEvent(t){return Ni(t)&&this.condition_(t)?(t.map.getView().beginInteraction(),this.lastAngle_=void 0,this.lastMagnitude_=void 0,!0):!1}},Ko=Xc;var Vo=class{model;el;map=null;mapContainer=null;lastProcessedCallId=0;pendingCalls=[];eventQueue=[];isMapReady=!1;methodHandlers=new Map;modelListeners=[];constructor(t,e){this.model=t,this.el=e}createMapContainer(){let t=this.model.get("width")||"100%",e=this.model.get("height")||"400px";this.el.style.width="100%",this.el.style.display="block",e.endsWith("%")&&(this.el.style.height="100%");let i=document.createElement("div");return i.style.width=t,i.style.height=e,i.style.position="relative",i.style.minWidth="200px",this.el.appendChild(i),this.mapContainer=i,i}setupModelListeners(){let t=()=>this.processJsCalls(),e=()=>this.onCenterChange(),i=()=>this.onZoomChange(),r=()=>this.onStyleChange();this.model.on("change:_js_calls",t),this.model.on("change:center",e),this.model.on("change:zoom",i),this.model.on("change:style",r),this.modelListeners.push(()=>this.model.off("change:_js_calls",t),()=>this.model.off("change:center",e),()=>this.model.off("change:zoom",i),()=>this.model.off("change:style",r))}removeModelListeners(){this.modelListeners.forEach(t=>t()),this.modelListeners=[]}registerMethod(t,e){this.methodHandlers.set(t,e)}executeMethod(t,e,i){let r=this.methodHandlers.get(t);if(r)try{r(e,i)}catch(s){console.error(`Error executing method ${t}:`,s)}else console.warn(`Unknown method: ${t}`)}processJsCalls(){let e=(this.model.get("_js_calls")||[]).filter(i=>i.id>this.lastProcessedCallId);for(let i of e)this.isMapReady?this.executeMethod(i.method,i.args,i.kwargs):this.pendingCalls.push(i),this.lastProcessedCallId=i.id}processPendingCalls(){for(let t of this.pendingCalls)this.executeMethod(t.method,t.args,t.kwargs);this.pendingCalls=[]}sendEvent(t,e){let i={type:t,data:e,timestamp:Date.now()};this.eventQueue.push(i),this.model.set("_js_events",[...this.eventQueue]),this.model.save_changes()}restoreState(){let t=this.model.get("_sources")||{};for(let[l,h]of Object.entries(t))this.executeMethod("addSource",[l],h);let e=new Set(["fill","line","symbol","circle","heatmap","fill-extrusion","raster","hillshade","color-relief","background"]),i=this.model.get("_layers")||{},r=Object.entries(i).filter(([,l])=>e.has(l.type)),s=r.filter(([l,h])=>l.startsWith("basemap-")||h.type==="raster"),o=r.filter(([l,h])=>!(l.startsWith("basemap-")||h.type==="raster")),a=[...s,...o];for(let[l,h]of a)this.executeMethod("addLayer",[],h)}getMap(){return this.map}getIsMapReady(){return this.isMapReady}getModel(){return this.model}};var Bo=class extends Vo{map=null;olMethodHandlers={};layersMap=new globalThis.Map;controlsMap=new globalThis.Map;constructor(t,e){super(t,e),this.registerDefaultMethods()}registerMethod(t,e){this.olMethodHandlers[t]=e}registerDefaultMethods(){this.registerMethod("addBasemap",this.handleAddBasemap.bind(this)),this.registerMethod("addTileLayer",this.handleAddTileLayer.bind(this)),this.registerMethod("addGeoJSON",this.handleAddGeoJSON.bind(this)),this.registerMethod("addWMSLayer",this.handleAddWMSLayer.bind(this)),this.registerMethod("addImageWMSLayer",this.handleAddImageWMSLayer.bind(this)),this.registerMethod("removeLayer",this.handleRemoveLayer.bind(this)),this.registerMethod("setVisibility",this.handleSetVisibility.bind(this)),this.registerMethod("setOpacity",this.handleSetOpacity.bind(this)),this.registerMethod("addControl",this.handleAddControl.bind(this)),this.registerMethod("removeControl",this.handleRemoveControl.bind(this)),this.registerMethod("setCenter",this.handleSetCenter.bind(this)),this.registerMethod("setZoom",this.handleSetZoom.bind(this)),this.registerMethod("flyTo",this.handleFlyTo.bind(this)),this.registerMethod("fitBounds",this.handleFitBounds.bind(this)),this.registerMethod("fitExtent",this.handleFitExtent.bind(this)),this.registerMethod("addMarker",this.handleAddMarker.bind(this))}async initialize(){let t=this.model.get("center")||[0,0],e=this.model.get("zoom")||2;this.el.style.width="100%",this.el.style.display="block";let i=document.createElement("div");i.style.width=this.model.get("width")||"100%",i.style.height=this.model.get("height")||"600px",i.style.position="relative",i.style.minWidth="200px",this.el.appendChild(i),this.map=new ah({target:i,view:new Bt({center:nn(t),zoom:e}),controls:kn({attribution:!1}),interactions:jn().extend([new Ko])});let r=this.model.get("_js_calls");if(r&&r.length>0)for(let s of r)await this.executeOLMethod(s);this.model.on("change:_js_calls",()=>{this.handleJsCallsChange()}),this.model.on("change:center",()=>{let s=this.model.get("center");this.map&&this.map.getView().setCenter(nn(s))}),this.model.on("change:zoom",()=>{let s=this.model.get("zoom");this.map&&this.map.getView().setZoom(s)}),this.map.getView().on("change:center",()=>{if(this.map){let s=Wu(this.map.getView().getCenter()||[0,0]);this.model.set("center",s),this.model.save_changes()}}),this.map.getView().on("change:resolution",()=>{if(this.map){let s=this.map.getView().getZoom();this.model.set("zoom",s),this.model.save_changes()}})}handleJsCallsChange(){let t=this.model.get("_js_calls");if(t&&t.length>0){let e=t[t.length-1];this.executeOLMethod(e)}}async executeOLMethod(t){let{method:e,args:i,kwargs:r}=t,s=this.olMethodHandlers[e];if(s)try{s(i,r)}catch(o){console.error(`Error executing method ${e}:`,o)}else console.warn(`Unknown method: ${e}`)}createMap(){let t=this.model.get("center")||[0,0],e=this.model.get("zoom")||2,i=this.createMapContainer();return new ah({target:i,view:new Bt({center:nn(t),zoom:e}),controls:kn({attribution:!1}),interactions:jn().extend([new Ko])})}onCenterChange(){let t=this.model.get("center");this.map&&this.map.getView().setCenter(nn(t))}onZoomChange(){let t=this.model.get("zoom");this.map&&this.map.getView().setZoom(t)}onStyleChange(){}handleAddBasemap(t,e){if(!this.map)return;let i=t[0],r=e.name||"basemap",s=e.attribution||"",o=this.layersMap.get("basemap-"+r);o&&this.map.removeLayer(o);let a=new Po({source:new nc({url:i,attributions:s?[s]:void 0}),zIndex:0});this.map.getLayers().insertAt(0,a),this.layersMap.set("basemap-"+r,a)}handleAddTileLayer(t,e){if(!this.map)return;let i=t[0],r=e.name||`tiles-${this.layersMap.size}`,s=e.attribution||"",o=e.opacity??1,a=e.minZoom??0,l=e.maxZoom??22,h=new Po({source:new nc({url:i,attributions:s?[s]:void 0,minZoom:a,maxZoom:l}),opacity:o});this.map.addLayer(h),this.layersMap.set(r,h)}handleAddGeoJSON(t,e){if(!this.map)return;let i=e.data,r=e.name||`geojson-${this.layersMap.size}`,s=e.fitBounds!==!1,o=e.style||{},a=new vc({features:new Oc().readFeatures(i,{featureProjection:"EPSG:3857"})}),l=new Vh({source:a,style:this.createVectorStyle(o)});if(this.map.addLayer(l),this.layersMap.set(r,l),s){let h=a.getExtent();h&&h.every(c=>isFinite(c))&&this.map.getView().fit(h,{padding:[50,50,50,50],duration:500})}}createVectorStyle(t){let e=new Pe({color:t.fillColor||"rgba(51, 136, 255, 0.5)"}),i=new Ki({color:t.strokeColor||"#3388ff",width:t.strokeWidth??2}),r=new Yi({radius:t.radius??6,fill:e,stroke:i});return new Ze({fill:e,stroke:i,image:r})}handleAddWMSLayer(t,e){if(!this.map)return;let i=e.url,r=e.name||`wms-${this.layersMap.size}`,s=e.layers,o=e.format||"image/png",a=e.transparent!==!1,l=e.attribution||"",h=new Po({source:new dg({url:i,params:{LAYERS:s,FORMAT:o,TRANSPARENT:a},serverType:e.serverType||void 0,attributions:l?[l]:void 0})});this.map.addLayer(h),this.layersMap.set(r,h)}handleAddImageWMSLayer(t,e){if(!this.map)return;let i=e.url,r=e.name||`imagewms-${this.layersMap.size}`,s=e.layers,o=e.format||"image/png",a=e.transparent!==!1,l=e.attribution||"",h=new Zf({source:new fg({url:i,params:{LAYERS:s,FORMAT:o,TRANSPARENT:a},serverType:e.serverType||void 0,attributions:l?[l]:void 0})});this.map.addLayer(h),this.layersMap.set(r,h)}handleRemoveLayer(t,e){if(!this.map)return;let[i]=t,r=this.layersMap.get(i);r&&(this.map.removeLayer(r),this.layersMap.delete(i))}handleSetVisibility(t,e){let[i,r]=t,s=this.layersMap.get(i);s&&s.setVisible(r)}handleSetOpacity(t,e){let[i,r]=t,s=this.layersMap.get(i);s&&s.setOpacity(r)}handleAddControl(t,e){if(!this.map)return;let i=t[0],r=e.position||"top-right",s;switch(i){case"zoom":case"navigation":s=new br;break;case"scale":s=new Wc({units:e.units||"metric"});break;case"fullscreen":s=new Dc;break;case"attribution":s=new Ir({collapsible:e.collapsible!==!1});break;case"rotate":s=new Mr({autoHide:e.autoHide!==!1});break;case"mousePosition":s=new Gc({coordinateFormat:mu(4),projection:"EPSG:4326"});break}s&&(this.map.addControl(s),this.controlsMap.set(i,s))}handleRemoveControl(t,e){if(!this.map)return;let[i]=t,r=this.controlsMap.get(i);r&&(this.map.removeControl(r),this.controlsMap.delete(i))}handleSetCenter(t,e){if(!this.map)return;let[i,r]=t;this.map.getView().setCenter(nn([i,r]))}handleSetZoom(t,e){if(!this.map)return;let[i]=t;this.map.getView().setZoom(i)}handleFlyTo(t,e){if(!this.map)return;let[i,r]=t,s=e.zoom,o=e.duration||2e3;this.map.getView().animate({center:nn([i,r]),zoom:s,duration:o})}handleFitBounds(t,e){if(!this.map)return;let i=t[0],r=e.padding||50,s=e.duration||1e3,o=fr([i[0],i[1],i[2],i[3]],"EPSG:4326","EPSG:3857");this.map.getView().fit(o,{padding:[r,r,r,r],duration:s})}handleFitExtent(t,e){if(!this.map)return;let i=t[0],r=e.padding||50,s=e.duration||1e3;this.map.getView().fit(i,{padding:[r,r,r,r],duration:s})}handleAddMarker(t,e){if(!this.map)return;let[i,r]=t,s=e.id||e.name||`marker-${this.layersMap.size}`,o=e.popup,a=e.color||"#3388ff",l=new Oc().readFeature({type:"Feature",geometry:{type:"Point",coordinates:[i,r]},properties:{popup:o}},{featureProjection:"EPSG:3857"}),h=Array.isArray(l)?l:[l],c=new vc({features:h}),u=new Ze({image:new Yi({radius:8,fill:new Pe({color:a}),stroke:new Ki({color:"#ffffff",width:2})})}),d=new Vh({source:c,style:u});this.map.addLayer(d),this.layersMap.set(s,d)}destroy(){this.removeModelListeners(),this.map&&(this.map.setTarget(void 0),this.map=null),this.layersMap.clear(),this.controlsMap.clear()}};var ls=null;function v_({model:n,el:t}){return ls=new Bo(n,t),ls.initialize().catch(e=>{console.error("Failed to initialize OpenLayers map:",e)}),()=>{ls&&(ls.destroy(),ls=null)}}var vO={render:v_};export{vO as default,v_ as render};
|