13 lines
237 KiB
JavaScript
13 lines
237 KiB
JavaScript
import no from"./downloads.4cdbbcc5.js";import{_ as ur}from"./linesGL.99030c5a.js";import{_ as so,a as ro}from"./face.2eec3bdc.js";import"./index.e2d056fa.js";/* empty css */import{K as Yn,_ as oo,r as U,x as ao,t as lo,X as ho,v as co,M as uo,d as $t,o as et,c as rt,k as P,J as Xi,f as k,e as it,w as ot,P as vn,Q as Sn,j as ds,F as fs,l as gt,m as lt,y as Wi,B as fo,a2 as gs,p as go,q as _o}from"./index.1974707a.js";import{u as _s}from"./useEcharts.2e9d7b11.js";import{d as Pe}from"./download.b14e0d1d.js";import{e as mo}from"./element-resize-detector.d8720798.js";import{i as po,L as oi}from"./install.49294472.js";const Qe="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAXCAYAAAAP6L+eAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAP2SURBVDiNjZUxbxxVEMd/M+/tru9ufcbGNrIEggIButDRIsU1EqIyBRUSUiQ6QIpSGn8D4AOQD5CGgoYuEYiSjpOgiIgIMuAoji9n+273vRmKs8+OnShMs6vVvt/MPP3nP8L/CHcEgJ2T59NiGz99FcGf/eMp8BS2DdxCWLsA3zsBbuHsnCXQZwH9SxQQBghX0eEtIjURiOxRsEcBs29DCNxG2T7rSi4C5y0PEPZR3kX4lcAS+jATVoqzMw9bfKWD7Y6xjUDmT4xrZHYgXGp7EwF0eERY6xCBgh4lLJYdyvLIYtVOirLVouhrFaDSxdgILc4LwF/Axyd3PIduA7dR1lHuEgnEx3mxDJbLbtfitPWicUJZAQlzkexRmpxCW+t4ujuh3T8mDSDLuSuQJ6A1JU1dTqZpQRa8EvcquZd4EQAKaXOTpY2FTMx1knOYTNrxZLVPC6Qwr3YPGR4R0pi4uEAxTnVValqwYN3sXkeJPTepNVhXxRfMtRDREMgARiO21G/z7hhb/APTuZTWkEGNFEZAFmPIuZwm74h7t5RQ52xLLrak6x+8Ub311XXD+yreSxY7glfdrkXyYtgokeEyEueS+B1hGV1dRsGimpcpeKUaO5qsp8vvvFRufPieFP2tmZz0ZnZDI21KPvVIbLOHyQQdXIE5eLiMLHeQjYgcjTyEjofSPBrLvWrw+fsUL356XpqiXgb3xk0KvAhYDnVwaQqEe8ilATk4nOm0aREML9688dFF6EyfaHYUcUEvj/ocPNifjeJSD6fCy4C1QPPbjZvtP999Qjr6/sLZBGRHcqEYhpPFrcV5FX+i4o0a4xgz0ewuKao0nqWxv3+4fzz84tv04M51vP15JlGbaJAJTuuWWhfJ44yv9mcFylxuV080fJ9i5P0qTtNCqHJXsV6S2FP3LngleIyvffZ2e/frX1zk2NDDmNM4F2Hc8eKQdjQZHpPOKt7E+AnnAEs2St1emFqhx4YeWsqPs+uBqT4y1Ud275sfQ9ADMx1HSUeOTi1pSxhljvHBPh5FcHdOjceGkAdjeFg/ZqVc5GiaPZSWpMhTyV5iqItLk8WKSOutNjnrpFeFhkimxlg77xXM4TKEMIDAGuHgkCIUdVGLxcnEIgWKIqdeYa6pF0Lz0EZpZUw7hDzYIs1l8lTLfAXdzYTCCKt9AtO+js0CASHjtWqmGtmDEXl1SuIKmX8x7mCX9PeE0906S8AYpYNQow9GyGofp8F3G3yjxoZ72GANYxODC3KD2b46WS/OEOcamTGJNdrhMYl1mtXXmbJOw8szm4SZVbKJsXPCuTRRF6s/vR6YmRUnnZzG1snOO7fvnrtMn5rkOSEyg/8HfCwU8ZRvPMgAAAAASUVORK5CYII=",$e="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAXCAYAAAAP6L+eAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAQBSURBVDiNjZXPa11VEMc/M+ec+16S15TEJBJRC0WQvi79A9qN4MZlBF2ICxFcunIjtAVXroq4cuNSMItuXHXTgqV/gX1KsWIRDJg0aZKb9/LuPWfGxcvPpi3O5t7DZb5zZu58v18BcEc4jBsn3p+NaziAyOT5spAj0BsI14DVg/PiMwXWcVZwbhwXeVkBPQV6Fx1AoEcEIusk1klApEccrBK5gtJHAPHr6KluT934Oso14HsCb6BrhbDcQzdH6Hw6Ttps8flAYRvjMoV7OHMYA/x5IxJ3lLsoIwKFQJeEnIsUD0O3wBihg0+LFoIUwm4BMuuUAZT+IsZVjBunxyP+E2EAYW6KuNwl1dbrhFiSZK/EPRDRZgyVUDpJ2uFQc9HQnAu7DYXMRTL/ngUXvzOZ58YOqZt63RBKV8W6ufVuFTy1nsKkt7ZEkcZFxr4v424n7lPVDTXNKXAmwJGHyNpr6PIsYbhjSdU66jatGqeLeydoSQBeQtEg+43l/diRgGbqpkevW/van7A1IvdXcQbgDuGDj4kXZwhwrkqpdM19ulicUfWe4b2pSze/cO1s2N5vLUZMqoKbZxMXw1KcsnHT+IUpjPM4n0xmrP3LsLGP1sXDWIjZvJLoneI+LegMsfNuWnrvu+6lbz7UuXdeLcVnssapjHfUvAKLC9MoNcrD4y1SHiOakF5wwTzgKYiRongS9epofdLsSnrz0x86/a/fV+ZmKvFI5WG454GIrE0hg7mTwGcpI4hLcRR/zvf0yufp7S8/wvCmnQBt750lSeQCbn/gBHEcT4oVpIBP9vVk5OHP7ZPbt8rG7UcGVAErAT/fwYc19LeOCRIBFmbxeoTHIMUtt4i2GmTfik1Wzdv7+cn9W+0/Pz5Slz0XbaJKYy7ZVAsjbLmHnbrx4AH0p7Be0jJCMoXWgu5rsaCO2+7vX+W/bv7qSFbRsakMo+ehoWNrtLGOZgKFpckOH5AE7W/hjHDCTrGsraPjKHlopnUIum2Pv/3FVJ+a6tPium257Bq6Z0lH0zNhnG0ns41xDz8gyIFW3CEyIjBFYjxbDce5G4J1JVnVZlIVXN3FUcyDNN5KY4020zNhvNnstvM17QBKH8qhIE0o7ehgldiHsNkjzets3CulUrF4qBUYTot1u5pr11zauj0/Q3skRCdAD1VuIptXUJZQHhA2OsSFWQLjWa3NAgGh4D3VQmfHNnYorVKWA4W/sRdJ56GDCHfRwTraX0TXanS5QqiQjR1kYRanxhjh9LAjwJWjn3XGTQ4dBK5ifShA3hqReZ2WJZqFtxizRDMYkVmkpSbz2UHrHM/0WYIInDDTQ4uCY+8DWDlIPOF3J9t+Xhwlv8i7ziT8D4cG+A+S3jQF4r/VqQAAAABJRU5ErkJggg==",dr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAANZSURBVDiNtZW9biRFEIC/qu6Z3dldn+VDRrJDAoIBEUB00fklSAn9DkSWH4EECTKIEJfBA2AkEgLIbpFOSBdYYOmMMMeNd3ZmuqsIdr2396NDQlxJJZVara+q668FwB3hRk637OflBL8xRZ7aL5O4gZ4inAA1wv767AHC22vA5RboFNxf7SA+Az1D56B1i1Ah7CFcrm/OMOY4P+DU2L850A30cwItYa8iUlHQUrLPaKMw4hHlxSEFM+L8HpEaAYRT5Jl0AuKOcobSEghElIjsRLKHxdLipIJFCx7FXCRna9KQSYOSD94i8QjjCON0VYObyMW/Jswh1BWRGWXTz8qQc6nmZS8eS11HImR3SeOgfZN0mFXNQM9AJnGOcUzehot/RwTiny1lyWwUQh6nZJXiozLGEvewTmLuLQ2xkOXIZYmE7vHyut8t6MkkKjJHGKzAkQfIxSE6EYJmKzTaeBysShKn2W0k5gUR3CVpCJ1mKfohBRNkt5g52thFj19d4vU9nPmqoDrfQw5KZHe8o5OJRTEvk8VK3SfmvjN675OPR4cfvetmu5rslmBTKeJE1MdtziWyEw9maD3balMg1u/AH7+i47GHYiBq6UUhXmZ8HEUrpDxi785Rtfv+9+nq52/yb1/eD+opmfchek/2nh6lQTnHONnuY2AGdNEVQ5MQ3bwQ8fJpY47uxjfu3I17H5xZ88tX5fmnP1pyvXbXafnitOrLpub/kE3EDVAkMUosOimrDIL0m5vWbaVCn/RJcohiU8QYXhzrOL8P9S5GkIyS+ixDMulVWSY3Lb0/46+fvm3Pv3ioLssQpHWkiyq9ZRkoJVNigLGPr3sZ8c8oLg4pJsKoyJMqVHmqZpMkcSruz7QbRh9UWx/SwkQX4xhbtOkulgxXLamGzBzn5DUOiHKJzy+x25k0q5ohE7oouoiu18uUn5jb45XmxwH9e2ShaYbYEq67DfR8a1+s5T8toazkLpNetYSUU+AI4xwjky6WDIQnHblZTm4tFhSLxeTWYjGV68WsatqF092G7qolcX/9/OegK/DJupLHZCryVUuiZaCi55Juo9DxJv3B7ww0pPpDEnMc1sV6YdGz8nYTec3KAZC4IrHPwP4KRk3ieF35LeDLvieB1/OZ/gOh5x9VRnDXPwAAAABJRU5ErkJggg==",xo="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB0AAAAeCAYAAADQBxWhAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAJBSURBVEiJ7ZfPa9NgHMaf933j27jazTqRLq02tc0q6E4DZYfCEPwFuwzmwYPiQTz4H3gQ/wBRPHhxetB58CKIbKcNRKig11EGdutoHW6dP7aqXS2NTeKhjQSNW96tKyg+EEieNzyf9/3mG/KGwFY8kmCGmbJA+gD40TpVCKyMwWga8+9yAEAAgB0Ij1gUJ1oIchUxMWUsLD5hiEcSBDi/3cAGFXGru+sNZYaZaguwKWaYKdp8hm2TBdInQbBpYpMPhrimKr/62djgqMcIPxUBhm5c7eeaquhzhSXnYU/Ga47kZgYvDEfBdzAA4L2xoO13jZzqBwD9/cqa836uqeCaqoQf3RysFz+UAUCfzZcAAPp3ozT29K3zfkLV8F2n4TucCKgT9895nbUXFYYuPa7N5Mr29W8rrc3kyl/Gnr1GB5d2HR9Isj27A/pso4RsbzCwXrjxqVQGAN6rKsbq5/La81dZfNPrTiDgslKn7KYRaBIAQDL/4rI+V1jKn7w44TYu1EitkjC05/a1o9Hx0dMAQHycRsfvnem5c/2YSIZr964nfujgPjkZU6RISKYdMpOPaPupfycXyfg7yvsf+u9BrWpVBwDKGCFNz6w0PK8SfmUWhq9MSqFuX315pQYA8wNnH9aXP9ZEMjZVXhvYOBcDbhq6VXkqr8gHesvQ6nS2yDVVcduebKTqdLb4pzFC1fAttHZzvZEqlMDKtBEIAitDDUbT7YQajKYZSl9XaWenDIL4dgOJiSmrsPiS/HTa+AP1A194w/sdsoQRAAAAAElFTkSuQmCC";function ms(n){return Yn({url:"equipment/contractors",method:"get",params:n})}function ve(n){return Yn({url:"equipment/districtsBlocks",method:"get",params:n})}function Cn(n){return Yn({url:"equipment/cityAndCount",method:"get",params:n})}const ht={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4};function tt(){throw new Error("Unimplemented abstract method.")}let yo=0;function nt(n){return n.ol_uid||(n.ol_uid=String(++yo))}function Ki(n,t){return Array.isArray(n)?n:(t===void 0?t=[n,n]:(t[0]=n,t[1]=n),t)}class zn{constructor(t){this.opacity_=t.opacity,this.rotateWithView_=t.rotateWithView,this.rotation_=t.rotation,this.scale_=t.scale,this.scaleArray_=Ki(t.scale),this.displacement_=t.displacement,this.declutterMode_=t.declutterMode}clone(){const t=this.getScale();return new zn({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 tt()}getImage(t){return tt()}getHitDetectionImage(){return tt()}getPixelRatio(t){return 1}getImageState(){return tt()}getImageSize(){return tt()}getOrigin(){return tt()}getSize(){return tt()}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_=Ki(t)}listenImageChange(t){tt()}load(){tt()}unlistenImageChange(t){tt()}}const fr=zn,vo={1:"The view center is not defined",2:"The view resolution is not defined",3:"The view rotation is not defined",4:"`image` and `src` cannot be provided at the same time",5:"`imgSize` must be set when `image` is provided",7:"`format` must be set when `url` is set",8:"Unknown `serverType` configured",9:"`url` must be configured or set using `#setUrl()`",10:"The default `geometryFunction` can only handle `Point` geometries",11:"`options.featureTypes` must be an Array",12:"`options.geometryName` must also be provided when `options.bbox` is set",13:"Invalid corner",14:"Invalid color",15:"Tried to get a value for a key that does not exist in the cache",16:"Tried to set a value for a key that is used already",17:"`resolutions` must be sorted in descending order",18:"Either `origin` or `origins` must be configured, never both",19:"Number of `tileSizes` and `resolutions` must be equal",20:"Number of `origins` and `resolutions` must be equal",22:"Either `tileSize` or `tileSizes` must be configured, never both",24:"Invalid extent or geometry provided as `geometry`",25:"Cannot fit empty extent provided as `geometry`",26:"Features must have an id set",27:"Features must have an id set",28:'`renderMode` must be `"hybrid"` or `"vector"`',30:"The passed `feature` was already added to the source",31:"Tried to enqueue an `element` that was already added to the queue",32:"Transformation matrix cannot be inverted",33:"Invalid units",34:"Invalid geometry layout",36:"Unknown SRS type",37:"Unknown geometry type found",38:"`styleMapValue` has an unknown type",39:"Unknown geometry type",40:"Expected `feature` to have a geometry",41:"Expected an `ol/style/Style` or an array of `ol/style/Style.js`",42:"Question unknown, the answer is 42",43:"Expected `layers` to be an array or a `Collection`",47:"Expected `controls` to be an array or an `ol/Collection`",48:"Expected `interactions` to be an array or an `ol/Collection`",49:"Expected `overlays` to be an array or an `ol/Collection`",50:"`options.featureTypes` should be an Array",51:"Either `url` or `tileJSON` options must be provided",52:"Unknown `serverType` configured",53:"Unknown `tierSizeCalculation` configured",55:"The {-y} placeholder requires a tile grid with extent",56:"mapBrowserEvent must originate from a pointer event",57:"At least 2 conditions are required",59:"Invalid command found in the PBF",60:"Missing or invalid `size`",61:"Cannot determine IIIF Image API version from provided image information JSON",62:"A `WebGLArrayBuffer` must either be of type `ELEMENT_ARRAY_BUFFER` or `ARRAY_BUFFER`",64:"Layer opacity must be a number",66:"`forEachFeatureAtCoordinate` cannot be used on a WebGL layer if the hit detection logic has not been enabled. This is done by providing adequate shaders using the `hitVertexShader` and `hitFragmentShader` properties of `WebGLPointsLayerRenderer`",67:"A layer can only be added to the map once. Use either `layer.setMap()` or `map.addLayer()`, not both",68:"A VectorTile source can only be rendered if it has a projection compatible with the view projection",69:"`width` or `height` cannot be provided together with `scale`"};class So extends Error{constructor(t){const e=vo[t];super(e),this.code=t,this.name="AssertionError",this.message=e}}const gr=So;function ft(n,t){if(!n)throw new gr(t)}function yt(n,t,e){return Math.min(Math.max(n,t),e)}function Co(n,t,e,i,s,r){const o=s-e,a=r-i;if(o!==0||a!==0){const l=((n-e)*o+(t-i)*a)/(o*o+a*a);l>1?(e=s,i=r):l>0&&(e+=o*l,i+=a*l)}return je(n,t,e,i)}function je(n,t,e,i){const s=e-n,r=i-t;return s*s+r*r}function Me(n){return n*Math.PI/180}function ps(n,t){const e=n%t;return e*t<0?e+t:e}function wt(n,t,e){return n+e*(t-n)}function Eo(n,t){const e=Math.pow(10,t);return Math.round(n*e)/e}const Ro=/^#([a-f0-9]{3}|[a-f0-9]{4}(?:[a-f0-9]{2}){0,2})$/i,wo=/^([a-z]*)$|^hsla?\(.*\)$/i;function _r(n){return typeof n=="string"?n:mr(n)}function Io(n){const t=document.createElement("div");if(t.style.color=n,t.style.color!==""){document.body.appendChild(t);const e=getComputedStyle(t).color;return document.body.removeChild(t),e}return""}const Mo=function(){const t={};let e=0;return function(i){let s;if(t.hasOwnProperty(i))s=t[i];else{if(e>=1024){let r=0;for(const o in t)(r++&3)===0&&(delete t[o],--e)}s=Ao(i),t[i]=s,++e}return s}}();function Ji(n){return Array.isArray(n)?n:Mo(n)}function Ao(n){let t,e,i,s,r;if(wo.exec(n)&&(n=Io(n)),Ro.exec(n)){const o=n.length-1;let a;o<=4?a=1:a=2;const l=o===4||o===8;t=parseInt(n.substr(1+0*a,a),16),e=parseInt(n.substr(1+1*a,a),16),i=parseInt(n.substr(1+2*a,a),16),l?s=parseInt(n.substr(1+3*a,a),16):s=255,a==1&&(t=(t<<4)+t,e=(e<<4)+e,i=(i<<4)+i,l&&(s=(s<<4)+s)),r=[t,e,i,s/255]}else n.startsWith("rgba(")?(r=n.slice(5,-1).split(",").map(Number),xs(r)):n.startsWith("rgb(")?(r=n.slice(4,-1).split(",").map(Number),r.push(1),xs(r)):ft(!1,14);return r}function xs(n){return n[0]=yt(n[0]+.5|0,0,255),n[1]=yt(n[1]+.5|0,0,255),n[2]=yt(n[2]+.5|0,0,255),n[3]=yt(n[3],0,1),n}function mr(n){let t=n[0];t!=(t|0)&&(t=t+.5|0);let e=n[1];e!=(e|0)&&(e=e+.5|0);let i=n[2];i!=(i|0)&&(i=i+.5|0);const s=n[3]===void 0?1:Math.round(n[3]*100)/100;return"rgba("+t+","+e+","+i+","+s+")"}function Pt(n){return Array.isArray(n)?mr(n):n}const ce=typeof navigator<"u"&&typeof navigator.userAgent<"u"?navigator.userAgent.toLowerCase():"";ce.includes("firefox");const Lo=ce.includes("safari")&&!ce.includes("chrom");Lo&&(ce.includes("version/15.4")||/cpu (os|iphone os) 15_4 like mac os x/.test(ce));ce.includes("webkit")&&ce.includes("edge");ce.includes("macintosh");const Vn=typeof WorkerGlobalScope<"u"&&typeof OffscreenCanvas<"u"&&self instanceof WorkerGlobalScope,bo=typeof Image<"u"&&Image.prototype.decode;(function(){let n=!1;try{const t=Object.defineProperty({},"passive",{get:function(){n=!0}});window.addEventListener("_",null,t),window.removeEventListener("_",null,t)}catch{}return n})();function kt(n,t,e,i){let s;return e&&e.length?s=e.shift():Vn?s=new OffscreenCanvas(n||300,t||300):s=document.createElement("canvas"),n&&(s.width=n),t&&(s.height=t),s.getContext("2d",i)}function To(n){const t=n.canvas;t.width=1,t.height=1,n.clearRect(0,0,1,1)}class Do{constructor(t){this.propagationStopped,this.defaultPrevented,this.type=t,this.target=null}preventDefault(){this.defaultPrevented=!0}stopPropagation(){this.propagationStopped=!0}}const ti=Do,pr={PROPERTYCHANGE:"propertychange"};class ko{constructor(){this.disposed=!1}dispose(){this.disposed||(this.disposed=!0,this.disposeInternal())}disposeInternal(){}}const Fo=ko;function Oo(n,t,e){let i,s;e=e||gi;let r=0,o=n.length,a=!1;for(;r<o;)i=r+(o-r>>1),s=+e(n[i],t),s<0?r=i+1:(o=i,a=!s);return a?r:~r}function gi(n,t){return n>t?1:n<t?-1:0}function xr(n,t,e){if(n[0]<=t)return 0;const i=n.length;if(t<=n[i-1])return i-1;if(typeof e=="function"){for(let s=1;s<i;++s){const r=n[s];if(r===t)return s;if(r<t)return e(t,n[s-1],r)>0?s-1:s}return i-1}if(e>0){for(let s=1;s<i;++s)if(n[s]<t)return s-1;return i-1}if(e<0){for(let s=1;s<i;++s)if(n[s]<=t)return s;return i-1}for(let s=1;s<i;++s){if(n[s]==t)return s;if(n[s]<t)return n[s-1]-t<t-n[s]?s-1:s}return i-1}function Po(n,t,e){for(;t<e;){const i=n[t];n[t]=n[e],n[e]=i,++t,--e}}function Zn(n,t){const e=Array.isArray(t)?t:[t],i=e.length;for(let s=0;s<i;s++)n[n.length]=e[s]}function be(n,t){const e=n.length;if(e!==t.length)return!1;for(let i=0;i<e;i++)if(n[i]!==t[i])return!1;return!0}function yr(){return!0}function _i(){}function Go(n){let t=!1,e,i,s;return function(){const r=Array.prototype.slice.call(arguments);return(!t||this!==s||!be(r,i))&&(t=!0,s=this,i=r,e=n.apply(this,arguments)),e}}function jn(n){for(const t in n)delete n[t]}function mi(n){let t;for(t in n)return!1;return!t}class Bo extends Fo{constructor(t){super(),this.eventTarget_=t,this.pendingRemovals_=null,this.dispatching_=null,this.listeners_=null}addEventListener(t,e){if(!t||!e)return;const i=this.listeners_||(this.listeners_={}),s=i[t]||(i[t]=[]);s.includes(e)||s.push(e)}dispatchEvent(t){const e=typeof t=="string",i=e?t:t.type,s=this.listeners_&&this.listeners_[i];if(!s)return;const r=e?new ti(t):t;r.target||(r.target=this.eventTarget_||this);const o=this.dispatching_||(this.dispatching_={}),a=this.pendingRemovals_||(this.pendingRemovals_={});i in o||(o[i]=0,a[i]=0),++o[i];let l;for(let h=0,c=s.length;h<c;++h)if("handleEvent"in s[h]?l=s[h].handleEvent(r):l=s[h].call(this,r),l===!1||r.propagationStopped){l=!1;break}if(--o[i]===0){let h=a[i];for(delete a[i];h--;)this.removeEventListener(i,_i);delete o[i]}return l}disposeInternal(){this.listeners_&&jn(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){const i=this.listeners_&&this.listeners_[t];if(i){const s=i.indexOf(e);s!==-1&&(this.pendingRemovals_&&t in this.pendingRemovals_?(i[s]=_i,++this.pendingRemovals_[t]):(i.splice(s,1),i.length===0&&delete this.listeners_[t]))}}}const vr=Bo,vt={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"};function zt(n,t,e,i,s){if(i&&i!==n&&(e=e.bind(i)),s){const o=e;e=function(){n.removeEventListener(t,e),o.apply(this,arguments)}}const r={target:n,type:t,listener:e};return n.addEventListener(t,e),r}function Qi(n,t,e,i){return zt(n,t,e,i,!0)}function Vt(n){n&&n.target&&(n.target.removeEventListener(n.type,n.listener),jn(n))}class hn extends vr{constructor(){super(),this.on=this.onInternal,this.once=this.onceInternal,this.un=this.unInternal,this.revision_=0}changed(){++this.revision_,this.dispatchEvent(vt.CHANGE)}getRevision(){return this.revision_}onInternal(t,e){if(Array.isArray(t)){const i=t.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=zt(this,t[r],e);return s}return zt(this,t,e)}onceInternal(t,e){let i;if(Array.isArray(t)){const s=t.length;i=new Array(s);for(let r=0;r<s;++r)i[r]=Qi(this,t[r],e)}else i=Qi(this,t,e);return e.ol_key=i,i}unInternal(t,e){const i=e.ol_key;if(i)No(i);else if(Array.isArray(t))for(let s=0,r=t.length;s<r;++s)this.removeEventListener(t[s],e);else this.removeEventListener(t,e)}}hn.prototype.on;hn.prototype.once;hn.prototype.un;function No(n){if(Array.isArray(n))for(let t=0,e=n.length;t<e;++t)Vt(n[t]);else Vt(n)}const Sr=hn;class ys extends ti{constructor(t,e,i){super(t),this.key=e,this.oldValue=i}}class Xo extends Sr{constructor(t){super(),this.on,this.once,this.un,nt(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_)||{}}hasProperties(){return!!this.values_}notify(t,e){let i;i=`change:${t}`,this.hasListener(i)&&this.dispatchEvent(new ys(i,t,e)),i=pr.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){const s=this.values_||(this.values_={});if(i)s[t]=e;else{const r=s[t];s[t]=e,r!==e&&this.notify(t,r)}}setProperties(t,e){for(const i in t)this.set(i,t[i],e)}applyProperties(t){!t.values_||Object.assign(this.values_||(this.values_={}),t.values_)}unset(t,e){if(this.values_&&t in this.values_){const i=this.values_[t];delete this.values_[t],mi(this.values_)&&(this.values_=null),e||this.notify(t,i)}}}const ue=Xo,Wo=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-z]+?)\\s*$`].join(""),"i"),vs=["style","variant","weight","size","lineHeight","family"],Cr=function(n){const t=n.match(Wo);if(!t)return null;const e={lineHeight:"normal",size:"1.2em",style:"normal",weight:"normal",variant:"normal"};for(let i=0,s=vs.length;i<s;++i){const r=t[i+1];r!==void 0&&(e[vs[i]]=r)}return e.families=e.family.split(/,\s?/),e},Er="10px sans-serif",Zt="#000",$i="round",pi=[],xi=0,qe="round",yi=10,vi="#000",Si="center",tn="middle",Ee=[0,0,0,0],Ci=1,te=new ue;let Xe=null,kn;const Fn={},Yo=function(){const t="32px ",e=["monospace","serif"],i=e.length,s="wmytzilWMYTZIL@#/&?$%10\uF013";let r,o;function a(h,c,u){let d=!0;for(let f=0;f<i;++f){const g=e[f];if(o=en(h+" "+c+" "+t+g,s),u!=g){const _=en(h+" "+c+" "+t+u+","+g,s);d=d&&_!=o}}return!!d}function l(){let h=!0;const c=te.getKeys();for(let u=0,d=c.length;u<d;++u){const f=c[u];te.get(f)<100&&(a.apply(this,f.split(`
|
|
`))?(jn(Fn),Xe=null,kn=void 0,te.set(f,100)):(te.set(f,te.get(f)+1,!0),h=!1))}h&&(clearInterval(r),r=void 0)}return function(h){const c=Cr(h);if(!c)return;const u=c.families;for(let d=0,f=u.length;d<f;++d){const g=u[d],_=c.style+`
|
|
`+c.weight+`
|
|
`+g;te.get(_)===void 0&&(te.set(_,100,!0),a(c.style,c.weight,g)||(te.set(_,0,!0),r===void 0&&(r=setInterval(l,32))))}}}(),zo=function(){let n;return function(t){let e=Fn[t];if(e==null){if(Vn){const i=Cr(t),s=Rr(t,"\u017Dg");e=(isNaN(Number(i.lineHeight))?1.2:Number(i.lineHeight))*(s.actualBoundingBoxAscent+s.actualBoundingBoxDescent)}else n||(n=document.createElement("div"),n.innerHTML="M",n.style.minHeight="0",n.style.maxHeight="none",n.style.height="auto",n.style.padding="0",n.style.border="none",n.style.position="absolute",n.style.display="block",n.style.left="-99999px"),n.style.font=t,document.body.appendChild(n),e=n.offsetHeight,document.body.removeChild(n);Fn[t]=e}return e}}();function Rr(n,t){return Xe||(Xe=kt(1,1)),n!=kn&&(Xe.font=n,kn=Xe.font),Xe.measureText(t)}function en(n,t){return Rr(n,t).width}function Ss(n,t,e){if(t in e)return e[t];const i=t.split(`
|
|
`).reduce((s,r)=>Math.max(s,en(n,r)),0);return e[t]=i,i}function Vo(n,t){const e=[],i=[],s=[];let r=0,o=0,a=0,l=0;for(let h=0,c=t.length;h<=c;h+=2){const u=t[h];if(u===`
|
|
`||h===c){r=Math.max(r,o),s.push(o),o=0,a+=l;continue}const d=t[h+1]||n.font,f=en(d,u);e.push(f),o+=f;const g=zo(d);i.push(g),l=Math.max(l,g)}return{width:r,height:a,widths:e,heights:i,lineWidths:s}}function Zo(n,t,e,i,s,r,o,a,l,h,c){n.save(),e!==1&&(n.globalAlpha*=e),t&&n.setTransform.apply(n,t),i.contextInstructions?(n.translate(l,h),n.scale(c[0],c[1]),jo(i,n)):c[0]<0||c[1]<0?(n.translate(l,h),n.scale(c[0],c[1]),n.drawImage(i,s,r,o,a,0,0,o,a)):n.drawImage(i,s,r,o,a,l,h,o*c[0],a*c[1]),n.restore()}function jo(n,t){const e=n.contextInstructions;for(let i=0,s=e.length;i<s;i+=2)Array.isArray(e[i+1])?t[e[i]].apply(t,e[i+1]):t[e[i]]=e[i+1]}class Un extends fr{constructor(t){const e=t.rotateWithView!==void 0?t.rotateWithView:!1;super({opacity:1,rotateWithView:e,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.canvas_=void 0,this.hitDetectionCanvas_=null,this.fill_=t.fill!==void 0?t.fill:null,this.origin_=[0,0],this.points_=t.points,this.radius_=t.radius!==void 0?t.radius:t.radius1,this.radius2_=t.radius2,this.angle_=t.angle!==void 0?t.angle:0,this.stroke_=t.stroke!==void 0?t.stroke:null,this.size_=null,this.renderOptions_=null,this.render()}clone(){const t=this.getScale(),e=new Un({fill:this.getFill()?this.getFill().clone():void 0,points:this.getPoints(),radius:this.getRadius(),radius2:this.getRadius2(),angle:this.getAngle(),stroke:this.getStroke()?this.getStroke().clone():void 0,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),scale:Array.isArray(t)?t.slice():t,displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}getAnchor(){const t=this.size_;if(!t)return null;const 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.createHitDetectionCanvas_(this.renderOptions_),this.hitDetectionCanvas_}getImage(t){let e=this.canvas_[t];if(!e){const i=this.renderOptions_,s=kt(i.size*t,i.size*t);this.draw_(i,s,t),e=s.canvas,this.canvas_[t]=e}return e}getPixelRatio(t){return t}getImageSize(){return this.size_}getImageState(){return ht.LOADED}getOrigin(){return this.origin_}getPoints(){return this.points_}getRadius(){return this.radius_}getRadius2(){return this.radius2_}getSize(){return this.size_}getStroke(){return this.stroke_}setStroke(t){this.stroke_=t,this.render()}listenImageChange(t){}load(){}unlistenImageChange(t){}calculateLineJoinSize_(t,e,i){if(e===0||this.points_===1/0||t!=="bevel"&&t!=="miter")return e;let s=this.radius_,r=this.radius2_===void 0?s:this.radius2_;if(s<r){const N=s;s=r,r=N}const o=this.radius2_===void 0?this.points_:this.points_*2,a=2*Math.PI/o,l=r*Math.sin(a),h=Math.sqrt(r*r-l*l),c=s-h,u=Math.sqrt(l*l+c*c),d=u/l;if(t==="miter"&&d<=i)return d*e;const f=e/2/d,g=e/2*(c/u),p=Math.sqrt((s+f)*(s+f)+g*g)-s;if(this.radius2_===void 0||t==="bevel")return p*2;const x=s*Math.sin(a),S=Math.sqrt(s*s-x*x),I=r-S,T=Math.sqrt(x*x+I*I)/x;if(T<=i){const N=T*e/2-r-s;return 2*Math.max(p,N)}return p*2}createRenderOptions(){let t=qe,e=0,i=null,s=0,r,o=0;this.stroke_&&(r=this.stroke_.getColor(),r===null&&(r=vi),r=Pt(r),o=this.stroke_.getWidth(),o===void 0&&(o=Ci),i=this.stroke_.getLineDash(),s=this.stroke_.getLineDashOffset(),t=this.stroke_.getLineJoin(),t===void 0&&(t=qe),e=this.stroke_.getMiterLimit(),e===void 0&&(e=yi));const a=this.calculateLineJoinSize_(t,o,e),l=Math.max(this.radius_,this.radius2_||0),h=Math.ceil(2*l+a);return{strokeStyle:r,strokeWidth:o,size:h,lineDash:i,lineDashOffset:s,lineJoin:t,miterLimit:e}}render(){this.renderOptions_=this.createRenderOptions();const t=this.renderOptions_.size;this.canvas_={},this.size_=[t,t]}draw_(t,e,i){if(e.scale(i,i),e.translate(t.size/2,t.size/2),this.createPath_(e),this.fill_){let s=this.fill_.getColor();s===null&&(s=Zt),e.fillStyle=Pt(s),e.fill()}this.stroke_&&(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())}createHitDetectionCanvas_(t){if(this.fill_){let e=this.fill_.getColor(),i=0;if(typeof e=="string"&&(e=Ji(e)),e===null?i=1:Array.isArray(e)&&(i=e.length===4?e[3]:1),i===0){const s=kt(t.size,t.size);this.hitDetectionCanvas_=s.canvas,this.drawHitDetectionCanvas_(t,s)}}this.hitDetectionCanvas_||(this.hitDetectionCanvas_=this.getImage(1))}createPath_(t){let e=this.points_;const i=this.radius_;if(e===1/0)t.arc(0,0,i,0,2*Math.PI);else{const s=this.radius2_===void 0?i:this.radius2_;this.radius2_!==void 0&&(e*=2);const r=this.angle_-Math.PI/2,o=2*Math.PI/e;for(let a=0;a<e;a++){const l=r+a*o,h=a%2===0?i:s;t.lineTo(h*Math.cos(l),h*Math.sin(l))}t.closePath()}}drawHitDetectionCanvas_(t,e){e.translate(t.size/2,t.size/2),this.createPath_(e),e.fillStyle=Zt,e.fill(),this.stroke_&&(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())}}const nn=Un;class Hn extends nn{constructor(t){t=t||{radius:5},super({points:1/0,fill:t.fill,radius:t.radius,stroke:t.stroke,scale:t.scale!==void 0?t.scale:1,rotation:t.rotation!==void 0?t.rotation:0,rotateWithView:t.rotateWithView!==void 0?t.rotateWithView:!1,displacement:t.displacement!==void 0?t.displacement:[0,0],declutterMode:t.declutterMode})}clone(){const t=this.getScale(),e=new Hn({fill:this.getFill()?this.getFill().clone():void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,radius:this.getRadius(),scale:Array.isArray(t)?t.slice():t,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}setRadius(t){this.radius_=t,this.render()}}const Ei=Hn;class qn{constructor(t){t=t||{},this.color_=t.color!==void 0?t.color:null}clone(){const t=this.getColor();return new qn({color:Array.isArray(t)?t.slice():t||void 0})}getColor(){return this.color_}setColor(t){this.color_=t}}const mt=qn;class Uo{constructor(){this.cache_={},this.cacheSize_=0,this.maxCacheSize_=32}clear(){this.cache_={},this.cacheSize_=0}canExpireCache(){return this.cacheSize_>this.maxCacheSize_}expire(){if(this.canExpireCache()){let t=0;for(const e in this.cache_){const i=this.cache_[e];(t++&3)===0&&!i.hasListener()&&(delete this.cache_[e],--this.cacheSize_)}}}get(t,e,i){const s=Cs(t,e,i);return s in this.cache_?this.cache_[s]:null}set(t,e,i,s){const r=Cs(t,e,i);this.cache_[r]=s,++this.cacheSize_}setSize(t){this.maxCacheSize_=t,this.expire()}}function Cs(n,t,e){const i=e?_r(e):"null";return t+":"+n+":"+i}const Es=new Uo,pt={UNKNOWN:0,INTERSECTING:1,ABOVE:2,RIGHT:4,BELOW:8,LEFT:16};function Nt(n){const t=Le();for(let e=0,i=n.length;e<i;++e)Ar(t,n[e]);return t}function cn(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 Ho(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n.slice()}function Kn(n,t,e){let i,s;return t<n[0]?i=n[0]-t:n[2]<t?i=t-n[2]:i=0,e<n[1]?s=n[1]-e:n[3]<e?s=e-n[3]:s=0,i*i+s*s}function qo(n,t){return wr(n,t[0],t[1])}function ze(n,t){return n[0]<=t[0]&&t[2]<=n[2]&&n[1]<=t[1]&&t[3]<=n[3]}function wr(n,t,e){return n[0]<=t&&t<=n[2]&&n[1]<=e&&e<=n[3]}function On(n,t){const e=n[0],i=n[1],s=n[2],r=n[3],o=t[0],a=t[1];let l=pt.UNKNOWN;return o<e?l=l|pt.LEFT:o>s&&(l=l|pt.RIGHT),a<i?l=l|pt.BELOW:a>r&&(l=l|pt.ABOVE),l===pt.UNKNOWN&&(l=pt.INTERSECTING),l}function Le(){return[1/0,1/0,-1/0,-1/0]}function Ke(n,t,e,i,s){return s?(s[0]=n,s[1]=t,s[2]=e,s[3]=i,s):[n,t,e,i]}function Ir(n){return Ke(1/0,1/0,-1/0,-1/0,n)}function qi(n,t){const e=n[0],i=n[1];return Ke(e,i,e,i,t)}function Ko(n,t,e,i,s){const r=Ir(s);return Lr(r,n,t,e,i)}function Mr(n,t){return n[0]==t[0]&&n[2]==t[2]&&n[1]==t[1]&&n[3]==t[3]}function Ar(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 Lr(n,t,e,i,s){for(;e<i;e+=s)Jo(n,t[e],t[e+1]);return n}function Jo(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 Qo(n,t){let e;return e=t(br(n)),e||(e=t(Tr(n)),e)||(e=t(kr(n)),e)||(e=t(Dr(n)),e)?e:!1}function br(n){return[n[0],n[1]]}function Tr(n){return[n[2],n[1]]}function Ri(n){return[(n[0]+n[2])/2,(n[1]+n[3])/2]}function $o(n,t,e,i,s){const[r,o,a,l,h,c,u,d]=ta(n,t,e,i);return Ke(Math.min(r,a,h,u),Math.min(o,l,c,d),Math.max(r,a,h,u),Math.max(o,l,c,d),s)}function ta(n,t,e,i){const s=t*i[0]/2,r=t*i[1]/2,o=Math.cos(e),a=Math.sin(e),l=s*o,h=s*a,c=r*o,u=r*a,d=n[0],f=n[1];return[d-l+u,f-h-c,d-l-u,f-h+c,d+l-u,f+h+c,d+l+u,f+h-c,d-l+u,f-h-c]}function wi(n){return n[3]-n[1]}function Dr(n){return[n[0],n[3]]}function kr(n){return[n[2],n[3]]}function At(n){return n[2]-n[0]}function Dt(n,t){return n[0]<=t[2]&&n[2]>=t[0]&&n[1]<=t[3]&&n[3]>=t[1]}function ea(n){return n[2]<n[0]||n[3]<n[1]}function ia(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n}function na(n,t,e){let i=!1;const s=On(n,t),r=On(n,e);if(s===pt.INTERSECTING||r===pt.INTERSECTING)i=!0;else{const o=n[0],a=n[1],l=n[2],h=n[3],c=t[0],u=t[1],d=e[0],f=e[1],g=(f-u)/(d-c);let _,p;!!(r&pt.ABOVE)&&!(s&pt.ABOVE)&&(_=d-(f-h)/g,i=_>=o&&_<=l),!i&&!!(r&pt.RIGHT)&&!(s&pt.RIGHT)&&(p=f-(d-l)*g,i=p>=a&&p<=h),!i&&!!(r&pt.BELOW)&&!(s&pt.BELOW)&&(_=d-(f-a)/g,i=_>=o&&_<=l),!i&&!!(r&pt.LEFT)&&!(s&pt.LEFT)&&(p=f-(d-o)*g,i=p>=a&&p<=h)}return i}function Fr(n,t){const e=t.getExtent(),i=Ri(n);if(t.canWrapX()&&(i[0]<e[0]||i[0]>=e[2])){const s=At(e),o=Math.floor((i[0]-e[0])/s)*s;n[0]-=o,n[2]-=o}return n}function sa(n,t){if(t.canWrapX()){const e=t.getExtent();if(!isFinite(n[0])||!isFinite(n[2]))return[[e[0],n[1],e[2],n[3]]];Fr(n,t);const i=At(e);if(At(n)>i)return[[e[0],n[1],e[2],n[3]]];if(n[0]<e[0])return[[n[0]+i,n[1],e[2],n[3]],[e[0],n[1],n[2],n[3]]];if(n[2]>e[2])return[[n[0],n[1],e[2],n[3]],[e[0],n[1],n[2]-i,n[3]]]}return[n]}function ra(n,t,e){const i=n;let s=!0,r=!1,o=!1;const a=[Qi(i,vt.LOAD,function(){o=!0,r||t()})];return i.src&&bo?(r=!0,i.decode().then(function(){s&&t()}).catch(function(l){s&&(o?t():e())})):a.push(Qi(i,vt.ERROR,e)),function(){s=!1,a.forEach(Vt)}}let ai=null;class oa extends vr{constructor(t,e,i,s,r,o){super(),this.hitDetectionImage_=null,this.image_=t,this.crossOrigin_=s,this.canvas_={},this.color_=o,this.unlisten_=null,this.imageState_=r,this.size_=i,this.src_=e,this.tainted_}initializeImage_(){this.image_=new Image,this.crossOrigin_!==null&&(this.image_.crossOrigin=this.crossOrigin_)}isTainted_(){if(this.tainted_===void 0&&this.imageState_===ht.LOADED){ai||(ai=kt(1,1,void 0,{willReadFrequently:!0})),ai.drawImage(this.image_,0,0);try{ai.getImageData(0,0,1,1),this.tainted_=!1}catch{ai=null,this.tainted_=!0}}return this.tainted_===!0}dispatchChangeEvent_(){this.dispatchEvent(vt.CHANGE)}handleImageError_(){this.imageState_=ht.ERROR,this.unlistenImage_(),this.dispatchChangeEvent_()}handleImageLoad_(){this.imageState_=ht.LOADED,this.size_?(this.image_.width=this.size_[0],this.image_.height=this.size_[1]):this.size_=[this.image_.width,this.image_.height],this.unlistenImage_(),this.dispatchChangeEvent_()}getImage(t){return this.image_||this.initializeImage_(),this.replaceColor_(t),this.canvas_[t]?this.canvas_[t]:this.image_}getPixelRatio(t){return this.replaceColor_(t),this.canvas_[t]?t:1}getImageState(){return this.imageState_}getHitDetectionImage(){if(this.image_||this.initializeImage_(),!this.hitDetectionImage_)if(this.isTainted_()){const t=this.size_[0],e=this.size_[1],i=kt(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_===ht.IDLE){this.image_||this.initializeImage_(),this.imageState_=ht.LOADING;try{this.image_.src=this.src_}catch{this.handleImageError_()}this.unlisten_=ra(this.image_,this.handleImageLoad_.bind(this),this.handleImageError_.bind(this))}}replaceColor_(t){if(!this.color_||this.canvas_[t]||this.imageState_!==ht.LOADED)return;const e=this.image_,i=document.createElement("canvas");i.width=Math.ceil(e.width*t),i.height=Math.ceil(e.height*t);const s=i.getContext("2d");s.scale(t,t),s.drawImage(e,0,0),s.globalCompositeOperation="multiply",s.fillStyle=_r(this.color_),s.fillRect(0,0,i.width/t,i.height/t),s.globalCompositeOperation="destination-in",s.drawImage(e,0,0),this.canvas_[t]=i}unlistenImage_(){this.unlisten_&&(this.unlisten_(),this.unlisten_=null)}}function aa(n,t,e,i,s,r){let o=Es.get(t,i,r);return o||(o=new oa(n,t,e,i,s,r),Es.set(t,i,r,o)),o}function Rs(n,t,e,i){return e!==void 0&&i!==void 0?[e/n,i/t]:e!==void 0?e/n:i!==void 0?i/t:1}class Jn extends fr{constructor(t){t=t||{};const e=t.opacity!==void 0?t.opacity:1,i=t.rotation!==void 0?t.rotation:0,s=t.scale!==void 0?t.scale:1,r=t.rotateWithView!==void 0?t.rotateWithView:!1;super({opacity:e,rotation:i,scale:s,displacement:t.displacement!==void 0?t.displacement:[0,0],rotateWithView:r,declutterMode:t.declutterMode}),this.anchor_=t.anchor!==void 0?t.anchor:[.5,.5],this.normalizedAnchor_=null,this.anchorOrigin_=t.anchorOrigin!==void 0?t.anchorOrigin:"top-left",this.anchorXUnits_=t.anchorXUnits!==void 0?t.anchorXUnits:"fraction",this.anchorYUnits_=t.anchorYUnits!==void 0?t.anchorYUnits:"fraction",this.crossOrigin_=t.crossOrigin!==void 0?t.crossOrigin:null;const o=t.img!==void 0?t.img:null;this.imgSize_=t.imgSize;let a=t.src;ft(!(a!==void 0&&o),4),ft(!o||o&&this.imgSize_,5),(a===void 0||a.length===0)&&o&&(a=o.src||nt(o)),ft(a!==void 0&&a.length>0,6),ft(!((t.width!==void 0||t.height!==void 0)&&t.scale!==void 0),69);const l=t.src!==void 0?ht.IDLE:ht.LOADED;if(this.color_=t.color!==void 0?Ji(t.color):null,this.iconImage_=aa(o,a,this.imgSize_!==void 0?this.imgSize_:null,this.crossOrigin_,l,this.color_),this.offset_=t.offset!==void 0?t.offset:[0,0],this.offsetOrigin_=t.offsetOrigin!==void 0?t.offsetOrigin:"top-left",this.origin_=null,this.size_=t.size!==void 0?t.size:null,t.width!==void 0||t.height!==void 0){let h,c;if(t.size)[h,c]=t.size;else{const u=this.getImage(1);if(u instanceof HTMLCanvasElement||u.src&&u.complete)h=u.width,c=u.height;else{this.initialOptions_=t;const d=()=>{if(this.unlistenImageChange(d),!this.initialOptions_)return;const f=this.iconImage_.getSize();this.setScale(Rs(f[0],f[1],t.width,t.height))};this.listenImageChange(d);return}}h!==void 0&&this.setScale(Rs(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 Jn({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_,imgSize:this.imgSize_,offset:this.offset_.slice(),offsetOrigin:this.offsetOrigin_,opacity:this.getOpacity(),rotateWithView:this.getRotateWithView(),rotation:this.getRotation(),scale:t,width:e,height:i,size:this.size_!==null?this.size_.slice():void 0,src:this.getSrc(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()})}getAnchor(){let t=this.normalizedAnchor_;if(!t){t=this.anchor_;const s=this.getSize();if(this.anchorXUnits_=="fraction"||this.anchorYUnits_=="fraction"){if(!s)return null;t=this.anchor_.slice(),this.anchorXUnits_=="fraction"&&(t[0]*=s[0]),this.anchorYUnits_=="fraction"&&(t[1]*=s[1])}if(this.anchorOrigin_!="top-left"){if(!s)return null;t===this.anchor_&&(t=this.anchor_.slice()),(this.anchorOrigin_=="top-right"||this.anchorOrigin_=="bottom-right")&&(t[0]=-t[0]+s[0]),(this.anchorOrigin_=="bottom-left"||this.anchorOrigin_=="bottom-right")&&(t[1]=-t[1]+s[1])}this.normalizedAnchor_=t}const e=this.getDisplacement(),i=this.getScaleArray();return[t[0]-e[0]/i[0],t[1]+e[1]/i[1]]}setAnchor(t){this.anchor_=t,this.normalizedAnchor_=null}getColor(){return this.color_}getImage(t){return this.iconImage_.getImage(t)}getPixelRatio(t){return this.iconImage_.getPixelRatio(t)}getImageSize(){return this.iconImage_.getSize()}getImageState(){return this.iconImage_.getImageState()}getHitDetectionImage(){return this.iconImage_.getHitDetectionImage()}getOrigin(){if(this.origin_)return this.origin_;let t=this.offset_;if(this.offsetOrigin_!="top-left"){const e=this.getSize(),i=this.iconImage_.getSize();if(!e||!i)return null;t=t.slice(),(this.offsetOrigin_=="top-right"||this.offsetOrigin_=="bottom-right")&&(t[0]=i[0]-e[0]-t[0]),(this.offsetOrigin_=="bottom-left"||this.offsetOrigin_=="bottom-right")&&(t[1]=i[1]-e[1]-t[1])}return this.origin_=t,this.origin_}getSrc(){return this.iconImage_.getSrc()}getSize(){return this.size_?this.size_:this.iconImage_.getSize()}getWidth(){const t=this.getScaleArray();if(this.size_)return this.size_[0]*t[0];if(this.iconImage_.getImageState()==ht.LOADED)return this.iconImage_.getSize()[0]*t[0]}getHeight(){const t=this.getScaleArray();if(this.size_)return this.size_[1]*t[1];if(this.iconImage_.getImageState()==ht.LOADED)return this.iconImage_.getSize()[1]*t[1]}setScale(t){delete this.initialOptions_,super.setScale(t)}listenImageChange(t){this.iconImage_.addEventListener(vt.CHANGE,t)}load(){this.iconImage_.load()}unlistenImageChange(t){this.iconImage_.removeEventListener(vt.CHANGE,t)}}const Or=Jn;class Qn{constructor(t){t=t||{},this.color_=t.color!==void 0?t.color:null,this.lineCap_=t.lineCap,this.lineDash_=t.lineDash!==void 0?t.lineDash:null,this.lineDashOffset_=t.lineDashOffset,this.lineJoin_=t.lineJoin,this.miterLimit_=t.miterLimit,this.width_=t.width}clone(){const t=this.getColor();return new Qn({color:Array.isArray(t)?t.slice():t||void 0,lineCap:this.getLineCap(),lineDash:this.getLineDash()?this.getLineDash().slice():void 0,lineDashOffset:this.getLineDashOffset(),lineJoin:this.getLineJoin(),miterLimit:this.getMiterLimit(),width:this.getWidth()})}getColor(){return this.color_}getLineCap(){return this.lineCap_}getLineDash(){return this.lineDash_}getLineDashOffset(){return this.lineDashOffset_}getLineJoin(){return this.lineJoin_}getMiterLimit(){return this.miterLimit_}getWidth(){return this.width_}setColor(t){this.color_=t}setLineCap(t){this.lineCap_=t}setLineDash(t){this.lineDash_=t}setLineDashOffset(t){this.lineDashOffset_=t}setLineJoin(t){this.lineJoin_=t}setMiterLimit(t){this.miterLimit_=t}setWidth(t){this.width_=t}}const le=Qn;class re{constructor(t){t=t||{},this.geometry_=null,this.geometryFunction_=ws,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 re({geometry:t,fill:this.getFill()?this.getFill().clone():void 0,image:this.getImage()?this.getImage().clone():void 0,renderer:this.getRenderer(),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_=ws,this.geometry_=t}setZIndex(t){this.zIndex_=t}}function la(n){let t;if(typeof n=="function")t=n;else{let e;Array.isArray(n)?e=n:(ft(typeof n.getZIndex=="function",41),e=[n]),t=function(){return e}}return t}let En=null;function ha(n,t){if(!En){const e=new mt({color:"rgba(255,255,255,0.4)"}),i=new le({color:"#3399CC",width:1.25});En=[new re({image:new Ei({fill:e,stroke:i,radius:5}),fill:e,stroke:i})]}return En}function ca(){const n={},t=[255,255,255,1],e=[0,153,255,1],i=3;return n.Polygon=[new re({fill:new mt({color:[255,255,255,.5]})})],n.MultiPolygon=n.Polygon,n.LineString=[new re({stroke:new le({color:t,width:i+2})}),new re({stroke:new le({color:e,width:i})})],n.MultiLineString=n.LineString,n.Circle=n.Polygon.concat(n.LineString),n.Point=[new re({image:new Ei({radius:i*2,fill:new mt({color:e}),stroke:new le({color:t,width:i/2})}),zIndex:1/0})],n.MultiPoint=n.Point,n.GeometryCollection=n.Polygon.concat(n.LineString,n.Point),n}function ws(n){return n.getGeometry()}const se=re,ua="#333";class $n{constructor(t){t=t||{},this.font_=t.font,this.rotation_=t.rotation,this.rotateWithView_=t.rotateWithView,this.scale_=t.scale,this.scaleArray_=Ki(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 mt({color:ua}),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}clone(){const 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(),scale:Array.isArray(t)?t.slice():t,text:this.getText(),textAlign:this.getTextAlign(),justify:this.getJustify(),textBaseline:this.getTextBaseline(),fill:this.getFill()?this.getFill().clone():void 0,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})}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_}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_}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}setFill(t){this.fill_=t}setRotation(t){this.rotation_=t}setScale(t){this.scale_=t,this.scaleArray_=Ki(t!==void 0?t:1)}setStroke(t){this.stroke_=t}setText(t){this.text_=t}setTextAlign(t){this.textAlign_=t}setJustify(t){this.justify_=t}setTextBaseline(t){this.textBaseline_=t}setBackgroundFill(t){this.backgroundFill_=t}setBackgroundStroke(t){this.backgroundStroke_=t}setPadding(t){this.padding_=t}}const hi=$n;function da(n){return Math.pow(n,3)}function fa(n){return 1-da(1-n)}function ga(n){return 3*n*n-2*n*n*n}const Pr={radians:6370997/(2*Math.PI),degrees:2*Math.PI*6370997/360,ft:.3048,m:1,"us-ft":1200/3937};class _a{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_||Pr[this.units_]}getWorldExtent(){return this.worldExtent_}getAxisOrientation(){return this.axisOrientation_}isGlobal(){return this.global_}setGlobal(t){this.global_=t,this.canWrapX_=!!(t&&this.extent_)}getDefaultTileGrid(){return this.defaultTileGrid_}setDefaultTileGrid(t){this.defaultTileGrid_=t}setExtent(t){this.extent_=t,this.canWrapX_=!!(this.global_&&t)}setWorldExtent(t){this.worldExtent_=t}setGetPointResolution(t){this.getPointResolutionFunc_=t}getPointResolutionFunc(){return this.getPointResolutionFunc_}}const Gr=_a,Ti=6378137,Ve=Math.PI*Ti,ma=[-Ve,-Ve,Ve,Ve],pa=[-180,-85,180,85],Yi=Ti*Math.log(Math.tan(Math.PI/2));class Ge extends Gr{constructor(t){super({code:t,units:"m",extent:ma,global:!0,worldExtent:pa,getPointResolution:function(e,i){return e/Math.cosh(i[1]/Ti)}})}}const Is=[new Ge("EPSG:3857"),new Ge("EPSG:102100"),new Ge("EPSG:102113"),new Ge("EPSG:900913"),new Ge("http://www.opengis.net/def/crs/EPSG/0/3857"),new Ge("http://www.opengis.net/gml/srs/epsg.xml#3857")];function xa(n,t,e){const i=n.length;e=e>1?e:2,t===void 0&&(e>2?t=n.slice():t=new Array(i));for(let s=0;s<i;s+=e){t[s]=Ve*n[s]/180;let r=Ti*Math.log(Math.tan(Math.PI*(+n[s+1]+90)/360));r>Yi?r=Yi:r<-Yi&&(r=-Yi),t[s+1]=r}return t}function ya(n,t,e){const i=n.length;e=e>1?e:2,t===void 0&&(e>2?t=n.slice():t=new Array(i));for(let s=0;s<i;s+=e)t[s]=180*n[s]/Ve,t[s+1]=360*Math.atan(Math.exp(n[s+1]/Ti))/Math.PI-90;return t}const va=6378137,Ms=[-180,-90,180,90],Sa=Math.PI*va/180;class Se extends Gr{constructor(t,e){super({code:t,units:"degrees",extent:Ms,axisOrientation:e,global:!0,metersPerUnit:Sa,worldExtent:Ms})}}const As=[new Se("CRS:84"),new Se("EPSG:4326","neu"),new Se("urn:ogc:def:crs:OGC:1.3:CRS84"),new Se("urn:ogc:def:crs:OGC:2:84"),new Se("http://www.opengis.net/def/crs/OGC/1.3/CRS84"),new Se("http://www.opengis.net/gml/srs/epsg.xml#4326","neu"),new Se("http://www.opengis.net/def/crs/EPSG/0/4326","neu")];let Pn={};function Ca(n){return Pn[n]||Pn[n.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\w+)$/,"EPSG:$3")]||null}function Ea(n,t){Pn[n]=t}let Ue={};function sn(n,t,e){const i=n.getCode(),s=t.getCode();i in Ue||(Ue[i]={}),Ue[i][s]=e}function Ra(n,t){let e;return n in Ue&&t in Ue[n]&&(e=Ue[n][t]),e}function wa(n,t){return n[0]+=+t[0],n[1]+=+t[1],n}function Br(n,t){const e=n[0],i=n[1],s=t[0],r=t[1],o=s[0],a=s[1],l=r[0],h=r[1],c=l-o,u=h-a,d=c===0&&u===0?0:(c*(e-o)+u*(i-a))/(c*c+u*u||0);let f,g;return d<=0?(f=o,g=a):d>=1?(f=l,g=h):(f=o+d*c,g=a+d*u),[f,g]}function Tt(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 Ia(n,t){const e=Math.cos(t),i=Math.sin(t),s=n[0]*e-n[1]*i,r=n[1]*e+n[0]*i;return n[0]=s,n[1]=r,n}function Ii(n,t){const e=n[0]-t[0],i=n[1]-t[1];return e*e+i*i}function Ls(n,t){return Math.sqrt(Ii(n,t))}function Ma(n,t){return Ii(n,Br(n,t))}function Aa(n,t){if(t.canWrapX()){const e=At(t.getExtent()),i=La(n,t,e);i&&(n[0]-=i*e)}return n}function La(n,t,e){const i=t.getExtent();let s=0;return t.canWrapX()&&(n[0]<i[0]||n[0]>i[2])&&(e=e||At(i),s=Math.floor((n[0]-i[0])/e)),s}const ts=63710088e-1;function ba(n,t,e){e=e||ts;const i=Me(n[1]),s=Me(t[1]),r=(s-i)/2,o=Me(t[0]-n[0])/2,a=Math.sin(r)*Math.sin(r)+Math.sin(o)*Math.sin(o)*Math.cos(i)*Math.cos(s);return 2*e*Math.atan2(Math.sqrt(a),Math.sqrt(1-a))}function Rn(n,t){let e=0;for(let i=0,s=n.length;i<s-1;++i)e+=ba(n[i],n[i+1],t);return e}function Nr(n,t){t=t||{};const e=t.radius||ts,i=t.projection||"EPSG:3857",s=n.getType();s!=="GeometryCollection"&&(n=n.clone().transform(i,"EPSG:4326"));let r=0,o,a,l,h,c,u;switch(s){case"Point":case"MultiPoint":break;case"LineString":case"LinearRing":{o=n.getCoordinates(),r=Rn(o,e);break}case"MultiLineString":case"Polygon":{for(o=n.getCoordinates(),l=0,h=o.length;l<h;++l)r+=Rn(o[l],e);break}case"MultiPolygon":{for(o=n.getCoordinates(),l=0,h=o.length;l<h;++l)for(a=o[l],c=0,u=a.length;c<u;++c)r+=Rn(a[c],e);break}case"GeometryCollection":{const d=n.getGeometries();for(l=0,h=d.length;l<h;++l)r+=Nr(d[l],t);break}default:throw new Error("Unsupported geometry type: "+s)}return r}function zi(n,t){let e=0;const i=n.length;let s=n[i-1][0],r=n[i-1][1];for(let o=0;o<i;o++){const a=n[o][0],l=n[o][1];e+=Me(a-s)*(2+Math.sin(Me(r))+Math.sin(Me(l))),s=a,r=l}return e*t*t/2}function Xr(n,t){t=t||{};const e=t.radius||ts,i=t.projection||"EPSG:3857",s=n.getType();s!=="GeometryCollection"&&(n=n.clone().transform(i,"EPSG:4326"));let r=0,o,a,l,h,c,u;switch(s){case"Point":case"MultiPoint":case"LineString":case"MultiLineString":case"LinearRing":break;case"Polygon":{for(o=n.getCoordinates(),r=Math.abs(zi(o[0],e)),l=1,h=o.length;l<h;++l)r-=Math.abs(zi(o[l],e));break}case"MultiPolygon":{for(o=n.getCoordinates(),l=0,h=o.length;l<h;++l)for(a=o[l],r+=Math.abs(zi(a[0],e)),c=1,u=a.length;c<u;++c)r-=Math.abs(zi(a[c],e));break}case"GeometryCollection":{const d=n.getGeometries();for(l=0,h=d.length;l<h;++l)r+=Xr(d[l],t);break}default:throw new Error("Unsupported geometry type: "+s)}return r}const Wr={info:1,warn:2,error:3,none:4};let Ta=Wr.info;function Da(...n){Ta>Wr.warn||console.warn(...n)}let Gn=!0;function ka(n){Gn=!(n===void 0?!0:n)}function Yr(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 Fa(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 Oa(n){Ea(n.getCode(),n),sn(n,n,Yr)}function Pa(n){n.forEach(Oa)}function Je(n){return typeof n=="string"?Ca(n):n||null}function bs(n){Pa(n),n.forEach(function(t){n.forEach(function(e){t!==e&&sn(t,e,Yr)})})}function Ga(n,t,e,i){n.forEach(function(s){t.forEach(function(r){sn(s,r,e),sn(r,s,i)})})}function es(n,t){return n?typeof n=="string"?Je(n):n:Je(t)}function Ba(n,t){const e=n.getCode(),i=t.getCode();let s=Ra(e,i);return s||(s=Fa),s}function Ts(n,t){const e=Je(n),i=Je(t);return Ba(e,i)}function Mi(n,t){return n}function xt(n,t){return Gn&&!Tt(n,[0,0])&&n[0]>=-180&&n[0]<=180&&n[1]>=-90&&n[1]<=90&&(Gn=!1,Da("Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates.")),n}function is(n,t){return n}function Ze(n,t){return n}function Na(){bs(Is),bs(As),Ga(As,Is,xa,ya)}Na();class Xa extends ue{constructor(t){super(),this.projection=Je(t.projection),this.attributions_=Ds(t.attributions),this.attributionsCollapsible_=t.attributionsCollapsible!==void 0?t.attributionsCollapsible:!0,this.loading=!1,this.state_=t.state!==void 0?t.state:"ready",this.wrapX_=t.wrapX!==void 0?t.wrapX:!1,this.interpolate_=!!t.interpolate,this.viewResolver=null,this.viewRejector=null;const e=this;this.viewPromise_=new Promise(function(i,s){e.viewResolver=i,e.viewRejector=s})}getAttributions(){return this.attributions_}getAttributionsCollapsible(){return this.attributionsCollapsible_}getProjection(){return this.projection}getResolutions(t){return null}getView(){return this.viewPromise_}getState(){return this.state_}getWrapX(){return this.wrapX_}getInterpolate(){return this.interpolate_}refresh(){this.changed()}setAttributions(t){this.attributions_=Ds(t),this.changed()}setState(t){this.state_=t,this.changed()}}function Ds(n){return n?Array.isArray(n)?function(t){return n}:typeof n=="function"?n:function(t){return[n]}:null}const Wa=Xa,Ya=256;function zr(n,t,e,i,s){let r;for(t+=i;t<e;t+=i)if(r=s(n.slice(t-i,t),n.slice(t,t+i)),r)return r;return!1}function za(n,t,e,i,s){return!Qo(s,function(o){return!Re(n,t,e,i,o[0],o[1])})}function Re(n,t,e,i,s,r){let o=0,a=n[e-i],l=n[e-i+1];for(;t<e;t+=i){const h=n[t],c=n[t+1];l<=r?c>r&&(h-a)*(r-l)-(s-a)*(c-l)>0&&o++:c<=r&&(h-a)*(r-l)-(s-a)*(c-l)<0&&o--,a=h,l=c}return o!==0}function Vr(n,t,e,i,s,r){if(e.length===0||!Re(n,t,e[0],i,s,r))return!1;for(let o=1,a=e.length;o<a;++o)if(Re(n,e[o-1],e[o],i,s,r))return!1;return!0}function ns(n,t,e,i,s){const r=Lr(Le(),n,t,e,i);return Dt(s,r)?ze(s,r)||r[0]>=s[0]&&r[2]<=s[2]||r[1]>=s[1]&&r[3]<=s[3]?!0:zr(n,t,e,i,function(o,a){return na(s,o,a)}):!1}function Va(n,t,e,i,s){return!!(ns(n,t,e,i,s)||Re(n,t,e,i,s[0],s[1])||Re(n,t,e,i,s[0],s[3])||Re(n,t,e,i,s[2],s[1])||Re(n,t,e,i,s[2],s[3]))}function Za(n,t,e,i,s){if(!Va(n,t,e[0],i,s))return!1;if(e.length===1)return!0;for(let r=1,o=e.length;r<o;++r)if(za(n,e[r-1],e[r],i,s)&&!ns(n,e[r-1],e[r],i,s))return!1;return!0}class ss extends ue{constructor(t){if(super(),this.on,this.once,this.un,this.id_=void 0,this.geometryName_="geometry",this.style_=null,this.styleFunction_=void 0,this.geometryChangeKey_=null,this.addChangeListener(this.geometryName_,this.handleGeometryChanged_),t)if(typeof t.getSimplifiedGeometry=="function"){const e=t;this.setGeometry(e)}else{const e=t;this.setProperties(e)}}clone(){const t=new ss(this.hasProperties()?this.getProperties():null);t.setGeometryName(this.getGeometryName());const e=this.getGeometry();e&&t.setGeometry(e.clone());const i=this.getStyle();return i&&t.setStyle(i),t}getGeometry(){return this.get(this.geometryName_)}getId(){return this.id_}getGeometryName(){return this.geometryName_}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}handleGeometryChange_(){this.changed()}handleGeometryChanged_(){this.geometryChangeKey_&&(Vt(this.geometryChangeKey_),this.geometryChangeKey_=null);const t=this.getGeometry();t&&(this.geometryChangeKey_=zt(t,vt.CHANGE,this.handleGeometryChange_,this)),this.changed()}setGeometry(t){this.set(this.geometryName_,t)}setStyle(t){this.style_=t,this.styleFunction_=t?ja(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 ja(n){if(typeof n=="function")return n;let t;return Array.isArray(n)?t=n:(ft(typeof n.getZIndex=="function",41),t=[n]),function(){return t}}const ks=ss;new Array(6);function he(){return[1,0,0,1,0,0]}function Ua(n,t,e,i,s,r,o){return n[0]=t,n[1]=e,n[2]=i,n[3]=s,n[4]=r,n[5]=o,n}function Ha(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 St(n,t){const e=t[0],i=t[1];return t[0]=n[0]*e+n[2]*i+n[4],t[1]=n[1]*e+n[3]*i+n[5],t}function qa(n,t,e){return Ua(n,t,0,0,e,0,0)}function Di(n,t,e,i,s,r,o,a){const l=Math.sin(r),h=Math.cos(r);return n[0]=i*h,n[1]=s*l,n[2]=-i*l,n[3]=s*h,n[4]=o*i*h-a*i*l+t,n[5]=o*s*l+a*s*h+e,n}function Ka(n,t){const e=Ja(t);ft(e!==0,32);const i=t[0],s=t[1],r=t[2],o=t[3],a=t[4],l=t[5];return n[0]=o/e,n[1]=-s/e,n[2]=-r/e,n[3]=i/e,n[4]=(r*l-o*a)/e,n[5]=-(i*l-s*a)/e,n}function Ja(n){return n[0]*n[3]-n[1]*n[2]}let Fs;function Qa(n){const t="matrix("+n.join(", ")+")";if(Vn)return t;const e=Fs||(Fs=document.createElement("div"));return e.style.transform=t,e.style.transform}function Ae(n,t,e,i,s,r){r=r||[];let o=0;for(let a=t;a<e;a+=i){const l=n[a],h=n[a+1];r[o++]=s[0]*l+s[2]*h+s[4],r[o++]=s[1]*l+s[3]*h+s[5]}return r&&r.length!=o&&(r.length=o),r}function Zr(n,t,e,i,s,r,o){o=o||[];const a=Math.cos(s),l=Math.sin(s),h=r[0],c=r[1];let u=0;for(let d=t;d<e;d+=i){const f=n[d]-h,g=n[d+1]-c;o[u++]=h+f*a-g*l,o[u++]=c+f*l+g*a;for(let _=d+2;_<d+i;++_)o[u++]=n[_]}return o&&o.length!=u&&(o.length=u),o}function $a(n,t,e,i,s,r,o,a){a=a||[];const l=o[0],h=o[1];let c=0;for(let u=t;u<e;u+=i){const d=n[u]-l,f=n[u+1]-h;a[c++]=l+s*d,a[c++]=h+r*f;for(let g=u+2;g<u+i;++g)a[c++]=n[g]}return a&&a.length!=c&&(a.length=c),a}function tl(n,t,e,i,s,r,o){o=o||[];let a=0;for(let l=t;l<e;l+=i){o[a++]=n[l]+s,o[a++]=n[l+1]+r;for(let h=l+2;h<l+i;++h)o[a++]=n[h]}return o&&o.length!=a&&(o.length=a),o}const Os=he();class el extends ue{constructor(){super(),this.extent_=Le(),this.extentRevision_=-1,this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=0,this.simplifyTransformedInternal=Go(function(t,e,i){if(!i)return this.getSimplifiedGeometry(e);const s=this.clone();return s.applyTransform(i),s.getSimplifiedGeometry(e)})}simplifyTransformed(t,e){return this.simplifyTransformedInternal(this.getRevision(),t,e)}clone(){return tt()}closestPointXY(t,e,i,s){return tt()}containsXY(t,e){const i=this.getClosestPoint([t,e]);return i[0]===t&&i[1]===e}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 tt()}getExtent(t){if(this.extentRevision_!=this.getRevision()){const e=this.computeExtent(this.extent_);(isNaN(e[0])||isNaN(e[1]))&&Ir(e),this.extentRevision_=this.getRevision()}return ia(this.extent_,t)}rotate(t,e){tt()}scale(t,e,i){tt()}simplify(t){return this.getSimplifiedGeometry(t*t)}getSimplifiedGeometry(t){return tt()}getType(){return tt()}applyTransform(t){tt()}intersectsExtent(t){return tt()}translate(t,e){tt()}transform(t,e){const i=Je(t),s=i.getUnits()=="tile-pixels"?function(r,o,a){const l=i.getExtent(),h=i.getWorldExtent(),c=wi(h)/wi(l);return Di(Os,h[0],h[3],c,-c,0,0,0),Ae(r,0,r.length,a,Os,o),Ts(i,e)(r,o,a)}:Ts(i,e);return this.applyTransform(s),this}}const il=el;class nl extends il{constructor(){super(),this.layout="XY",this.stride=2,this.flatCoordinates=null}computeExtent(t){return Ko(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinates(){return tt()}getFirstCoordinate(){return this.flatCoordinates.slice(0,this.stride)}getFlatCoordinates(){return this.flatCoordinates}getLastCoordinate(){return this.flatCoordinates.slice(this.flatCoordinates.length-this.stride)}getLayout(){return this.layout}getSimplifiedGeometry(t){if(this.simplifiedGeometryRevision!==this.getRevision()&&(this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=this.getRevision()),t<0||this.simplifiedGeometryMaxMinSquaredTolerance!==0&&t<=this.simplifiedGeometryMaxMinSquaredTolerance)return this;const e=this.getSimplifiedGeometryInternal(t);return e.getFlatCoordinates().length<this.flatCoordinates.length?e:(this.simplifiedGeometryMaxMinSquaredTolerance=t,this)}getSimplifiedGeometryInternal(t){return this}getStride(){return this.stride}setFlatCoordinates(t,e){this.stride=Ps(t),this.layout=t,this.flatCoordinates=e}setCoordinates(t,e){tt()}setLayout(t,e,i){let s;if(t)s=Ps(t);else{for(let r=0;r<i;++r){if(e.length===0){this.layout="XY",this.stride=2;return}e=e[0]}s=e.length,t=sl(s)}this.layout=t,this.stride=s}applyTransform(t){this.flatCoordinates&&(t(this.flatCoordinates,this.flatCoordinates,this.stride),this.changed())}rotate(t,e){const i=this.getFlatCoordinates();if(i){const s=this.getStride();Zr(i,0,i.length,s,t,e,i),this.changed()}}scale(t,e,i){e===void 0&&(e=t),i||(i=Ri(this.getExtent()));const s=this.getFlatCoordinates();if(s){const r=this.getStride();$a(s,0,s.length,r,t,e,i,s),this.changed()}}translate(t,e){const i=this.getFlatCoordinates();if(i){const s=this.getStride();tl(i,0,i.length,s,t,e,i),this.changed()}}}function sl(n){let t;return n==2?t="XY":n==3?t="XYZ":n==4&&(t="XYZM"),t}function Ps(n){let t;return n=="XY"?t=2:n=="XYZ"||n=="XYM"?t=3:n=="XYZM"&&(t=4),t}function rl(n,t,e){const i=n.getFlatCoordinates();if(!i)return null;const s=n.getStride();return Ae(i,0,i.length,s,t,e)}const un=nl;function al(n,t,e,i){for(let s=0,r=e.length;s<r;++s)n[t++]=e[s];return t}function rs(n,t,e,i){for(let s=0,r=e.length;s<r;++s){const o=e[s];for(let a=0;a<i;++a)n[t++]=o[a]}return t}function ll(n,t,e,i,s){s=s||[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=rs(n,t,e[o],i);s[r++]=l,t=l}return s.length=r,s}class os extends un{constructor(t,e){super(),this.setCoordinates(t,e)}clone(){const t=new os(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,s){const r=this.flatCoordinates,o=je(t,e,r[0],r[1]);if(o<s){const a=this.stride;for(let l=0;l<a;++l)i[l]=r[l];return i.length=a,o}return s}getCoordinates(){return this.flatCoordinates?this.flatCoordinates.slice():[]}computeExtent(t){return qi(this.flatCoordinates,t)}getType(){return"Point"}intersectsExtent(t){return wr(t,this.flatCoordinates[0],this.flatCoordinates[1])}setCoordinates(t,e){this.setLayout(e,t,0),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=al(this.flatCoordinates,0,t,this.stride),this.changed()}}const Ai=os,oe={ADD:"add",REMOVE:"remove"},Gs={LENGTH:"length"};class Vi extends ti{constructor(t,e,i){super(t),this.element=e,this.index=i}}class hl extends ue{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=0,s=this.array_.length;i<s;++i)this.assertUnique_(this.array_[i],i);this.updateLength_()}clear(){for(;this.getLength()>0;)this.pop()}extend(t){for(let e=0,i=t.length;e<i;++e)this.push(t[e]);return this}forEach(t){const e=this.array_;for(let i=0,s=e.length;i<s;++i)t(e[i],i,e)}getArray(){return this.array_}item(t){return this.array_[t]}getLength(){return this.get(Gs.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 Vi(oe.ADD,e,t))}pop(){return this.removeAt(this.getLength()-1)}push(t){this.unique_&&this.assertUnique_(t);const e=this.getLength();return this.insertAt(e,t),this.getLength()}remove(t){const e=this.array_;for(let i=0,s=e.length;i<s;++i)if(e[i]===t)return this.removeAt(i)}removeAt(t){if(t<0||t>=this.getLength())return;const e=this.array_[t];return this.array_.splice(t,1),this.updateLength_(),this.dispatchEvent(new Vi(oe.REMOVE,e,t)),e}setAt(t,e){const i=this.getLength();if(t>=i){this.insertAt(t,e);return}if(t<0)throw new Error("Index out of bounds: "+t);this.unique_&&this.assertUnique_(e,t);const s=this.array_[t];this.array_[t]=e,this.dispatchEvent(new Vi(oe.REMOVE,s,t)),this.dispatchEvent(new Vi(oe.ADD,e,t))}updateLength_(){this.set(Gs.LENGTH,this.array_.length)}assertUnique_(t,e){for(let i=0,s=this.array_.length;i<s;++i)if(this.array_[i]===t&&i!==e)throw new gr(58)}}const Bn=hl;function cl(n,t,e,i,s){jr(n,t,e||0,i||n.length-1,s||ul)}function jr(n,t,e,i,s){for(;i>e;){if(i-e>600){var r=i-e+1,o=t-e+1,a=Math.log(r),l=.5*Math.exp(2*a/3),h=.5*Math.sqrt(a*l*(r-l)/r)*(o-r/2<0?-1:1),c=Math.max(e,Math.floor(t-o*l/r+h)),u=Math.min(i,Math.floor(t+(r-o)*l/r+h));jr(n,t,c,u,s)}var d=n[t],f=e,g=i;for(li(n,e,t),s(n[i],d)>0&&li(n,e,i);f<g;){for(li(n,f,g),f++,g--;s(n[f],d)<0;)f++;for(;s(n[g],d)>0;)g--}s(n[e],d)===0?li(n,e,g):(g++,li(n,g,i)),g<=t&&(e=g+1),t<=g&&(i=g-1)}}function li(n,t,e){var i=n[t];n[t]=n[e],n[e]=i}function ul(n,t){return n<t?-1:n>t?1:0}class Ur{constructor(t=9){this._maxEntries=Math.max(4,t),this._minEntries=Math.max(2,Math.ceil(this._maxEntries*.4)),this.clear()}all(){return this._all(this.data,[])}search(t){let e=this.data;const i=[];if(!ji(t,e))return i;const s=this.toBBox,r=[];for(;e;){for(let o=0;o<e.children.length;o++){const a=e.children[o],l=e.leaf?s(a):a;ji(t,l)&&(e.leaf?i.push(a):In(t,l)?this._all(a,i):r.push(a))}e=r.pop()}return i}collides(t){let e=this.data;if(!ji(t,e))return!1;const i=[];for(;e;){for(let s=0;s<e.children.length;s++){const r=e.children[s],o=e.leaf?this.toBBox(r):r;if(ji(t,o)){if(e.leaf||In(t,o))return!0;i.push(r)}}e=i.pop()}return!1}load(t){if(!(t&&t.length))return this;if(t.length<this._minEntries){for(let i=0;i<t.length;i++)this.insert(t[i]);return this}let e=this._build(t.slice(),0,t.length-1,0);if(!this.data.children.length)this.data=e;else if(this.data.height===e.height)this._splitRoot(this.data,e);else{if(this.data.height<e.height){const i=this.data;this.data=e,e=i}this._insert(e,this.data.height-e.height-1,!0)}return this}insert(t){return t&&this._insert(t,this.data.height-1),this}clear(){return this.data=We([]),this}remove(t,e){if(!t)return this;let i=this.data;const s=this.toBBox(t),r=[],o=[];let a,l,h;for(;i||r.length;){if(i||(i=r.pop(),l=r[r.length-1],a=o.pop(),h=!0),i.leaf){const c=dl(t,i.children,e);if(c!==-1)return i.children.splice(c,1),r.push(i),this._condense(r),this}!h&&!i.leaf&&In(i,s)?(r.push(i),o.push(a),a=0,l=i,i=i.children[0]):l?(a++,i=l.children[a],h=!1):i=null}return this}toBBox(t){return t}compareMinX(t,e){return t.minX-e.minX}compareMinY(t,e){return t.minY-e.minY}toJSON(){return this.data}fromJSON(t){return this.data=t,this}_all(t,e){const i=[];for(;t;)t.leaf?e.push(...t.children):i.push(...t.children),t=i.pop();return e}_build(t,e,i,s){const r=i-e+1;let o=this._maxEntries,a;if(r<=o)return a=We(t.slice(e,i+1)),Be(a,this.toBBox),a;s||(s=Math.ceil(Math.log(r)/Math.log(o)),o=Math.ceil(r/Math.pow(o,s-1))),a=We([]),a.leaf=!1,a.height=s;const l=Math.ceil(r/o),h=l*Math.ceil(Math.sqrt(o));Bs(t,e,i,h,this.compareMinX);for(let c=e;c<=i;c+=h){const u=Math.min(c+h-1,i);Bs(t,c,u,l,this.compareMinY);for(let d=c;d<=u;d+=l){const f=Math.min(d+l-1,u);a.children.push(this._build(t,d,f,s-1))}}return Be(a,this.toBBox),a}_chooseSubtree(t,e,i,s){for(;s.push(e),!(e.leaf||s.length-1===i);){let r=1/0,o=1/0,a;for(let l=0;l<e.children.length;l++){const h=e.children[l],c=wn(h),u=_l(t,h)-c;u<o?(o=u,r=c<r?c:r,a=h):u===o&&c<r&&(r=c,a=h)}e=a||e.children[0]}return e}_insert(t,e,i){const s=i?t:this.toBBox(t),r=[],o=this._chooseSubtree(s,this.data,e,r);for(o.children.push(t),ui(o,s);e>=0&&r[e].children.length>this._maxEntries;)this._split(r,e),e--;this._adjustParentBBoxes(s,r,e)}_split(t,e){const i=t[e],s=i.children.length,r=this._minEntries;this._chooseSplitAxis(i,r,s);const o=this._chooseSplitIndex(i,r,s),a=We(i.children.splice(o,i.children.length-o));a.height=i.height,a.leaf=i.leaf,Be(i,this.toBBox),Be(a,this.toBBox),e?t[e-1].children.push(a):this._splitRoot(i,a)}_splitRoot(t,e){this.data=We([t,e]),this.data.height=t.height+1,this.data.leaf=!1,Be(this.data,this.toBBox)}_chooseSplitIndex(t,e,i){let s,r=1/0,o=1/0;for(let a=e;a<=i-e;a++){const l=ci(t,0,a,this.toBBox),h=ci(t,a,i,this.toBBox),c=ml(l,h),u=wn(l)+wn(h);c<r?(r=c,s=a,o=u<o?u:o):c===r&&u<o&&(o=u,s=a)}return s||i-e}_chooseSplitAxis(t,e,i){const s=t.leaf?this.compareMinX:fl,r=t.leaf?this.compareMinY:gl,o=this._allDistMargin(t,e,i,s),a=this._allDistMargin(t,e,i,r);o<a&&t.children.sort(s)}_allDistMargin(t,e,i,s){t.children.sort(s);const r=this.toBBox,o=ci(t,0,e,r),a=ci(t,i-e,i,r);let l=Zi(o)+Zi(a);for(let h=e;h<i-e;h++){const c=t.children[h];ui(o,t.leaf?r(c):c),l+=Zi(o)}for(let h=i-e-1;h>=e;h--){const c=t.children[h];ui(a,t.leaf?r(c):c),l+=Zi(a)}return l}_adjustParentBBoxes(t,e,i){for(let s=i;s>=0;s--)ui(e[s],t)}_condense(t){for(let e=t.length-1,i;e>=0;e--)t[e].children.length===0?e>0?(i=t[e-1].children,i.splice(i.indexOf(t[e]),1)):this.clear():Be(t[e],this.toBBox)}}function dl(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 Be(n,t){ci(n,0,n.children.length,t,n)}function ci(n,t,e,i,s){s||(s=We(null)),s.minX=1/0,s.minY=1/0,s.maxX=-1/0,s.maxY=-1/0;for(let r=t;r<e;r++){const o=n.children[r];ui(s,n.leaf?i(o):o)}return s}function ui(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 fl(n,t){return n.minX-t.minX}function gl(n,t){return n.minY-t.minY}function wn(n){return(n.maxX-n.minX)*(n.maxY-n.minY)}function Zi(n){return n.maxX-n.minX+(n.maxY-n.minY)}function _l(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 ml(n,t){const e=Math.max(n.minX,t.minX),i=Math.max(n.minY,t.minY),s=Math.min(n.maxX,t.maxX),r=Math.min(n.maxY,t.maxY);return Math.max(0,s-e)*Math.max(0,r-i)}function In(n,t){return n.minX<=t.minX&&n.minY<=t.minY&&t.maxX<=n.maxX&&t.maxY<=n.maxY}function ji(n,t){return t.minX<=n.maxX&&t.minY<=n.maxY&&t.maxX>=n.minX&&t.maxY>=n.minY}function We(n){return{children:n,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function Bs(n,t,e,i,s){const r=[t,e];for(;r.length;){if(e=r.pop(),t=r.pop(),e-t<=i)continue;const o=t+Math.ceil((e-t)/i/2)*i;cl(n,o,t,e,s),r.push(t,o,o,e)}}class pl{constructor(t){this.rbush_=new Ur(t),this.items_={}}insert(t,e){const i={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3],value:e};this.rbush_.insert(i),this.items_[nt(e)]=i}load(t,e){const i=new Array(e.length);for(let s=0,r=e.length;s<r;s++){const o=t[s],a=e[s],l={minX:o[0],minY:o[1],maxX:o[2],maxY:o[3],value:a};i[s]=l,this.items_[nt(a)]=l}this.rbush_.load(i)}remove(t){const e=nt(t),i=this.items_[e];return delete this.items_[e],this.rbush_.remove(i)!==null}update(t,e){const i=this.items_[nt(e)],s=[i.minX,i.minY,i.maxX,i.maxY];Mr(s,t)||(this.remove(e),this.insert(t,e))}getAll(){return this.rbush_.all().map(function(e){return e.value})}getInExtent(t){const e={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3]};return this.rbush_.search(e).map(function(s){return s.value})}forEach(t){return this.forEach_(this.getAll(),t)}forEachInExtent(t,e){return this.forEach_(this.getInExtent(t),e)}forEach_(t,e){let i;for(let s=0,r=t.length;s<r;s++)if(i=e(t[s]),i)return i;return i}isEmpty(){return mi(this.items_)}clear(){this.rbush_.clear(),this.items_={}}getExtent(t){const e=this.rbush_.toJSON();return Ke(e.minX,e.minY,e.maxX,e.maxY,t)}concat(t){this.rbush_.load(t.rbush_.all());for(const e in t.items_)this.items_[e]=t.items_[e]}}const Nn=pl,Rt={ADDFEATURE:"addfeature",CHANGEFEATURE:"changefeature",CLEAR:"clear",REMOVEFEATURE:"removefeature",FEATURESLOADSTART:"featuresloadstart",FEATURESLOADEND:"featuresloadend",FEATURESLOADERROR:"featuresloaderror"};function xl(n,t){return[[-1/0,-1/0,1/0,1/0]]}let yl=!1;function vl(n,t,e,i,s,r,o){const a=new XMLHttpRequest;a.open("GET",typeof n=="function"?n(e,i,s):n,!0),t.getType()=="arraybuffer"&&(a.responseType="arraybuffer"),a.withCredentials=yl,a.onload=function(l){if(!a.status||a.status>=200&&a.status<300){const h=t.getType();let c;h=="json"||h=="text"?c=a.responseText:h=="xml"?(c=a.responseXML,c||(c=new DOMParser().parseFromString(a.responseText,"application/xml"))):h=="arraybuffer"&&(c=a.response),c?r(t.readFeatures(c,{extent:e,featureProjection:s}),t.readProjection(c)):o()}else o()},a.onerror=o,a.send()}function Ns(n,t){return function(e,i,s,r,o){const a=this;vl(n,t,e,i,s,function(l,h){a.addFeatures(l),r!==void 0&&r(l)},o||_i)}}class ee extends ti{constructor(t,e,i){super(t),this.feature=e,this.features=i}}class Sl extends Wa{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_=_i,this.format_=t.format,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&&(ft(this.format_,7),this.loader_=Ns(this.url_,this.format_)),this.strategy_=t.strategy!==void 0?t.strategy:xl;const e=t.useSpatialIndex!==void 0?t.useSpatialIndex:!0;this.featuresRtree_=e?new Nn:null,this.loadedExtentsRtree_=new Nn,this.loadingExtentsCount_=0,this.nullGeometryFeatures_={},this.idIndex_={},this.uidIndex_={},this.featureChangeKeys_={},this.featuresCollection_=null;let i,s;Array.isArray(t.features)?s=t.features:t.features&&(i=t.features,s=i.getArray()),!e&&i===void 0&&(i=new Bn(s)),s!==void 0&&this.addFeaturesInternal(s),i!==void 0&&this.bindFeaturesCollection_(i)}addFeature(t){this.addFeatureInternal(t),this.changed()}addFeatureInternal(t){const e=nt(t);if(!this.addToIndex_(e,t)){this.featuresCollection_&&this.featuresCollection_.remove(t);return}this.setupChangeEvents_(e,t);const i=t.getGeometry();if(i){const s=i.getExtent();this.featuresRtree_&&this.featuresRtree_.insert(s,t)}else this.nullGeometryFeatures_[e]=t;this.dispatchEvent(new ee(Rt.ADDFEATURE,t))}setupChangeEvents_(t,e){this.featureChangeKeys_[t]=[zt(e,vt.CHANGE,this.handleFeatureChange_,this),zt(e,pr.PROPERTYCHANGE,this.handleFeatureChange_,this)]}addToIndex_(t,e){let i=!0;const s=e.getId();return s!==void 0&&(s.toString()in this.idIndex_?i=!1:this.idIndex_[s.toString()]=e),i&&(ft(!(t in this.uidIndex_),30),this.uidIndex_[t]=e),i}addFeatures(t){this.addFeaturesInternal(t),this.changed()}addFeaturesInternal(t){const e=[],i=[],s=[];for(let r=0,o=t.length;r<o;r++){const a=t[r],l=nt(a);this.addToIndex_(l,a)&&i.push(a)}for(let r=0,o=i.length;r<o;r++){const a=i[r],l=nt(a);this.setupChangeEvents_(l,a);const h=a.getGeometry();if(h){const c=h.getExtent();e.push(c),s.push(a)}else this.nullGeometryFeatures_[l]=a}if(this.featuresRtree_&&this.featuresRtree_.load(e,s),this.hasListener(Rt.ADDFEATURE))for(let r=0,o=i.length;r<o;r++)this.dispatchEvent(new ee(Rt.ADDFEATURE,i[r]))}bindFeaturesCollection_(t){let e=!1;this.addEventListener(Rt.ADDFEATURE,function(i){e||(e=!0,t.push(i.feature),e=!1)}),this.addEventListener(Rt.REMOVEFEATURE,function(i){e||(e=!0,t.remove(i.feature),e=!1)}),t.addEventListener(oe.ADD,i=>{e||(e=!0,this.addFeature(i.element),e=!1)}),t.addEventListener(oe.REMOVE,i=>{e||(e=!0,this.removeFeature(i.element),e=!1)}),this.featuresCollection_=t}clear(t){if(t){for(const i in this.featureChangeKeys_)this.featureChangeKeys_[i].forEach(Vt);this.featuresCollection_||(this.featureChangeKeys_={},this.idIndex_={},this.uidIndex_={})}else if(this.featuresRtree_){const i=s=>{this.removeFeatureInternal(s)};this.featuresRtree_.forEach(i);for(const s in this.nullGeometryFeatures_)this.removeFeatureInternal(this.nullGeometryFeatures_[s])}this.featuresCollection_&&this.featuresCollection_.clear(),this.featuresRtree_&&this.featuresRtree_.clear(),this.nullGeometryFeatures_={};const e=new ee(Rt.CLEAR);this.dispatchEvent(e),this.changed()}forEachFeature(t){if(this.featuresRtree_)return this.featuresRtree_.forEach(t);this.featuresCollection_&&this.featuresCollection_.forEach(t)}forEachFeatureAtCoordinateDirect(t,e){const i=[t[0],t[1],t[0],t[1]];return this.forEachFeatureInExtent(i,function(s){if(s.getGeometry().intersectsCoordinate(t))return e(s)})}forEachFeatureInExtent(t,e){if(this.featuresRtree_)return this.featuresRtree_.forEachInExtent(t,e);this.featuresCollection_&&this.featuresCollection_.forEach(e)}forEachFeatureIntersectingExtent(t,e){return this.forEachFeatureInExtent(t,function(i){if(i.getGeometry().intersectsExtent(t)){const r=e(i);if(r)return r}})}getFeaturesCollection(){return this.featuresCollection_}getFeatures(){let t;return this.featuresCollection_?t=this.featuresCollection_.getArray().slice(0):this.featuresRtree_&&(t=this.featuresRtree_.getAll(),mi(this.nullGeometryFeatures_)||Zn(t,Object.values(this.nullGeometryFeatures_))),t}getFeaturesAtCoordinate(t){const e=[];return this.forEachFeatureAtCoordinateDirect(t,function(i){e.push(i)}),e}getFeaturesInExtent(t,e){if(this.featuresRtree_){if(!(e&&e.canWrapX()&&this.getWrapX()))return this.featuresRtree_.getInExtent(t);const s=sa(t,e);return[].concat(...s.map(r=>this.featuresRtree_.getInExtent(r)))}return this.featuresCollection_?this.featuresCollection_.getArray().slice(0):[]}getClosestFeatureToCoordinate(t,e){const i=t[0],s=t[1];let r=null;const o=[NaN,NaN];let a=1/0;const l=[-1/0,-1/0,1/0,1/0];return e=e||yr,this.featuresRtree_.forEachInExtent(l,function(h){if(e(h)){const c=h.getGeometry(),u=a;if(a=c.closestPointXY(i,s,o,a),a<u){r=h;const d=Math.sqrt(a);l[0]=i-d,l[1]=s-d,l[2]=i+d,l[3]=s+d}}}),r}getExtent(t){return this.featuresRtree_.getExtent(t)}getFeatureById(t){const e=this.idIndex_[t.toString()];return e!==void 0?e:null}getFeatureByUid(t){const e=this.uidIndex_[t];return e!==void 0?e:null}getFormat(){return this.format_}getOverlaps(){return this.overlaps_}getUrl(){return this.url_}handleFeatureChange_(t){const e=t.target,i=nt(e),s=e.getGeometry();if(!s)i in this.nullGeometryFeatures_||(this.featuresRtree_&&this.featuresRtree_.remove(e),this.nullGeometryFeatures_[i]=e);else{const o=s.getExtent();i in this.nullGeometryFeatures_?(delete this.nullGeometryFeatures_[i],this.featuresRtree_&&this.featuresRtree_.insert(o,e)):this.featuresRtree_&&this.featuresRtree_.update(o,e)}const r=e.getId();if(r!==void 0){const o=r.toString();this.idIndex_[o]!==e&&(this.removeFromIdIndex_(e),this.idIndex_[o]=e)}else this.removeFromIdIndex_(e),this.uidIndex_[i]=e;this.changed(),this.dispatchEvent(new ee(Rt.CHANGEFEATURE,e))}hasFeature(t){const e=t.getId();return e!==void 0?e in this.idIndex_:nt(t)in this.uidIndex_}isEmpty(){return this.featuresRtree_?this.featuresRtree_.isEmpty()&&mi(this.nullGeometryFeatures_):this.featuresCollection_?this.featuresCollection_.getLength()===0:!0}loadFeatures(t,e,i){const s=this.loadedExtentsRtree_,r=this.strategy_(t,e,i);for(let o=0,a=r.length;o<a;++o){const l=r[o];s.forEachInExtent(l,function(c){return ze(c.extent,l)})||(++this.loadingExtentsCount_,this.dispatchEvent(new ee(Rt.FEATURESLOADSTART)),this.loader_.call(this,l,e,i,c=>{--this.loadingExtentsCount_,this.dispatchEvent(new ee(Rt.FEATURESLOADEND,void 0,c))},()=>{--this.loadingExtentsCount_,this.dispatchEvent(new ee(Rt.FEATURESLOADERROR))}),s.insert(l,{extent:l.slice()}))}this.loading=this.loader_.length<4?!1:this.loadingExtentsCount_>0}refresh(){this.clear(!0),this.loadedExtentsRtree_.clear(),super.refresh()}removeLoadedExtent(t){const e=this.loadedExtentsRtree_;let i;e.forEachInExtent(t,function(s){if(Mr(s.extent,t))return i=s,!0}),i&&e.remove(i)}removeFeature(t){if(!t)return;const e=nt(t);e in this.nullGeometryFeatures_?delete this.nullGeometryFeatures_[e]:this.featuresRtree_&&this.featuresRtree_.remove(t),this.removeFeatureInternal(t)&&this.changed()}removeFeatureInternal(t){const e=nt(t),i=this.featureChangeKeys_[e];if(!i)return;i.forEach(Vt),delete this.featureChangeKeys_[e];const s=t.getId();return s!==void 0&&delete this.idIndex_[s.toString()],delete this.uidIndex_[e],this.dispatchEvent(new ee(Rt.REMOVEFEATURE,t)),t}removeFromIdIndex_(t){let e=!1;for(const i in this.idIndex_)if(this.idIndex_[i]===t){delete this.idIndex_[i],e=!0;break}return e}setLoader(t){this.loader_=t}setUrl(t){ft(this.format_,7),this.url_=t,this.setLoader(Ns(t,this.format_))}}const Hr=Sl,$={OPACITY:"opacity",VISIBLE:"visible",EXTENT:"extent",Z_INDEX:"zIndex",MAX_RESOLUTION:"maxResolution",MIN_RESOLUTION:"minResolution",MAX_ZOOM:"maxZoom",MIN_ZOOM:"minZoom",SOURCE:"source",MAP:"map"};class Cl extends ue{constructor(t){super(),this.on,this.once,this.un,this.background_=t.background;const e=Object.assign({},t);typeof t.properties=="object"&&(delete e.properties,Object.assign(e,t.properties)),e[$.OPACITY]=t.opacity!==void 0?t.opacity:1,ft(typeof e[$.OPACITY]=="number",64),e[$.VISIBLE]=t.visible!==void 0?t.visible:!0,e[$.Z_INDEX]=t.zIndex,e[$.MAX_RESOLUTION]=t.maxResolution!==void 0?t.maxResolution:1/0,e[$.MIN_RESOLUTION]=t.minResolution!==void 0?t.minResolution:0,e[$.MIN_ZOOM]=t.minZoom!==void 0?t.minZoom:-1/0,e[$.MAX_ZOOM]=t.maxZoom!==void 0?t.maxZoom:1/0,this.className_=e.className!==void 0?e.className:"ol-layer",delete e.className,this.setProperties(e),this.state_=null}getBackground(){return this.background_}getClassName(){return this.className_}getLayerState(t){const e=this.state_||{layer:this,managed:t===void 0?!0:t},i=this.getZIndex();return e.opacity=yt(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 tt()}getLayerStatesArray(t){return tt()}getExtent(){return this.get($.EXTENT)}getMaxResolution(){return this.get($.MAX_RESOLUTION)}getMinResolution(){return this.get($.MIN_RESOLUTION)}getMinZoom(){return this.get($.MIN_ZOOM)}getMaxZoom(){return this.get($.MAX_ZOOM)}getOpacity(){return this.get($.OPACITY)}getSourceState(){return tt()}getVisible(){return this.get($.VISIBLE)}getZIndex(){return this.get($.Z_INDEX)}setBackground(t){this.background_=t,this.changed()}setExtent(t){this.set($.EXTENT,t)}setMaxResolution(t){this.set($.MAX_RESOLUTION,t)}setMinResolution(t){this.set($.MIN_RESOLUTION,t)}setMaxZoom(t){this.set($.MAX_ZOOM,t)}setMinZoom(t){this.set($.MIN_ZOOM,t)}setOpacity(t){ft(typeof t=="number",64),this.set($.OPACITY,t)}setVisible(t){this.set($.VISIBLE,t)}setZIndex(t){this.set($.Z_INDEX,t)}disposeInternal(){this.state_&&(this.state_.layer=null,this.state_=null),super.disposeInternal()}}const El=Cl,Xn={PRERENDER:"prerender",POSTRENDER:"postrender",PRECOMPOSE:"precompose",POSTCOMPOSE:"postcompose",RENDERCOMPLETE:"rendercomplete"},Mt={ANIMATING:0,INTERACTING:1},bt={CENTER:"center",RESOLUTION:"resolution",ROTATION:"rotation"};function Xs(n,t,e){return function(i,s,r,o,a){if(!i)return;if(!s&&!t)return i;const l=t?0:r[0]*s,h=t?0:r[1]*s,c=a?a[0]:0,u=a?a[1]:0;let d=n[0]+l/2+c,f=n[2]-l/2+c,g=n[1]+h/2+u,_=n[3]-h/2+u;d>f&&(d=(f+d)/2,f=d),g>_&&(g=(_+g)/2,_=g);let p=yt(i[0],d,f),x=yt(i[1],g,_);if(o&&e&&s){const S=30*s;p+=-S*Math.log(1+Math.max(0,d-i[0])/S)+S*Math.log(1+Math.max(0,i[0]-f)/S),x+=-S*Math.log(1+Math.max(0,g-i[1])/S)+S*Math.log(1+Math.max(0,i[1]-_)/S)}return[p,x]}}function Rl(n){return n}function as(n,t,e,i){const s=At(t)/e[0],r=wi(t)/e[1];return i?Math.min(n,Math.max(s,r)):Math.min(n,Math.min(s,r))}function ls(n,t,e){let i=Math.min(n,t);const s=50;return i*=Math.log(1+s*Math.max(0,n/t-1))/s+1,e&&(i=Math.max(i,e),i/=Math.log(1+s*Math.max(0,e/n-1))/s+1),yt(i,e/2,t*2)}function wl(n,t,e,i){return t=t!==void 0?t:!0,function(s,r,o,a){if(s!==void 0){const l=n[0],h=n[n.length-1],c=e?as(l,e,o,i):l;if(a)return t?ls(s,c,h):yt(s,h,c);const u=Math.min(c,s),d=Math.floor(xr(n,u,r));return n[d]>c&&d<n.length-1?n[d+1]:n[d]}}}function Il(n,t,e,i,s,r){return i=i!==void 0?i:!0,e=e!==void 0?e:0,function(o,a,l,h){if(o!==void 0){const c=s?as(t,s,l,r):t;if(h)return i?ls(o,c,e):yt(o,e,c);const u=1e-9,d=Math.ceil(Math.log(t/c)/Math.log(n)-u),f=-a*(.5-u)+.5,g=Math.min(c,o),_=Math.floor(Math.log(t/g)/Math.log(n)+f),p=Math.max(d,_),x=t/Math.pow(n,p);return yt(x,e,c)}}}function Ws(n,t,e,i,s){return e=e!==void 0?e:!0,function(r,o,a,l){if(r!==void 0){const h=i?as(n,i,a,s):n;return!e||!l?yt(r,t,h):ls(r,h,t)}}}function Ml(n){if(n!==void 0)return 0}function Ys(n){if(n!==void 0)return n}function Al(n){const t=2*Math.PI/n;return function(e,i){if(i)return e;if(e!==void 0)return e=Math.floor(e/t+.5)*t,e}}function Ll(n){return n=n||Me(5),function(t,e){if(e)return t;if(t!==void 0)return Math.abs(t)<=n?0:t}}function zs(n,t,e,i,s,r,o){const a=n[t],l=n[t+1],h=n[e]-a,c=n[e+1]-l;let u;if(h===0&&c===0)u=t;else{const d=((s-a)*h+(r-l)*c)/(h*h+c*c);if(d>1)u=e;else if(d>0){for(let f=0;f<i;++f)o[f]=wt(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 hs(n,t,e,i,s){let r=n[t],o=n[t+1];for(t+=i;t<e;t+=i){const a=n[t],l=n[t+1],h=je(r,o,a,l);h>s&&(s=h),r=a,o=l}return s}function bl(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r){const a=e[r];s=hs(n,t,a,i,s),t=a}return s}function cs(n,t,e,i,s,r,o,a,l,h,c){if(t==e)return h;let u,d;if(s===0){if(d=je(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(zs(n,f-i,f,i,o,a,c),d=je(o,a,c[0],c[1]),d<h){for(h=d,u=0;u<i;++u)l[u]=c[u];l.length=i,f+=i}else f+=i*Math.max((Math.sqrt(d)-Math.sqrt(h))/s|0,1);if(r&&(zs(n,e-i,t,i,o,a,c),d=je(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 Tl(n,t,e,i,s,r,o,a,l,h,c){c=c||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){const f=e[u];h=cs(n,t,f,i,s,r,o,a,l,h,c),t=f}return h}function qr(n,t,e,i,s,r,o){const a=(e-t)/i;if(a<3){for(;t<e;t+=i)r[o++]=n[t],r[o++]=n[t+1];return o}const l=new Array(a);l[0]=1,l[a-1]=1;const h=[t,e-i];let c=0;for(;h.length>0;){const u=h.pop(),d=h.pop();let f=0;const g=n[d],_=n[d+1],p=n[u],x=n[u+1];for(let S=d+i;S<u;S+=i){const I=n[S],D=n[S+1],T=Co(I,D,g,_,p,x);T>f&&(c=S,f=T)}f>s&&(l[(c-t)/i]=1,d+i<c&&h.push(d,c),c+i<u&&h.push(c,u))}for(let u=0;u<a;++u)l[u]&&(r[o++]=n[t+u*i],r[o++]=n[t+u*i+1]);return o}function Ce(n,t){return t*Math.round(n/t)}function Dl(n,t,e,i,s,r,o){if(t==e)return o;let a=Ce(n[t],s),l=Ce(n[t+1],s);t+=i,r[o++]=a,r[o++]=l;let h,c;do if(h=Ce(n[t],s),c=Ce(n[t+1],s),t+=i,t==e)return r[o++]=h,r[o++]=c,o;while(h==a&&c==l);for(;t<e;){const u=Ce(n[t],s),d=Ce(n[t+1],s);if(t+=i,u==h&&d==c)continue;const f=h-a,g=c-l,_=u-a,p=d-l;if(f*p==g*_&&(f<0&&_<f||f==_||f>0&&_>f)&&(g<0&&p<g||g==p||g>0&&p>g)){h=u,c=d;continue}r[o++]=h,r[o++]=c,a=h,l=c,h=u,c=d}return r[o++]=h,r[o++]=c,o}function kl(n,t,e,i,s,r,o,a){for(let l=0,h=e.length;l<h;++l){const c=e[l];o=Dl(n,t,c,i,s,r,o),a.push(o),t=c}return o}function we(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=t;o<e;o+=i)s[r++]=n.slice(o,o+i);return s.length=r,s}function rn(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=e[o];s[r++]=we(n,t,l,i,s[r]),t=l}return s.length=r,s}function Vs(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=e[o];s[r++]=l.length===1&&l[0]===t?[]:rn(n,t,l,i,s[r]),t=l[l.length-1]}return s.length=r,s}function Kr(n,t,e,i){let s=0,r=n[e-i],o=n[e-i+1];for(;t<e;t+=i){const a=n[t],l=n[t+1];s+=o*a-r*l,r=a,o=l}return s/2}function Fl(n,t,e,i){let s=0;for(let r=0,o=e.length;r<o;++r){const a=e[r];s+=Kr(n,t,a,i),t=a}return s}class on extends un{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 on(this.flatCoordinates.slice(),this.layout)}closestPointXY(t,e,i,s){return s<Kn(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(hs(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),cs(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!0,t,e,i,s))}getArea(){return Kr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinates(){return we(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getSimplifiedGeometryInternal(t){const e=[];return e.length=qr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new on(e,"XY")}getType(){return"LinearRing"}intersectsExtent(t){return!1}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=rs(this.flatCoordinates,0,t,this.stride),this.changed()}}const Zs=on;function Ol(n,t,e,i,s,r,o){let a,l,h,c,u,d,f;const g=s[r+1],_=[];for(let S=0,I=e.length;S<I;++S){const D=e[S];for(c=n[D-i],d=n[D-i+1],a=t;a<D;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,_.push(h)),c=u,d=f}let p=NaN,x=-1/0;for(_.sort(gi),c=_[0],a=1,l=_.length;a<l;++a){u=_[a];const S=Math.abs(u-c);S>x&&(h=(c+u)/2,Vr(n,t,e,i,h,g)&&(p=h,x=S)),c=u}return isNaN(p)&&(p=s[r]),o?(o.push(p,g,x),o):[p,g,x]}function Pl(n,t,e,i){for(;t<e-i;){for(let s=0;s<i;++s){const r=n[t+s];n[t+s]=n[e-i+s],n[e-i+s]=r}t+=i,e-=i}}function Jr(n,t,e,i){let s=0,r=n[e-i],o=n[e-i+1];for(;t<e;t+=i){const a=n[t],l=n[t+1];s+=(a-r)*(l+o),r=a,o=l}return s===0?void 0:s>0}function Gl(n,t,e,i,s){s=s!==void 0?s:!1;for(let r=0,o=e.length;r<o;++r){const a=e[r],l=Jr(n,t,a,i);if(r===0){if(s&&l||!s&&!l)return!1}else if(s&&!l||!s&&l)return!1;t=a}return!0}function js(n,t,e,i,s){s=s!==void 0?s:!1;for(let r=0,o=e.length;r<o;++r){const a=e[r],l=Jr(n,t,a,i);(r===0?s&&l||!s&&!l:s&&!l||!s&&l)&&Pl(n,t,a,i),t=a}return t}class an extends un{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?Zn(this.flatCoordinates,t.getFlatCoordinates()):this.flatCoordinates=t.getFlatCoordinates().slice(),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){const t=new an(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,s){return s<Kn(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(bl(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),Tl(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!0,t,e,i,s))}containsXY(t,e){return Vr(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,e)}getArea(){return Fl(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),js(e,0,this.ends_,this.stride,t)):e=this.flatCoordinates,rn(e,0,this.ends_,this.stride)}getEnds(){return this.ends_}getFlatInteriorPoint(){if(this.flatInteriorPointRevision_!=this.getRevision()){const t=Ri(this.getExtent());this.flatInteriorPoint_=Ol(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,0),this.flatInteriorPointRevision_=this.getRevision()}return this.flatInteriorPoint_}getInteriorPoint(){return new Ai(this.getFlatInteriorPoint(),"XYM")}getLinearRingCount(){return this.ends_.length}getLinearRing(t){return t<0||this.ends_.length<=t?null:new Zs(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLinearRings(){const t=this.layout,e=this.flatCoordinates,i=this.ends_,s=[];let r=0;for(let o=0,a=i.length;o<a;++o){const l=i[o],h=new Zs(e.slice(r,l),t);s.push(h),r=l}return s}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){const t=this.flatCoordinates;Gl(t,0,this.ends_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=js(this.orientedFlatCoordinates_,0,this.ends_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){const e=[],i=[];return e.length=kl(this.flatCoordinates,0,this.ends_,this.stride,Math.sqrt(t),e,0,i),new an(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=[]);const i=ll(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}}function Us(n){const t=n[0],e=n[1],i=n[2],s=n[3],r=[t,e,t,s,i,s,i,e,t,e];return new an(r,"XY",[r.length])}const Mn=0;class Bl extends ue{constructor(t){super(),this.on,this.once,this.un,t=Object.assign({},t),this.hints_=[0,0],this.animations_=[],this.updateAnimationKey_,this.projection_=es(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&&ka(),t.center&&(t.center=xt(t.center,this.projection_)),t.extent&&(t.extent=Ze(t.extent,this.projection_)),this.applyOptions_(t)}applyOptions_(t){const e=Object.assign({},t);for(const a in bt)delete e[a];this.setProperties(e,!0);const i=Xl(t);this.maxResolution_=i.maxResolution,this.minResolution_=i.minResolution,this.zoomFactor_=i.zoomFactor,this.resolutions_=t.resolutions,this.padding_=t.padding,this.minZoom_=i.minZoom;const s=Nl(t),r=i.constraint,o=Wl(t);this.constraints_={center:s,resolution:r,rotation:o},this.setRotation(t.rotation!==void 0?t.rotation:0),this.setCenterInternal(t.center!==void 0?t.center:null),t.resolution!==void 0?this.setResolution(t.resolution):t.zoom!==void 0&&this.setZoom(t.zoom)}get padding(){return this.padding_}set padding(t){let e=this.padding_;this.padding_=t;const i=this.getCenterInternal();if(i){const s=t||[0,0,0,0];e=e||[0,0,0,0];const r=this.getResolution(),o=r/2*(s[3]-e[3]+e[1]-s[1]),a=r/2*(s[0]-e[0]+e[2]-s[2]);this.setCenterInternal([i[0]+o,i[1]-a])}}getUpdatedOptions_(t){const e=this.getProperties();return e.resolution!==void 0?e.resolution=this.getResolution():e.zoom=this.getZoom(),e.center=this.getCenterInternal(),e.rotation=this.getRotation(),Object.assign({},e,t)}animate(t){this.isDef()&&!this.getAnimating()&&this.resolveConstraints(0);const e=new Array(arguments.length);for(let i=0;i<e.length;++i){let s=arguments[i];s.center&&(s=Object.assign({},s),s.center=xt(s.center,this.getProjection())),s.anchor&&(s=Object.assign({},s),s.anchor=xt(s.anchor,this.getProjection())),e[i]=s}this.animateInternal.apply(this,e)}animateInternal(t){let e=arguments.length,i;e>1&&typeof arguments[e-1]=="function"&&(i=arguments[e-1],--e);let s=0;for(;s<e&&!this.isDef();++s){const c=arguments[s];c.center&&this.setCenterInternal(c.center),c.zoom!==void 0?this.setZoom(c.zoom):c.resolution&&this.setResolution(c.resolution),c.rotation!==void 0&&this.setRotation(c.rotation)}if(s===e){i&&Ui(i,!0);return}let r=Date.now(),o=this.targetCenter_.slice(),a=this.targetResolution_,l=this.targetRotation_;const h=[];for(;s<e;++s){const c=arguments[s],u={start:r,complete:!1,anchor:c.anchor,duration:c.duration!==void 0?c.duration:1e3,easing:c.easing||ga,callback:i};if(c.center&&(u.sourceCenter=o,u.targetCenter=c.center.slice(),o=u.targetCenter),c.zoom!==void 0?(u.sourceResolution=a,u.targetResolution=this.getResolutionForZoom(c.zoom),a=u.targetResolution):c.resolution&&(u.sourceResolution=a,u.targetResolution=c.resolution,a=u.targetResolution),c.rotation!==void 0){u.sourceRotation=l;const d=ps(c.rotation-l+Math.PI,2*Math.PI)-Math.PI;u.targetRotation=l+d,l=u.targetRotation}Yl(u)?u.complete=!0:r+=u.duration,h.push(u)}this.animations_.push(h),this.setHint(Mt.ANIMATING,1),this.updateAnimations_()}getAnimating(){return this.hints_[Mt.ANIMATING]>0}getInteracting(){return this.hints_[Mt.INTERACTING]>0}cancelAnimations(){this.setHint(Mt.ANIMATING,-this.hints_[Mt.ANIMATING]);let t;for(let e=0,i=this.animations_.length;e<i;++e){const s=this.animations_[e];if(s[0].callback&&Ui(s[0].callback,!1),!t)for(let r=0,o=s.length;r<o;++r){const a=s[r];if(!a.complete){t=a.anchor;break}}}this.animations_.length=0,this.cancelAnchor_=t,this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN}updateAnimations_(){if(this.updateAnimationKey_!==void 0&&(cancelAnimationFrame(this.updateAnimationKey_),this.updateAnimationKey_=void 0),!this.getAnimating())return;const t=Date.now();let e=!1;for(let i=this.animations_.length-1;i>=0;--i){const s=this.animations_[i];let r=!0;for(let o=0,a=s.length;o<a;++o){const l=s[o];if(l.complete)continue;const h=t-l.start;let c=l.duration>0?h/l.duration:1;c>=1?(l.complete=!0,c=1):r=!1;const u=l.easing(c);if(l.sourceCenter){const d=l.sourceCenter[0],f=l.sourceCenter[1],g=l.targetCenter[0],_=l.targetCenter[1];this.nextCenter_=l.targetCenter;const p=d+u*(g-d),x=f+u*(_-f);this.targetCenter_=[p,x]}if(l.sourceResolution&&l.targetResolution){const d=u===1?l.targetResolution:l.sourceResolution+u*(l.targetResolution-l.sourceResolution);if(l.anchor){const f=this.getViewportSize_(this.getRotation()),g=this.constraints_.resolution(d,0,f,!0);this.targetCenter_=this.calculateCenterZoom(g,l.anchor)}this.nextResolution_=l.targetResolution,this.targetResolution_=d,this.applyTargetState_(!0)}if(l.sourceRotation!==void 0&&l.targetRotation!==void 0){const d=u===1?ps(l.targetRotation+Math.PI,2*Math.PI)-Math.PI:l.sourceRotation+u*(l.targetRotation-l.sourceRotation);if(l.anchor){const f=this.constraints_.rotation(d,!0);this.targetCenter_=this.calculateCenterRotate(f,l.anchor)}this.nextRotation_=l.targetRotation,this.targetRotation_=d}if(this.applyTargetState_(!0),e=!0,!l.complete)break}if(r){this.animations_[i]=null,this.setHint(Mt.ANIMATING,-1),this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN;const o=s[0].callback;o&&Ui(o,!0)}}this.animations_=this.animations_.filter(Boolean),e&&this.updateAnimationKey_===void 0&&(this.updateAnimationKey_=requestAnimationFrame(this.updateAnimations_.bind(this)))}calculateCenterRotate(t,e){let i;const s=this.getCenterInternal();return s!==void 0&&(i=[s[0]-e[0],s[1]-e[1]],Ia(i,t-this.getRotation()),wa(i,e)),i}calculateCenterZoom(t,e){let i;const s=this.getCenterInternal(),r=this.getResolution();if(s!==void 0&&r!==void 0){const o=e[0]-t*(e[0]-s[0])/r,a=e[1]-t*(e[1]-s[1])/r;i=[o,a]}return i}getViewportSize_(t){const e=this.viewportSize_;if(t){const i=e[0],s=e[1];return[Math.abs(i*Math.cos(t))+Math.abs(s*Math.sin(t)),Math.abs(i*Math.sin(t))+Math.abs(s*Math.cos(t))]}return e}setViewportSize(t){this.viewportSize_=Array.isArray(t)?t.slice():[100,100],this.getAnimating()||this.resolveConstraints(0)}getCenter(){const t=this.getCenterInternal();return t&&Mi(t,this.getProjection())}getCenterInternal(){return this.get(bt.CENTER)}getConstraints(){return this.constraints_}getConstrainResolution(){return this.get("constrainResolution")}getHints(t){return t!==void 0?(t[0]=this.hints_[0],t[1]=this.hints_[1],t):this.hints_.slice()}calculateExtent(t){const e=this.calculateExtentInternal(t);return is(e,this.getProjection())}calculateExtentInternal(t){t=t||this.getViewportSizeMinusPadding_();const e=this.getCenterInternal();ft(e,1);const i=this.getResolution();ft(i!==void 0,2);const s=this.getRotation();return ft(s!==void 0,3),$o(e,i,s,t)}getMaxResolution(){return this.maxResolution_}getMinResolution(){return this.minResolution_}getMaxZoom(){return this.getZoomForResolution(this.minResolution_)}setMaxZoom(t){this.applyOptions_(this.getUpdatedOptions_({maxZoom:t}))}getMinZoom(){return this.getZoomForResolution(this.maxResolution_)}setMinZoom(t){this.applyOptions_(this.getUpdatedOptions_({minZoom:t}))}setConstrainResolution(t){this.applyOptions_(this.getUpdatedOptions_({constrainResolution:t}))}getProjection(){return this.projection_}getResolution(){return this.get(bt.RESOLUTION)}getResolutions(){return this.resolutions_}getResolutionForExtent(t,e){return this.getResolutionForExtentInternal(Ze(t,this.getProjection()),e)}getResolutionForExtentInternal(t,e){e=e||this.getViewportSizeMinusPadding_();const i=At(t)/e[0],s=wi(t)/e[1];return Math.max(i,s)}getResolutionForValueFunction(t){t=t||2;const e=this.getConstrainedResolution(this.maxResolution_),i=this.minResolution_,s=Math.log(e/i)/Math.log(t);return function(r){return e/Math.pow(t,r*s)}}getRotation(){return this.get(bt.ROTATION)}getValueForResolutionFunction(t){const e=Math.log(t||2),i=this.getConstrainedResolution(this.maxResolution_),s=this.minResolution_,r=Math.log(i/s)/e;return function(o){return Math.log(i/o)/e/r}}getViewportSizeMinusPadding_(t){let e=this.getViewportSize_(t);const i=this.padding_;return i&&(e=[e[0]-i[1]-i[3],e[1]-i[0]-i[2]]),e}getState(){const t=this.getProjection(),e=this.getResolution(),i=this.getRotation();let s=this.getCenterInternal();const r=this.padding_;if(r){const o=this.getViewportSizeMinusPadding_();s=An(s,this.getViewportSize_(),[o[0]/2+r[3],o[1]/2+r[0]],e,i)}return{center:s.slice(0),projection:t!==void 0?t:null,resolution:e,nextCenter:this.nextCenter_,nextResolution:this.nextResolution_,nextRotation:this.nextRotation_,rotation:i,zoom:this.getZoom()}}getViewStateAndExtent(){return{viewState:this.getState(),extent:this.calculateExtent()}}getZoom(){let t;const e=this.getResolution();return e!==void 0&&(t=this.getZoomForResolution(e)),t}getZoomForResolution(t){let e=this.minZoom_||0,i,s;if(this.resolutions_){const r=xr(this.resolutions_,t,1);e=r,i=this.resolutions_[r],r==this.resolutions_.length-1?s=2:s=i/this.resolutions_[r+1]}else i=this.maxResolution_,s=this.zoomFactor_;return e+Math.log(i/t)/Math.log(s)}getResolutionForZoom(t){if(this.resolutions_){if(this.resolutions_.length<=1)return 0;const e=yt(Math.floor(t),0,this.resolutions_.length-2),i=this.resolutions_[e]/this.resolutions_[e+1];return this.resolutions_[e]/Math.pow(i,yt(t-e,0,1))}return this.maxResolution_/Math.pow(this.zoomFactor_,t-this.minZoom_)}fit(t,e){let i;if(ft(Array.isArray(t)||typeof t.getSimplifiedGeometry=="function",24),Array.isArray(t)){ft(!ea(t),25);const s=Ze(t,this.getProjection());i=Us(s)}else if(t.getType()==="Circle"){const s=Ze(t.getExtent(),this.getProjection());i=Us(s),i.rotate(this.getRotation(),Ri(s))}else i=t;this.fitInternal(i,e)}rotatedExtentForGeometry(t){const e=this.getRotation(),i=Math.cos(e),s=Math.sin(-e),r=t.getFlatCoordinates(),o=t.getStride();let a=1/0,l=1/0,h=-1/0,c=-1/0;for(let u=0,d=r.length;u<d;u+=o){const f=r[u]*i-r[u+1]*s,g=r[u]*s+r[u+1]*i;a=Math.min(a,f),l=Math.min(l,g),h=Math.max(h,f),c=Math.max(c,g)}return[a,l,h,c]}fitInternal(t,e){e=e||{};let i=e.size;i||(i=this.getViewportSizeMinusPadding_());const s=e.padding!==void 0?e.padding:[0,0,0,0],r=e.nearest!==void 0?e.nearest:!1;let o;e.minResolution!==void 0?o=e.minResolution:e.maxZoom!==void 0?o=this.getResolutionForZoom(e.maxZoom):o=0;const a=this.rotatedExtentForGeometry(t);let l=this.getResolutionForExtentInternal(a,[i[0]-s[1]-s[3],i[1]-s[0]-s[2]]);l=isNaN(l)?o:Math.max(l,o),l=this.getConstrainedResolution(l,r?0:1);const h=this.getRotation(),c=Math.sin(h),u=Math.cos(h),d=Ri(a);d[0]+=(s[1]-s[3])/2*l,d[1]+=(s[0]-s[2])/2*l;const f=d[0]*u-d[1]*c,g=d[1]*u+d[0]*c,_=this.getConstrainedCenter([f,g],l),p=e.callback?e.callback:_i;e.duration!==void 0?this.animateInternal({resolution:l,center:_,duration:e.duration,easing:e.easing},p):(this.targetResolution_=l,this.targetCenter_=_,this.applyTargetState_(!1,!0),Ui(p,!0))}centerOn(t,e,i){this.centerOnInternal(xt(t,this.getProjection()),e,i)}centerOnInternal(t,e,i){this.setCenterInternal(An(t,e,i,this.getResolution(),this.getRotation()))}calculateCenterShift(t,e,i,s){let r;const o=this.padding_;if(o&&t){const a=this.getViewportSizeMinusPadding_(-i),l=An(t,s,[a[0]/2+o[3],a[1]/2+o[0]],e,i);r=[t[0]-l[0],t[1]-l[1]]}return r}isDef(){return!!this.getCenterInternal()&&this.getResolution()!==void 0}adjustCenter(t){const e=Mi(this.targetCenter_,this.getProjection());this.setCenter([e[0]+t[0],e[1]+t[1]])}adjustCenterInternal(t){const e=this.targetCenter_;this.setCenterInternal([e[0]+t[0],e[1]+t[1]])}adjustResolution(t,e){e=e&&xt(e,this.getProjection()),this.adjustResolutionInternal(t,e)}adjustResolutionInternal(t,e){const i=this.getAnimating()||this.getInteracting(),s=this.getViewportSize_(this.getRotation()),r=this.constraints_.resolution(this.targetResolution_*t,0,s,i);e&&(this.targetCenter_=this.calculateCenterZoom(r,e)),this.targetResolution_*=t,this.applyTargetState_()}adjustZoom(t,e){this.adjustResolution(Math.pow(this.zoomFactor_,-t),e)}adjustRotation(t,e){e&&(e=xt(e,this.getProjection())),this.adjustRotationInternal(t,e)}adjustRotationInternal(t,e){const i=this.getAnimating()||this.getInteracting(),s=this.constraints_.rotation(this.targetRotation_+t,i);e&&(this.targetCenter_=this.calculateCenterRotate(s,e)),this.targetRotation_+=t,this.applyTargetState_()}setCenter(t){this.setCenterInternal(t&&xt(t,this.getProjection()))}setCenterInternal(t){this.targetCenter_=t,this.applyTargetState_()}setHint(t,e){return this.hints_[t]+=e,this.changed(),this.hints_[t]}setResolution(t){this.targetResolution_=t,this.applyTargetState_()}setRotation(t){this.targetRotation_=t,this.applyTargetState_()}setZoom(t){this.setResolution(this.getResolutionForZoom(t))}applyTargetState_(t,e){const i=this.getAnimating()||this.getInteracting()||e,s=this.constraints_.rotation(this.targetRotation_,i),r=this.getViewportSize_(s),o=this.constraints_.resolution(this.targetResolution_,0,r,i),a=this.constraints_.center(this.targetCenter_,o,r,i,this.calculateCenterShift(this.targetCenter_,o,s,r));this.get(bt.ROTATION)!==s&&this.set(bt.ROTATION,s),this.get(bt.RESOLUTION)!==o&&(this.set(bt.RESOLUTION,o),this.set("zoom",this.getZoom(),!0)),(!a||!this.get(bt.CENTER)||!Tt(this.get(bt.CENTER),a))&&this.set(bt.CENTER,a),this.getAnimating()&&!t&&this.cancelAnimations(),this.cancelAnchor_=void 0}resolveConstraints(t,e,i){t=t!==void 0?t:200;const s=e||0,r=this.constraints_.rotation(this.targetRotation_),o=this.getViewportSize_(r),a=this.constraints_.resolution(this.targetResolution_,s,o),l=this.constraints_.center(this.targetCenter_,a,o,!1,this.calculateCenterShift(this.targetCenter_,a,r,o));if(t===0&&!this.cancelAnchor_){this.targetResolution_=a,this.targetRotation_=r,this.targetCenter_=l,this.applyTargetState_();return}i=i||(t===0?this.cancelAnchor_:void 0),this.cancelAnchor_=void 0,(this.getResolution()!==a||this.getRotation()!==r||!this.getCenterInternal()||!Tt(this.getCenterInternal(),l))&&(this.getAnimating()&&this.cancelAnimations(),this.animateInternal({rotation:r,center:l,resolution:a,duration:t,easing:fa,anchor:i}))}beginInteraction(){this.resolveConstraints(0),this.setHint(Mt.INTERACTING,1)}endInteraction(t,e,i){i=i&&xt(i,this.getProjection()),this.endInteractionInternal(t,e,i)}endInteractionInternal(t,e,i){!this.getInteracting()||(this.setHint(Mt.INTERACTING,-1),this.resolveConstraints(t,e,i))}getConstrainedCenter(t,e){const i=this.getViewportSize_(this.getRotation());return this.constraints_.center(t,e||this.getResolution(),i)}getConstrainedZoom(t,e){const i=this.getResolutionForZoom(t);return this.getZoomForResolution(this.getConstrainedResolution(i,e))}getConstrainedResolution(t,e){e=e||0;const i=this.getViewportSize_(this.getRotation());return this.constraints_.resolution(t,e,i)}}function Ui(n,t){setTimeout(function(){n(t)},0)}function Nl(n){if(n.extent!==void 0){const e=n.smoothExtentConstraint!==void 0?n.smoothExtentConstraint:!0;return Xs(n.extent,n.constrainOnlyCenter,e)}const t=es(n.projection,"EPSG:3857");if(n.multiWorld!==!0&&t.isGlobal()){const e=t.getExtent().slice();return e[0]=-1/0,e[2]=1/0,Xs(e,!1,!1)}return Rl}function Xl(n){let t,e,i,o=n.minZoom!==void 0?n.minZoom:Mn,a=n.maxZoom!==void 0?n.maxZoom:28;const l=n.zoomFactor!==void 0?n.zoomFactor:2,h=n.multiWorld!==void 0?n.multiWorld:!1,c=n.smoothResolutionConstraint!==void 0?n.smoothResolutionConstraint:!0,u=n.showFullExtent!==void 0?n.showFullExtent:!1,d=es(n.projection,"EPSG:3857"),f=d.getExtent();let g=n.constrainOnlyCenter,_=n.extent;if(!h&&!_&&d.isGlobal()&&(g=!1,_=f),n.resolutions!==void 0){const p=n.resolutions;e=p[o],i=p[a]!==void 0?p[a]:p[p.length-1],n.constrainResolution?t=wl(p,c,!g&&_,u):t=Ws(e,i,c,!g&&_,u)}else{const x=(f?Math.max(At(f),wi(f)):360*Pr.degrees/d.getMetersPerUnit())/Ya/Math.pow(2,Mn),S=x/Math.pow(2,28-Mn);e=n.maxResolution,e!==void 0?o=0:e=x/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=x/Math.pow(l,a):i=S),a=o+Math.floor(Math.log(e/i)/Math.log(l)),i=e/Math.pow(l,a-o),n.constrainResolution?t=Il(l,e,i,c,!g&&_,u):t=Ws(e,i,c,!g&&_,u)}return{constraint:t,maxResolution:e,minResolution:i,minZoom:o,zoomFactor:l}}function Wl(n){if(n.enableRotation!==void 0?n.enableRotation:!0){const e=n.constrainRotation;return e===void 0||e===!0?Ll():e===!1?Ys:typeof e=="number"?Al(e):Ys}return Ml}function Yl(n){return!(n.sourceCenter&&n.targetCenter&&!Tt(n.sourceCenter,n.targetCenter)||n.sourceResolution!==n.targetResolution||n.sourceRotation!==n.targetRotation)}function An(n,t,e,i,s){const r=Math.cos(-s);let o=Math.sin(-s),a=n[0]*r-n[1]*o,l=n[1]*r+n[0]*o;a+=(t[0]/2-e[0])*i,l+=(e[1]-t[1]/2)*i,o=-o;const h=a*r-l*o,c=l*r+a*o;return[h,c]}const Hs=Bl;class zl extends El{constructor(t){const e=Object.assign({},t);delete e.source,super(e),this.on,this.once,this.un,this.mapPrecomposeKey_=null,this.mapRenderKey_=null,this.sourceChangeKey_=null,this.renderer_=null,this.sourceReady_=!1,this.rendered=!1,t.render&&(this.render=t.render),t.map&&this.setMap(t.map),this.addChangeListener($.SOURCE,this.handleSourcePropertyChange_);const i=t.source?t.source:null;this.setSource(i)}getLayersArray(t){return t=t||[],t.push(this),t}getLayerStatesArray(t){return t=t||[],t.push(this.getLayerState()),t}getSource(){return this.get($.SOURCE)||null}getRenderSource(){return this.getSource()}getSourceState(){const t=this.getSource();return t?t.getState():"undefined"}handleSourceChange_(){this.changed(),!(this.sourceReady_||this.getSource().getState()!=="ready")&&(this.sourceReady_=!0,this.dispatchEvent("sourceready"))}handleSourcePropertyChange_(){this.sourceChangeKey_&&(Vt(this.sourceChangeKey_),this.sourceChangeKey_=null),this.sourceReady_=!1;const t=this.getSource();t&&(this.sourceChangeKey_=zt(t,vt.CHANGE,this.handleSourceChange_,this),t.getState()==="ready"&&(this.sourceReady_=!0,setTimeout(()=>{this.dispatchEvent("sourceready")},0))),this.changed()}getFeatures(t){return this.renderer_?this.renderer_.getFeatures(t):Promise.resolve([])}getData(t){return!this.renderer_||!this.rendered?null:this.renderer_.getData(t)}isVisible(t){let e;const i=this.getMapInternal();!t&&i&&(t=i.getView()),t instanceof Hs?e={viewState:t.getState(),extent:t.calculateExtent()}:e=t,!e.layerStatesArray&&i&&(e.layerStatesArray=i.getLayerGroup().getLayerStatesArray());let s;e.layerStatesArray?s=e.layerStatesArray.find(o=>o.layer===this):s=this.getLayerState();const r=this.getExtent();return Vl(s,e.viewState)&&(!r||Dt(r,e.extent))}getAttributions(t){if(!this.isVisible(t))return[];let e;const i=this.getSource();if(i&&(e=i.getAttributions()),!e)return[];const s=t instanceof Hs?t.getViewStateAndExtent():t;let r=e(s);return Array.isArray(r)||(r=[r]),r}render(t,e){const i=this.getRenderer();return i.prepareFrame(t)?(this.rendered=!0,i.renderFrame(t,e)):null}unrender(){this.rendered=!1}setMapInternal(t){t||this.unrender(),this.set($.MAP,t)}getMapInternal(){return this.get($.MAP)}setMap(t){this.mapPrecomposeKey_&&(Vt(this.mapPrecomposeKey_),this.mapPrecomposeKey_=null),t||this.changed(),this.mapRenderKey_&&(Vt(this.mapRenderKey_),this.mapRenderKey_=null),t&&(this.mapPrecomposeKey_=zt(t,Xn.PRECOMPOSE,function(e){const s=e.frameState.layerStatesArray,r=this.getLayerState(!1);ft(!s.some(function(o){return o.layer===r.layer}),67),s.push(r)},this),this.mapRenderKey_=zt(this,vt.CHANGE,t.render,t),this.changed())}setSource(t){this.set($.SOURCE,t)}getRenderer(){return this.renderer_||(this.renderer_=this.createRenderer()),this.renderer_}hasRenderer(){return!!this.renderer_}createRenderer(){return null}disposeInternal(){this.renderer_&&(this.renderer_.dispose(),delete this.renderer_),this.setSource(null),super.disposeInternal()}}function Vl(n,t){if(!n.visible)return!1;const e=t.resolution;if(e<n.minResolution||e>=n.maxResolution)return!1;const i=t.zoom;return i>n.minZoom&&i<=n.maxZoom}const Zl=zl;class jl extends Sr{constructor(t){super(),this.ready=!0,this.boundHandleImageChange_=this.handleImageChange_.bind(this),this.layer_=t,this.declutterExecutorGroup=null}getFeatures(t){return tt()}getData(t){return null}prepareFrame(t){return tt()}renderFrame(t,e){return tt()}loadedTileCallback(t,e,i){t[e]||(t[e]={}),t[e][i.tileCoord.toString()]=i}createLoadedTileFinder(t,e,i){return(s,r)=>{const o=this.loadedTileCallback.bind(this,i,s);return t.forEachLoadedTile(e,s,r,o)}}forEachFeatureAtCoordinate(t,e,i,s,r){}getLayer(){return this.layer_}handleFontsChanged(){}handleImageChange_(t){t.target.getState()===ht.LOADED&&this.renderIfReadyAndVisible()}loadImage(t){let e=t.getState();return e!=ht.LOADED&&e!=ht.ERROR&&t.addEventListener(vt.CHANGE,this.boundHandleImageChange_),e==ht.IDLE&&(t.load(),e=t.getState()),e==ht.LOADED}renderIfReadyAndVisible(){const t=this.getLayer();t&&t.getVisible()&&t.getSourceState()==="ready"&&t.changed()}disposeInternal(){delete this.layer_,super.disposeInternal()}}const Ul=jl;class Hl extends ti{constructor(t,e,i,s){super(t),this.inversePixelTransform=e,this.frameState=i,this.context=s}}const ql=Hl,qs=[];let Ye=null;function Kl(){Ye=kt(1,1,void 0,{willReadFrequently:!0})}class Jl extends Ul{constructor(t){super(t),this.container=null,this.renderedResolution,this.tempTransform=he(),this.pixelTransform=he(),this.inversePixelTransform=he(),this.context=null,this.containerReused=!1,this.pixelContext_=null,this.frameState=null}getImageData(t,e,i){Ye||Kl(),Ye.clearRect(0,0,1,1);let s;try{Ye.drawImage(t,e,i,1,1,0,0,1,1),s=Ye.getImageData(0,0,1,1).data}catch{return Ye=null,null}return s}getBackground(t){let i=this.getLayer().getBackground();return typeof i=="function"&&(i=i(t.viewState.resolution)),i||void 0}useContainer(t,e,i){const s=this.getLayer().getClassName();let r,o;if(t&&t.className===s&&(!i||t&&t.style.backgroundColor&&be(Ji(t.style.backgroundColor),Ji(i)))){const a=t.firstElementChild;a instanceof HTMLCanvasElement&&(o=a.getContext("2d"))}if(o&&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){r=document.createElement("div"),r.className=s;let a=r.style;a.position="absolute",a.width="100%",a.height="100%",o=kt();const l=o.canvas;r.appendChild(l),a=l.style,a.position="absolute",a.left="0",a.transformOrigin="top left",this.container=r,this.context=o}!this.containerReused&&i&&!this.container.style.backgroundColor&&(this.container.style.backgroundColor=i)}clipUnrotated(t,e,i){const s=Dr(i),r=kr(i),o=Tr(i),a=br(i);St(e.coordinateToPixelTransform,s),St(e.coordinateToPixelTransform,r),St(e.coordinateToPixelTransform,o),St(e.coordinateToPixelTransform,a);const l=this.inversePixelTransform;St(l,s),St(l,r),St(l,o),St(l,a),t.save(),t.beginPath(),t.moveTo(Math.round(s[0]),Math.round(s[1])),t.lineTo(Math.round(r[0]),Math.round(r[1])),t.lineTo(Math.round(o[0]),Math.round(o[1])),t.lineTo(Math.round(a[0]),Math.round(a[1])),t.clip()}dispatchRenderEvent_(t,e,i){const s=this.getLayer();if(s.hasListener(t)){const r=new ql(t,this.inversePixelTransform,i,e);s.dispatchEvent(r)}}preRender(t,e){this.frameState=e,this.dispatchRenderEvent_(Xn.PRERENDER,t,e)}postRender(t,e){this.dispatchRenderEvent_(Xn.POSTRENDER,t,e)}getRenderTransform(t,e,i,s,r,o,a){const l=r/2,h=o/2,c=s/e,u=-c,d=-t[0]+a,f=-t[1];return Di(this.tempTransform,l,h,c,u,-i,d,f)}disposeInternal(){delete this.frameState,super.disposeInternal()}}const Ql=Jl;function $l(n,t,e,i,s,r,o){let a,l;const h=(e-t)/i;if(h===1)a=t;else if(h===2)a=t,l=s;else if(h!==0){let c=n[t],u=n[t+1],d=0;const f=[0];for(let p=t+i;p<e;p+=i){const x=n[p],S=n[p+1];d+=Math.sqrt((x-c)*(x-c)+(S-u)*(S-u)),f.push(d),c=x,u=S}const g=s*d,_=Oo(f,g);_<0?(l=(g-f[-_-2])/(f[-_-1]-f[-_-2]),a=t+(-_-2)*i):a=t+_*i}o=o>1?o:2,r=r||new Array(o);for(let c=0;c<o;++c)r[c]=a===void 0?NaN:l===void 0?n[a+c]:wt(n[a+c],n[a+i+c],l);return r}function th(n,t,e,i,s,r){if(e==t)return null;let o;if(s<n[t+i-1])return r?(o=n.slice(t,t+i),o[i-1]=s,o):null;if(n[e-1]<s)return r?(o=n.slice(e-i,e),o[i-1]=s,o):null;if(s==n[t+i-1])return n.slice(t,t+i);let a=t/i,l=e/i;for(;a<l;){const d=a+l>>1;s<n[(d+1)*i-1]?l=d:a=d+1}const h=n[a*i-1];if(s==h)return n.slice((a-1)*i,(a-1)*i+i);const c=n[(a+1)*i-1],u=(s-h)/(c-h);o=[];for(let d=0;d<i-1;++d)o.push(wt(n[(a-1)*i+d],n[a*i+d],u));return o.push(s),o}function Qr(n,t,e,i){let s=n[t],r=n[t+1],o=0;for(let a=t+i;a<e;a+=i){const l=n[a],h=n[a+1];o+=Math.sqrt((l-s)*(l-s)+(h-r)*(h-r)),s=l,r=h}return o}class ln extends un{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){this.flatCoordinates?Zn(this.flatCoordinates,t):this.flatCoordinates=t.slice(),this.changed()}clone(){const t=new ln(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,s){return s<Kn(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(hs(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),cs(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!1,t,e,i,s))}forEachSegment(t){return zr(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,th(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e))}getCoordinates(){return we(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinateAt(t,e){return $l(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,this.stride)}getLength(){return Qr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getFlatMidpoint(){return this.flatMidpointRevision_!=this.getRevision()&&(this.flatMidpoint_=this.getCoordinateAt(.5,this.flatMidpoint_),this.flatMidpointRevision_=this.getRevision()),this.flatMidpoint_}getSimplifiedGeometryInternal(t){const e=[];return e.length=qr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new ln(e,"XY")}getType(){return"LineString"}intersectsExtent(t){return ns(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=rs(this.flatCoordinates,0,t,this.stride),this.changed()}}const Ks=ln;function Js(n){return new se({fill:Li(n,""),stroke:bi(n,""),text:eh(n),image:ih(n)})}function Li(n,t){const e=n[t+"fill-color"];if(!!e)return new mt({color:e})}function bi(n,t){const e=n[t+"stroke-width"],i=n[t+"stroke-color"];if(!(!e&&!i))return new le({width:e,color:i,lineCap:n[t+"stroke-line-cap"],lineJoin:n[t+"stroke-line-join"],lineDash:n[t+"stroke-line-dash"],lineDashOffset:n[t+"stroke-line-dash-offset"],miterLimit:n[t+"stroke-miter-limit"]})}function eh(n){const t=n["text-value"];return t?new hi({text:t,font:n["text-font"],maxAngle:n["text-max-angle"],offsetX:n["text-offset-x"],offsetY:n["text-offset-y"],overflow:n["text-overflow"],placement:n["text-placement"],repeat:n["text-repeat"],scale:n["text-scale"],rotateWithView:n["text-rotate-with-view"],rotation:n["text-rotation"],textAlign:n["text-align"],justify:n["text-justify"],textBaseline:n["text-baseline"],padding:n["text-padding"],fill:Li(n,"text-"),backgroundFill:Li(n,"text-background-"),stroke:bi(n,"text-"),backgroundStroke:bi(n,"text-background-")}):void 0}function ih(n){const t=n["icon-src"],e=n["icon-img"];if(t||e)return new Or({src:t,img:e,imgSize:n["icon-img-size"],anchor:n["icon-anchor"],anchorOrigin:n["icon-anchor-origin"],anchorXUnits:n["icon-anchor-x-units"],anchorYUnits:n["icon-anchor-y-units"],color:n["icon-color"],crossOrigin:n["icon-cross-origin"],offset:n["icon-offset"],displacement:n["icon-displacement"],opacity:n["icon-opacity"],scale:n["icon-scale"],width:n["icon-width"],height:n["icon-height"],rotation:n["icon-rotation"],rotateWithView:n["icon-rotate-with-view"],size:n["icon-size"],declutterMode:n["icon-declutter-mode"]});const i=n["shape-points"];if(i){const r="shape-";return new nn({points:i,fill:Li(n,r),stroke:bi(n,r),radius:n["shape-radius"],radius1:n["shape-radius1"],radius2:n["shape-radius2"],angle:n["shape-angle"],displacement:n["shape-displacement"],rotation:n["shape-rotation"],rotateWithView:n["shape-rotate-with-view"],scale:n["shape-scale"],declutterMode:n["shape-declutter-mode"]})}const s=n["circle-radius"];if(s){const r="circle-";return new Ei({radius:s,fill:Li(n,r),stroke:bi(n,r),displacement:n["circle-displacement"],scale:n["circle-scale"],rotation:n["circle-rotation"],rotateWithView:n["circle-rotate-with-view"],declutterMode:n["circle-declutter-mode"]})}}const Qs={RENDER_ORDER:"renderOrder"};class nh extends Zl{constructor(t){t=t||{};const e=Object.assign({},t);delete e.style,delete e.renderBuffer,delete e.updateWhileAnimating,delete e.updateWhileInteracting,super(e),this.declutter_=t.declutter!==void 0?t.declutter:!1,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(Qs.RENDER_ORDER)}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}getUpdateWhileAnimating(){return this.updateWhileAnimating_}getUpdateWhileInteracting(){return this.updateWhileInteracting_}renderDeclutter(t){t.declutterTree||(t.declutterTree=new Ur(9)),this.getRenderer().renderDeclutter(t)}setRenderOrder(t){this.set(Qs.RENDER_ORDER,t)}setStyle(t){let e;if(t===void 0)e=ha;else if(t===null)e=null;else if(typeof t=="function")e=t;else if(t instanceof se)e=t;else if(Array.isArray(t)){const i=t.length,s=new Array(i);for(let r=0;r<i;++r){const o=t[r];o instanceof se?s[r]=o:s[r]=Js(o)}e=s}else e=Js(t);this.style_=e,this.styleFunction_=t===null?void 0:la(this.style_),this.changed()}}const sh=nh,ki={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},Hi=[ki.FILL],ae=[ki.STROKE],Ie=[ki.BEGIN_PATH],$s=[ki.CLOSE_PATH],G=ki;class rh{drawCustom(t,e,i,s){}drawGeometry(t){}setStyle(t){}drawCircle(t,e){}drawFeature(t,e){}drawGeometryCollection(t,e){}drawLineString(t,e){}drawMultiLineString(t,e){}drawMultiPoint(t,e){}drawMultiPolygon(t,e){}drawPoint(t,e){}drawPolygon(t,e){}drawText(t,e){}setFillStrokeStyle(t,e){}setImageStyle(t,e){}setTextStyle(t,e){}}const $r=rh;class oh extends $r{constructor(t,e,i,s){super(),this.tolerance=t,this.maxExtent=e,this.pixelRatio=s,this.maxLineWidth=0,this.resolution=i,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_=null,this.bufferedMaxExtent_=null,this.instructions=[],this.coordinates=[],this.tmpCoordinate_=[],this.hitDetectionInstructions=[],this.state={}}applyPixelRatio(t){const e=this.pixelRatio;return e==1?t:t.map(function(i){return i*e})}appendFlatPointCoordinates(t,e){const i=this.getBufferedMaxExtent(),s=this.tmpCoordinate_,r=this.coordinates;let o=r.length;for(let a=0,l=t.length;a<l;a+=e)s[0]=t[a],s[1]=t[a+1],qo(i,s)&&(r[o++]=s[0],r[o++]=s[1]);return o}appendFlatLineCoordinates(t,e,i,s,r,o){const a=this.coordinates;let l=a.length;const h=this.getBufferedMaxExtent();o&&(e+=s);let c=t[e],u=t[e+1];const d=this.tmpCoordinate_;let f=!0,g,_,p;for(g=e+s;g<i;g+=s)d[0]=t[g],d[1]=t[g+1],p=On(h,d),p!==_?(f&&(a[l++]=c,a[l++]=u,f=!1),a[l++]=d[0],a[l++]=d[1]):p===pt.INTERSECTING?(a[l++]=d[0],a[l++]=d[1],f=!1):f=!0,c=d[0],u=d[1],_=p;return(r&&f||g===e+s)&&(a[l++]=c,a[l++]=u),l}drawCustomCoordinates_(t,e,i,s,r){for(let o=0,a=i.length;o<a;++o){const l=i[o],h=this.appendFlatLineCoordinates(t,e,l,s,!1,!1);r.push(h),e=l}return e}drawCustom(t,e,i,s){this.beginGeometry(t,e);const r=t.getType(),o=t.getStride(),a=this.coordinates.length;let l,h,c,u,d;switch(r){case"MultiPolygon":l=t.getOrientedFlatCoordinates(),u=[];const f=t.getEndss();d=0;for(let g=0,_=f.length;g<_;++g){const p=[];d=this.drawCustomCoordinates_(l,d,f[g],o,p),u.push(p)}this.instructions.push([G.CUSTOM,a,u,t,i,Vs]),this.hitDetectionInstructions.push([G.CUSTOM,a,u,t,s||i,Vs]);break;case"Polygon":case"MultiLineString":c=[],l=r=="Polygon"?t.getOrientedFlatCoordinates():t.getFlatCoordinates(),d=this.drawCustomCoordinates_(l,0,t.getEnds(),o,c),this.instructions.push([G.CUSTOM,a,c,t,i,rn]),this.hitDetectionInstructions.push([G.CUSTOM,a,c,t,s||i,rn]);break;case"LineString":case"Circle":l=t.getFlatCoordinates(),h=this.appendFlatLineCoordinates(l,0,l.length,o,!1,!1),this.instructions.push([G.CUSTOM,a,h,t,i,we]),this.hitDetectionInstructions.push([G.CUSTOM,a,h,t,s||i,we]);break;case"MultiPoint":l=t.getFlatCoordinates(),h=this.appendFlatPointCoordinates(l,o),h>a&&(this.instructions.push([G.CUSTOM,a,h,t,i,we]),this.hitDetectionInstructions.push([G.CUSTOM,a,h,t,s||i,we]));break;case"Point":l=t.getFlatCoordinates(),this.coordinates.push(l[0],l[1]),h=this.coordinates.length,this.instructions.push([G.CUSTOM,a,h,t,i]),this.hitDetectionInstructions.push([G.CUSTOM,a,h,t,s||i]);break}this.endGeometry(e)}beginGeometry(t,e){this.beginGeometryInstruction1_=[G.BEGIN_GEOMETRY,e,0,t],this.instructions.push(this.beginGeometryInstruction1_),this.beginGeometryInstruction2_=[G.BEGIN_GEOMETRY,e,0,t],this.hitDetectionInstructions.push(this.beginGeometryInstruction2_)}finish(){return{instructions:this.instructions,hitDetectionInstructions:this.hitDetectionInstructions,coordinates:this.coordinates}}reverseHitDetectionInstructions(){const t=this.hitDetectionInstructions;t.reverse();let e;const i=t.length;let s,r,o=-1;for(e=0;e<i;++e)s=t[e],r=s[0],r==G.END_GEOMETRY?o=e:r==G.BEGIN_GEOMETRY&&(s[2]=e,Po(this.hitDetectionInstructions,o,e),o=-1)}setFillStrokeStyle(t,e){const i=this.state;if(t){const s=t.getColor();i.fillStyle=Pt(s||Zt)}else i.fillStyle=void 0;if(e){const s=e.getColor();i.strokeStyle=Pt(s||vi);const r=e.getLineCap();i.lineCap=r!==void 0?r:$i;const o=e.getLineDash();i.lineDash=o?o.slice():pi;const a=e.getLineDashOffset();i.lineDashOffset=a||xi;const l=e.getLineJoin();i.lineJoin=l!==void 0?l:qe;const h=e.getWidth();i.lineWidth=h!==void 0?h:Ci;const c=e.getMiterLimit();i.miterLimit=c!==void 0?c:yi,i.lineWidth>this.maxLineWidth&&(this.maxLineWidth=i.lineWidth,this.bufferedMaxExtent_=null)}else i.strokeStyle=void 0,i.lineCap=void 0,i.lineDash=null,i.lineDashOffset=void 0,i.lineJoin=void 0,i.lineWidth=void 0,i.miterLimit=void 0}createFill(t){const e=t.fillStyle,i=[G.SET_FILL_STYLE,e];return typeof e!="string"&&i.push(!0),i}applyStroke(t){this.instructions.push(this.createStroke(t))}createStroke(t){return[G.SET_STROKE_STYLE,t.strokeStyle,t.lineWidth*this.pixelRatio,t.lineCap,t.lineJoin,t.miterLimit,this.applyPixelRatio(t.lineDash),t.lineDashOffset*this.pixelRatio]}updateFillStyle(t,e){const i=t.fillStyle;(typeof i!="string"||t.currentFillStyle!=i)&&(i!==void 0&&this.instructions.push(e.call(this,t)),t.currentFillStyle=i)}updateStrokeStyle(t,e){const i=t.strokeStyle,s=t.lineCap,r=t.lineDash,o=t.lineDashOffset,a=t.lineJoin,l=t.lineWidth,h=t.miterLimit;(t.currentStrokeStyle!=i||t.currentLineCap!=s||r!=t.currentLineDash&&!be(t.currentLineDash,r)||t.currentLineDashOffset!=o||t.currentLineJoin!=a||t.currentLineWidth!=l||t.currentMiterLimit!=h)&&(i!==void 0&&e.call(this,t),t.currentStrokeStyle=i,t.currentLineCap=s,t.currentLineDash=r,t.currentLineDashOffset=o,t.currentLineJoin=a,t.currentLineWidth=l,t.currentMiterLimit=h)}endGeometry(t){this.beginGeometryInstruction1_[2]=this.instructions.length,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_[2]=this.hitDetectionInstructions.length,this.beginGeometryInstruction2_=null;const e=[G.END_GEOMETRY,t];this.instructions.push(e),this.hitDetectionInstructions.push(e)}getBufferedMaxExtent(){if(!this.bufferedMaxExtent_&&(this.bufferedMaxExtent_=Ho(this.maxExtent),this.maxLineWidth>0)){const t=this.resolution*(this.maxLineWidth+1)/2;cn(this.bufferedMaxExtent_,t,this.bufferedMaxExtent_)}return this.bufferedMaxExtent_}}const Fi=oh;class ah extends Fi{constructor(t,e,i,s){super(t,e,i,s),this.hitDetectionImage_=null,this.image_=null,this.imagePixelRatio_=void 0,this.anchorX_=void 0,this.anchorY_=void 0,this.height_=void 0,this.opacity_=void 0,this.originX_=void 0,this.originY_=void 0,this.rotateWithView_=void 0,this.rotation_=void 0,this.scale_=void 0,this.width_=void 0,this.declutterMode_=void 0,this.declutterImageWithText_=void 0}drawPoint(t,e){if(!this.image_)return;this.beginGeometry(t,e);const i=t.getFlatCoordinates(),s=t.getStride(),r=this.coordinates.length,o=this.appendFlatPointCoordinates(i,s);this.instructions.push([G.DRAW_IMAGE,r,o,this.image_,this.anchorX_*this.imagePixelRatio_,this.anchorY_*this.imagePixelRatio_,Math.ceil(this.height_*this.imagePixelRatio_),this.opacity_,this.originX_*this.imagePixelRatio_,this.originY_*this.imagePixelRatio_,this.rotateWithView_,this.rotation_,[this.scale_[0]*this.pixelRatio/this.imagePixelRatio_,this.scale_[1]*this.pixelRatio/this.imagePixelRatio_],Math.ceil(this.width_*this.imagePixelRatio_),this.declutterMode_,this.declutterImageWithText_]),this.hitDetectionInstructions.push([G.DRAW_IMAGE,r,o,this.hitDetectionImage_,this.anchorX_,this.anchorY_,this.height_,this.opacity_,this.originX_,this.originY_,this.rotateWithView_,this.rotation_,this.scale_,this.width_,this.declutterMode_,this.declutterImageWithText_]),this.endGeometry(e)}drawMultiPoint(t,e){if(!this.image_)return;this.beginGeometry(t,e);const i=t.getFlatCoordinates(),s=t.getStride(),r=this.coordinates.length,o=this.appendFlatPointCoordinates(i,s);this.instructions.push([G.DRAW_IMAGE,r,o,this.image_,this.anchorX_*this.imagePixelRatio_,this.anchorY_*this.imagePixelRatio_,Math.ceil(this.height_*this.imagePixelRatio_),this.opacity_,this.originX_*this.imagePixelRatio_,this.originY_*this.imagePixelRatio_,this.rotateWithView_,this.rotation_,[this.scale_[0]*this.pixelRatio/this.imagePixelRatio_,this.scale_[1]*this.pixelRatio/this.imagePixelRatio_],Math.ceil(this.width_*this.imagePixelRatio_),this.declutterMode_,this.declutterImageWithText_]),this.hitDetectionInstructions.push([G.DRAW_IMAGE,r,o,this.hitDetectionImage_,this.anchorX_,this.anchorY_,this.height_,this.opacity_,this.originX_,this.originY_,this.rotateWithView_,this.rotation_,this.scale_,this.width_,this.declutterMode_,this.declutterImageWithText_]),this.endGeometry(e)}finish(){return this.reverseHitDetectionInstructions(),this.anchorX_=void 0,this.anchorY_=void 0,this.hitDetectionImage_=null,this.image_=null,this.imagePixelRatio_=void 0,this.height_=void 0,this.scale_=void 0,this.opacity_=void 0,this.originX_=void 0,this.originY_=void 0,this.rotateWithView_=void 0,this.rotation_=void 0,this.width_=void 0,super.finish()}setImageStyle(t,e){const i=t.getAnchor(),s=t.getSize(),r=t.getOrigin();this.imagePixelRatio_=t.getPixelRatio(this.pixelRatio),this.anchorX_=i[0],this.anchorY_=i[1],this.hitDetectionImage_=t.getHitDetectionImage(),this.image_=t.getImage(this.pixelRatio),this.height_=s[1],this.opacity_=t.getOpacity(),this.originX_=r[0],this.originY_=r[1],this.rotateWithView_=t.getRotateWithView(),this.rotation_=t.getRotation(),this.scale_=t.getScaleArray(),this.width_=s[0],this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}}const lh=ah;class hh extends Fi{constructor(t,e,i,s){super(t,e,i,s)}drawFlatCoordinates_(t,e,i,s){const r=this.coordinates.length,o=this.appendFlatLineCoordinates(t,e,i,s,!1,!1),a=[G.MOVE_TO_LINE_TO,r,o];return this.instructions.push(a),this.hitDetectionInstructions.push(a),i}drawLineString(t,e){const i=this.state,s=i.strokeStyle,r=i.lineWidth;if(s===void 0||r===void 0)return;this.updateStrokeStyle(i,this.applyStroke),this.beginGeometry(t,e),this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,i.strokeStyle,i.lineWidth,i.lineCap,i.lineJoin,i.miterLimit,pi,xi],Ie);const o=t.getFlatCoordinates(),a=t.getStride();this.drawFlatCoordinates_(o,0,o.length,a),this.hitDetectionInstructions.push(ae),this.endGeometry(e)}drawMultiLineString(t,e){const i=this.state,s=i.strokeStyle,r=i.lineWidth;if(s===void 0||r===void 0)return;this.updateStrokeStyle(i,this.applyStroke),this.beginGeometry(t,e),this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,i.strokeStyle,i.lineWidth,i.lineCap,i.lineJoin,i.miterLimit,i.lineDash,i.lineDashOffset],Ie);const o=t.getEnds(),a=t.getFlatCoordinates(),l=t.getStride();let h=0;for(let c=0,u=o.length;c<u;++c)h=this.drawFlatCoordinates_(a,h,o[c],l);this.hitDetectionInstructions.push(ae),this.endGeometry(e)}finish(){const t=this.state;return t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&this.instructions.push(ae),this.reverseHitDetectionInstructions(),this.state=null,super.finish()}applyStroke(t){t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&(this.instructions.push(ae),t.lastStroke=this.coordinates.length),t.lastStroke=0,super.applyStroke(t),this.instructions.push(Ie)}}const ch=hh;class uh extends Fi{constructor(t,e,i,s){super(t,e,i,s)}drawFlatCoordinatess_(t,e,i,s){const r=this.state,o=r.fillStyle!==void 0,a=r.strokeStyle!==void 0,l=i.length;this.instructions.push(Ie),this.hitDetectionInstructions.push(Ie);for(let h=0;h<l;++h){const c=i[h],u=this.coordinates.length,d=this.appendFlatLineCoordinates(t,e,c,s,!0,!a),f=[G.MOVE_TO_LINE_TO,u,d];this.instructions.push(f),this.hitDetectionInstructions.push(f),a&&(this.instructions.push($s),this.hitDetectionInstructions.push($s)),e=c}return o&&(this.instructions.push(Hi),this.hitDetectionInstructions.push(Hi)),a&&(this.instructions.push(ae),this.hitDetectionInstructions.push(ae)),e}drawCircle(t,e){const i=this.state,s=i.fillStyle,r=i.strokeStyle;if(s===void 0&&r===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e),i.fillStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_FILL_STYLE,Zt]),i.strokeStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,i.strokeStyle,i.lineWidth,i.lineCap,i.lineJoin,i.miterLimit,i.lineDash,i.lineDashOffset]);const o=t.getFlatCoordinates(),a=t.getStride(),l=this.coordinates.length;this.appendFlatLineCoordinates(o,0,o.length,a,!1,!1);const h=[G.CIRCLE,l];this.instructions.push(Ie,h),this.hitDetectionInstructions.push(Ie,h),i.fillStyle!==void 0&&(this.instructions.push(Hi),this.hitDetectionInstructions.push(Hi)),i.strokeStyle!==void 0&&(this.instructions.push(ae),this.hitDetectionInstructions.push(ae)),this.endGeometry(e)}drawPolygon(t,e){const i=this.state,s=i.fillStyle,r=i.strokeStyle;if(s===void 0&&r===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e),i.fillStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_FILL_STYLE,Zt]),i.strokeStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,i.strokeStyle,i.lineWidth,i.lineCap,i.lineJoin,i.miterLimit,i.lineDash,i.lineDashOffset]);const o=t.getEnds(),a=t.getOrientedFlatCoordinates(),l=t.getStride();this.drawFlatCoordinatess_(a,0,o,l),this.endGeometry(e)}drawMultiPolygon(t,e){const i=this.state,s=i.fillStyle,r=i.strokeStyle;if(s===void 0&&r===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e),i.fillStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_FILL_STYLE,Zt]),i.strokeStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,i.strokeStyle,i.lineWidth,i.lineCap,i.lineJoin,i.miterLimit,i.lineDash,i.lineDashOffset]);const o=t.getEndss(),a=t.getOrientedFlatCoordinates(),l=t.getStride();let h=0;for(let c=0,u=o.length;c<u;++c)h=this.drawFlatCoordinatess_(a,h,o[c],l);this.endGeometry(e)}finish(){this.reverseHitDetectionInstructions(),this.state=null;const t=this.tolerance;if(t!==0){const e=this.coordinates;for(let i=0,s=e.length;i<s;++i)e[i]=Ce(e[i],t)}return super.finish()}setFillStrokeStyles_(){const t=this.state;t.fillStyle!==void 0&&this.updateFillStyle(t,this.createFill),t.strokeStyle!==void 0&&this.updateStrokeStyle(t,this.applyStroke)}}const tr=uh;function dh(n,t,e,i,s){const r=[];let o=e,a=0,l=t.slice(e,2);for(;a<n&&o+s<i;){const[h,c]=l.slice(-2),u=t[o+s],d=t[o+s+1],f=Math.sqrt((u-h)*(u-h)+(d-c)*(d-c));if(a+=f,a>=n){const g=(n-a+f)/f,_=wt(h,u,g),p=wt(c,d,g);l.push(_,p),r.push(l),l=[_,p],a==n&&(o+=s),a=0}else if(a<n)l.push(t[o+s],t[o+s+1]),o+=s;else{const g=f-a,_=wt(h,u,g/f),p=wt(c,d,g/f);l.push(_,p),r.push(l),l=[_,p],a=0,o+=s}}return a>0&&r.push(l),r}function fh(n,t,e,i,s){let r=e,o=e,a=0,l=0,h=e,c,u,d,f,g,_,p,x,S,I;for(u=e;u<i;u+=s){const D=t[u],T=t[u+1];g!==void 0&&(S=D-g,I=T-_,f=Math.sqrt(S*S+I*I),p!==void 0&&(l+=d,c=Math.acos((p*S+x*I)/(d*f)),c>n&&(l>a&&(a=l,r=h,o=u),l=0,h=u-s)),d=f,p=S,x=I),g=D,_=T}return l+=f,l>a?[h,u]:[r,o]}const di={left:0,end:0,center:.5,right:1,start:1,top:0,middle:.5,hanging:.2,alphabetic:.8,ideographic:.8,bottom:1};class gh extends Fi{constructor(t,e,i,s){super(t,e,i,s),this.labels_=null,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=void 0,this.textRotation_=0,this.textFillState_=null,this.fillStates={},this.textStrokeState_=null,this.strokeStates={},this.textState_={},this.textStates={},this.textKey_="",this.fillKey_="",this.strokeKey_="",this.declutterImageWithText_=void 0}finish(){const t=super.finish();return t.textStates=this.textStates,t.fillStates=this.fillStates,t.strokeStates=this.strokeStates,t}drawText(t,e){const i=this.textFillState_,s=this.textStrokeState_,r=this.textState_;if(this.text_===""||!r||!i&&!s)return;const o=this.coordinates;let a=o.length;const l=t.getType();let h=null,c=t.getStride();if(r.placement==="line"&&(l=="LineString"||l=="MultiLineString"||l=="Polygon"||l=="MultiPolygon")){if(!Dt(this.getBufferedMaxExtent(),t.getExtent()))return;let u;if(h=t.getFlatCoordinates(),l=="LineString")u=[h.length];else if(l=="MultiLineString")u=t.getEnds();else if(l=="Polygon")u=t.getEnds().slice(0,1);else if(l=="MultiPolygon"){const _=t.getEndss();u=[];for(let p=0,x=_.length;p<x;++p)u.push(_[p][0])}this.beginGeometry(t,e);const d=r.repeat,f=d?void 0:r.textAlign;let g=0;for(let _=0,p=u.length;_<p;++_){let x;d?x=dh(d*this.resolution,h,g,u[_],c):x=[h.slice(g,u[_])];for(let S=0,I=x.length;S<I;++S){const D=x[S];let T=0,N=D.length;if(f==null){const y=fh(r.maxAngle,D,0,D.length,2);T=y[0],N=y[1]}for(let y=T;y<N;y+=c)o.push(D[y],D[y+1]);const Z=o.length;g=u[_],this.drawChars_(a,Z),a=Z}}this.endGeometry(e)}else{let u=r.overflow?null:[];switch(l){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(),c=2;break;case"Polygon":h=t.getFlatInteriorPoint(),r.overflow||u.push(h[2]/this.resolution),c=3;break;case"MultiPolygon":const p=t.getFlatInteriorPoints();h=[];for(let x=0,S=p.length;x<S;x+=3)r.overflow||u.push(p[x+2]/this.resolution),h.push(p[x],p[x+1]);if(h.length===0)return;c=2;break}const d=this.appendFlatPointCoordinates(h,c);if(d===a)return;if(u&&(d-a)/2!==h.length/c){let p=a/2;u=u.filter((x,S)=>{const I=o[(p+S)*2]===h[S*c]&&o[(p+S)*2+1]===h[S*c+1];return I||--p,I})}this.saveTextStates_(),(r.backgroundFill||r.backgroundStroke)&&(this.setFillStrokeStyle(r.backgroundFill,r.backgroundStroke),r.backgroundFill&&(this.updateFillStyle(this.state,this.createFill),this.hitDetectionInstructions.push(this.createFill(this.state))),r.backgroundStroke&&(this.updateStrokeStyle(this.state,this.applyStroke),this.hitDetectionInstructions.push(this.createStroke(this.state)))),this.beginGeometry(t,e);let f=r.padding;if(f!=Ee&&(r.scale[0]<0||r.scale[1]<0)){let p=r.padding[0],x=r.padding[1],S=r.padding[2],I=r.padding[3];r.scale[0]<0&&(x=-x,I=-I),r.scale[1]<0&&(p=-p,S=-S),f=[p,x,S,I]}const g=this.pixelRatio;this.instructions.push([G.DRAW_IMAGE,a,d,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[1,1],NaN,void 0,this.declutterImageWithText_,f==Ee?Ee:f.map(function(p){return p*g}),!!r.backgroundFill,!!r.backgroundStroke,this.text_,this.textKey_,this.strokeKey_,this.fillKey_,this.textOffsetX_,this.textOffsetY_,u]);const _=1/g;this.hitDetectionInstructions.push([G.DRAW_IMAGE,a,d,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[_,_],NaN,void 0,this.declutterImageWithText_,f,!!r.backgroundFill,!!r.backgroundStroke,this.text_,this.textKey_,this.strokeKey_,this.fillKey_,this.textOffsetX_,this.textOffsetY_,u]),this.endGeometry(e)}}saveTextStates_(){const t=this.textStrokeState_,e=this.textState_,i=this.textFillState_,s=this.strokeKey_;t&&(s in this.strokeStates||(this.strokeStates[s]={strokeStyle:t.strokeStyle,lineCap:t.lineCap,lineDashOffset:t.lineDashOffset,lineWidth:t.lineWidth,lineJoin:t.lineJoin,miterLimit:t.miterLimit,lineDash:t.lineDash}));const r=this.textKey_;r in this.textStates||(this.textStates[r]={font:e.font,textAlign:e.textAlign||Si,justify:e.justify,textBaseline:e.textBaseline||tn,scale:e.scale});const o=this.fillKey_;i&&(o in this.fillStates||(this.fillStates[o]={fillStyle:i.fillStyle}))}drawChars_(t,e){const i=this.textStrokeState_,s=this.textState_,r=this.strokeKey_,o=this.textKey_,a=this.fillKey_;this.saveTextStates_();const l=this.pixelRatio,h=di[s.textBaseline],c=this.textOffsetY_*l,u=this.text_,d=i?i.lineWidth*Math.abs(s.scale[0])/2:0;this.instructions.push([G.DRAW_CHARS,t,e,h,s.overflow,a,s.maxAngle,l,c,r,d*l,u,o,1]),this.hitDetectionInstructions.push([G.DRAW_CHARS,t,e,h,s.overflow,a,s.maxAngle,1,c,r,d,u,o,1/l])}setTextStyle(t,e){let i,s,r;if(!t)this.text_="";else{const o=t.getFill();o?(s=this.textFillState_,s||(s={},this.textFillState_=s),s.fillStyle=Pt(o.getColor()||Zt)):(s=null,this.textFillState_=s);const a=t.getStroke();if(!a)r=null,this.textStrokeState_=r;else{r=this.textStrokeState_,r||(r={},this.textStrokeState_=r);const g=a.getLineDash(),_=a.getLineDashOffset(),p=a.getWidth(),x=a.getMiterLimit();r.lineCap=a.getLineCap()||$i,r.lineDash=g?g.slice():pi,r.lineDashOffset=_===void 0?xi:_,r.lineJoin=a.getLineJoin()||qe,r.lineWidth=p===void 0?Ci:p,r.miterLimit=x===void 0?yi:x,r.strokeStyle=Pt(a.getColor()||vi)}i=this.textState_;const l=t.getFont()||Er;Yo(l);const h=t.getScaleArray();i.overflow=t.getOverflow(),i.font=l,i.maxAngle=t.getMaxAngle(),i.placement=t.getPlacement(),i.textAlign=t.getTextAlign(),i.repeat=t.getRepeat(),i.justify=t.getJustify(),i.textBaseline=t.getTextBaseline()||tn,i.backgroundFill=t.getBackgroundFill(),i.backgroundStroke=t.getBackgroundStroke(),i.padding=t.getPadding()||Ee,i.scale=h===void 0?[1,1]:h;const c=t.getOffsetX(),u=t.getOffsetY(),d=t.getRotateWithView(),f=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.textRotation_=f===void 0?0:f,this.strokeKey_=r?(typeof r.strokeStyle=="string"?r.strokeStyle:nt(r.strokeStyle))+r.lineCap+r.lineDashOffset+"|"+r.lineWidth+r.lineJoin+r.miterLimit+"["+r.lineDash.join()+"]":"",this.textKey_=i.font+i.scale+(i.textAlign||"?")+(i.repeat||"?")+(i.justify||"?")+(i.textBaseline||"?"),this.fillKey_=s?typeof s.fillStyle=="string"?s.fillStyle:"|"+nt(s.fillStyle):""}this.declutterImageWithText_=e}}const _h={Circle:tr,Default:Fi,Image:lh,LineString:ch,Polygon:tr,Text:gh};class mh{constructor(t,e,i,s){this.tolerance_=t,this.maxExtent_=e,this.pixelRatio_=s,this.resolution_=i,this.buildersByZIndex_={}}finish(){const t={};for(const e in this.buildersByZIndex_){t[e]=t[e]||{};const i=this.buildersByZIndex_[e];for(const s in i){const r=i[s].finish();t[e][s]=r}}return t}getBuilder(t,e){const i=t!==void 0?t.toString():"0";let s=this.buildersByZIndex_[i];s===void 0&&(s={},this.buildersByZIndex_[i]=s);let r=s[e];if(r===void 0){const o=_h[e];r=new o(this.tolerance_,this.maxExtent_,this.resolution_,this.pixelRatio_),s[e]=r}return r}}const er=mh;function ph(n,t,e,i,s,r,o,a,l,h,c,u){let d=n[t],f=n[t+1],g=0,_=0,p=0,x=0;function S(){g=d,_=f,t+=i,d=n[t],f=n[t+1],x+=p,p=Math.sqrt((d-g)*(d-g)+(f-_)*(f-_))}do S();while(t<e-i&&x+p<r);let I=p===0?0:(r-x)/p;const D=wt(g,d,I),T=wt(_,f,I),N=t-i,Z=x,y=r+a*l(h,s,c);for(;t<e-i&&x+p<y;)S();I=p===0?0:(y-x)/p;const H=wt(g,d,I),q=wt(_,f,I);let j;if(u){const Y=[D,T,H,q];Zr(Y,0,4,2,u,Y,Y),j=Y[0]>Y[2]}else j=D>H;const W=Math.PI,R=[],at=N+i===t;t=N,p=0,x=Z,d=n[t],f=n[t+1];let B;if(at){S(),B=Math.atan2(f-_,d-g),j&&(B+=B>0?-W:W);const Y=(H+D)/2,z=(q+T)/2;return R[0]=[Y,z,(y-r)/2,B,s],R}s=s.replace(/\n/g," ");for(let Y=0,z=s.length;Y<z;){S();let J=Math.atan2(f-_,d-g);if(j&&(J+=J>0?-W:W),B!==void 0){let Et=J-B;if(Et+=Et>W?-2*W:Et<-W?2*W:0,Math.abs(Et)>o)return null}B=J;const ct=Y;let ut=0;for(;Y<z;++Y){const Et=j?z-Y-1:Y,Lt=a*l(h,s[Et],c);if(t+i<e&&x+p<r+ut+Lt/2)break;ut+=Lt}if(Y===ct)continue;const Ct=j?s.substring(z-ct,z-Y):s.substring(ct,Y);I=p===0?0:(r+ut/2-x)/p;const M=wt(g,d,I),Te=wt(_,f,I);R.push([M,Te,ut/2,J,Ct]),r+=ut}return R}const Ne=Le(),ie=[],Xt=[],Wt=[],ne=[];function ir(n){return n[3].declutterBox}const xh=new RegExp("["+String.fromCharCode(1425)+"-"+String.fromCharCode(2303)+String.fromCharCode(64285)+"-"+String.fromCharCode(65023)+String.fromCharCode(65136)+"-"+String.fromCharCode(65276)+String.fromCharCode(67584)+"-"+String.fromCharCode(69631)+String.fromCharCode(124928)+"-"+String.fromCharCode(126975)+"]");function nr(n,t){return(t==="start"||t==="end")&&!xh.test(n)&&(t=t==="start"?"left":"right"),di[t]}function yh(n,t,e){return e>0&&n.push(`
|
|
`,""),n.push(t,""),n}class vh{constructor(t,e,i,s){this.overlaps=i,this.pixelRatio=e,this.resolution=t,this.alignFill_,this.instructions=s.instructions,this.coordinates=s.coordinates,this.coordinateCache_={},this.renderedTransform_=he(),this.hitDetectionInstructions=s.hitDetectionInstructions,this.pixelCoordinates_=null,this.viewRotation_=0,this.fillStates=s.fillStates||{},this.strokeStates=s.strokeStates||{},this.textStates=s.textStates||{},this.widths_={},this.labels_={}}createLabel(t,e,i,s){const r=t+e+i+s;if(this.labels_[r])return this.labels_[r];const o=s?this.strokeStates[s]:null,a=i?this.fillStates[i]:null,l=this.textStates[e],h=this.pixelRatio,c=[l.scale[0]*h,l.scale[1]*h],u=Array.isArray(t),d=l.justify?di[l.justify]:nr(Array.isArray(t)?t[0]:t,l.textAlign||Si),f=s&&o.lineWidth?o.lineWidth:0,g=u?t:t.split(`
|
|
`).reduce(yh,[]),{width:_,height:p,widths:x,heights:S,lineWidths:I}=Vo(l,g),D=_+f,T=[],N=(D+2)*c[0],Z=(p+f)*c[1],y={width:N<0?Math.floor(N):Math.ceil(N),height:Z<0?Math.floor(Z):Math.ceil(Z),contextInstructions:T};(c[0]!=1||c[1]!=1)&&T.push("scale",c),s&&(T.push("strokeStyle",o.strokeStyle),T.push("lineWidth",f),T.push("lineCap",o.lineCap),T.push("lineJoin",o.lineJoin),T.push("miterLimit",o.miterLimit),T.push("setLineDash",[o.lineDash]),T.push("lineDashOffset",o.lineDashOffset)),i&&T.push("fillStyle",a.fillStyle),T.push("textBaseline","middle"),T.push("textAlign","center");const H=.5-d;let q=d*D+H*f;const j=[],W=[];let R=0,at=0,B=0,Y=0,z;for(let J=0,ct=g.length;J<ct;J+=2){const ut=g[J];if(ut===`
|
|
`){at+=R,R=0,q=d*D+H*f,++Y;continue}const Ct=g[J+1]||l.font;Ct!==z&&(s&&j.push("font",Ct),i&&W.push("font",Ct),z=Ct),R=Math.max(R,S[B]);const M=[ut,q+H*x[B]+d*(x[B]-I[Y]),.5*(f+R)+at];q+=x[B],s&&j.push("strokeText",M),i&&W.push("fillText",M),++B}return Array.prototype.push.apply(T,j),Array.prototype.push.apply(T,W),this.labels_[r]=y,y}replayTextBackground_(t,e,i,s,r,o,a){t.beginPath(),t.moveTo.apply(t,e),t.lineTo.apply(t,i),t.lineTo.apply(t,s),t.lineTo.apply(t,r),t.lineTo.apply(t,e),o&&(this.alignFill_=o[2],this.fill_(t)),a&&(this.setStrokeStyle_(t,a),t.stroke())}calculateImageOrLabelDimensions_(t,e,i,s,r,o,a,l,h,c,u,d,f,g,_,p){a*=d[0],l*=d[1];let x=i-a,S=s-l;const I=r+h>t?t-h:r,D=o+c>e?e-c:o,T=g[3]+I*d[0]+g[1],N=g[0]+D*d[1]+g[2],Z=x-g[3],y=S-g[0];(_||u!==0)&&(ie[0]=Z,ne[0]=Z,ie[1]=y,Xt[1]=y,Xt[0]=Z+T,Wt[0]=Xt[0],Wt[1]=y+N,ne[1]=Wt[1]);let H;return u!==0?(H=Di(he(),i,s,1,1,u,-i,-s),St(H,ie),St(H,Xt),St(H,Wt),St(H,ne),Ke(Math.min(ie[0],Xt[0],Wt[0],ne[0]),Math.min(ie[1],Xt[1],Wt[1],ne[1]),Math.max(ie[0],Xt[0],Wt[0],ne[0]),Math.max(ie[1],Xt[1],Wt[1],ne[1]),Ne)):Ke(Math.min(Z,Z+T),Math.min(y,y+N),Math.max(Z,Z+T),Math.max(y,y+N),Ne),f&&(x=Math.round(x),S=Math.round(S)),{drawImageX:x,drawImageY:S,drawImageW:I,drawImageH:D,originX:h,originY:c,declutterBox:{minX:Ne[0],minY:Ne[1],maxX:Ne[2],maxY:Ne[3],value:p},canvasTransform:H,scale:d}}replayImageOrLabel_(t,e,i,s,r,o,a){const l=!!(o||a),h=s.declutterBox,c=t.canvas,u=a?a[2]*s.scale[0]/2:0;return h.minX-u<=c.width/e&&h.maxX+u>=0&&h.minY-u<=c.height/e&&h.maxY+u>=0&&(l&&this.replayTextBackground_(t,ie,Xt,Wt,ne,o,a),Zo(t,s.canvasTransform,r,i,s.originX,s.originY,s.drawImageW,s.drawImageH,s.drawImageX,s.drawImageY,s.scale)),!0}fill_(t){if(this.alignFill_){const e=St(this.renderedTransform_,[0,0]),i=512*this.pixelRatio;t.save(),t.translate(e[0]%i,e[1]%i),t.rotate(this.viewRotation_)}t.fill(),this.alignFill_&&t.restore()}setStrokeStyle_(t,e){t.strokeStyle=e[1],t.lineWidth=e[2],t.lineCap=e[3],t.lineJoin=e[4],t.miterLimit=e[5],t.lineDashOffset=e[7],t.setLineDash(e[6])}drawLabelWithPointPlacement_(t,e,i,s){const r=this.textStates[e],o=this.createLabel(t,e,s,i),a=this.strokeStates[i],l=this.pixelRatio,h=nr(Array.isArray(t)?t[0]:t,r.textAlign||Si),c=di[r.textBaseline||tn],u=a&&a.lineWidth?a.lineWidth:0,d=o.width/l-2*r.scale[0],f=h*d+2*(.5-h)*u,g=c*o.height/l+2*(.5-c)*u;return{label:o,anchorX:f,anchorY:g}}execute_(t,e,i,s,r,o,a,l){let h;this.pixelCoordinates_&&be(i,this.renderedTransform_)?h=this.pixelCoordinates_:(this.pixelCoordinates_||(this.pixelCoordinates_=[]),h=Ae(this.coordinates,0,this.coordinates.length,2,i,this.pixelCoordinates_),Ha(this.renderedTransform_,i));let c=0;const u=s.length;let d=0,f,g,_,p,x,S,I,D,T,N,Z,y,H=0,q=0,j=null,W=null;const R=this.coordinateCache_,at=this.viewRotation_,B=Math.round(Math.atan2(-i[1],i[0])*1e12)/1e12,Y={context:t,pixelRatio:this.pixelRatio,resolution:this.resolution,rotation:at},z=this.instructions!=s||this.overlaps?0:200;let J,ct,ut,Ct;for(;c<u;){const M=s[c];switch(M[0]){case G.BEGIN_GEOMETRY:J=M[1],Ct=M[3],J.getGeometry()?a!==void 0&&!Dt(a,Ct.getExtent())?c=M[2]+1:++c:c=M[2];break;case G.BEGIN_PATH:H>z&&(this.fill_(t),H=0),q>z&&(t.stroke(),q=0),!H&&!q&&(t.beginPath(),p=NaN,x=NaN),++c;break;case G.CIRCLE:d=M[1];const Et=h[d],Lt=h[d+1],dn=h[d+2],fn=h[d+3],Oi=dn-Et,De=fn-Lt,Pi=Math.sqrt(Oi*Oi+De*De);t.moveTo(Et+Pi,Lt),t.arc(Et,Lt,Pi,0,2*Math.PI,!0),++c;break;case G.CLOSE_PATH:t.closePath(),++c;break;case G.CUSTOM:d=M[1],f=M[2];const gn=M[3],_n=M[4],ke=M.length==6?M[5]:void 0;Y.geometry=gn,Y.feature=J,c in R||(R[c]=[]);const de=R[c];ke?ke(h,d,f,2,de):(de[0]=h[d],de[1]=h[d+1],de.length=2),_n(de,Y),++c;break;case G.DRAW_IMAGE:d=M[1],f=M[2],D=M[3],g=M[4],_=M[5];let ei=M[6];const Ut=M[7],mn=M[8],pn=M[9],Gi=M[10];let ii=M[11];const Gt=M[12];let Fe=M[13];const Bi=M[14],fe=M[15];if(!D&&M.length>=20){T=M[19],N=M[20],Z=M[21],y=M[22];const E=this.drawLabelWithPointPlacement_(T,N,Z,y);D=E.label,M[3]=D;const w=M[23];g=(E.anchorX-w)*this.pixelRatio,M[4]=g;const A=M[24];_=(E.anchorY-A)*this.pixelRatio,M[5]=_,ei=D.height,M[6]=ei,Fe=D.width,M[13]=Fe}let Oe;M.length>25&&(Oe=M[25]);let ge,Ft,_e;M.length>17?(ge=M[16],Ft=M[17],_e=M[18]):(ge=Ee,Ft=!1,_e=!1),Gi&&B?ii+=at:!Gi&&!B&&(ii-=at);let Bt=0;for(;d<f;d+=2){if(Oe&&Oe[Bt++]<Fe/this.pixelRatio)continue;const E=this.calculateImageOrLabelDimensions_(D.width,D.height,h[d],h[d+1],Fe,ei,g,_,mn,pn,ii,Gt,r,ge,Ft||_e,J),w=[t,e,D,E,Ut,Ft?j:null,_e?W:null];if(l){if(Bi==="none")continue;if(Bi==="obstacle"){l.insert(E.declutterBox);continue}else{let A,F;if(fe){const O=f-d;if(!fe[O]){fe[O]=w;continue}if(A=fe[O],delete fe[O],F=ir(A),l.collides(F))continue}if(l.collides(E.declutterBox))continue;A&&(l.insert(F),this.replayImageOrLabel_.apply(this,A)),l.insert(E.declutterBox)}}this.replayImageOrLabel_.apply(this,w)}++c;break;case G.DRAW_CHARS:const Ht=M[1],qt=M[2],me=M[3],xn=M[4];y=M[5];const yn=M[6],Ni=M[7],ni=M[8];Z=M[9];const pe=M[10];T=M[11],N=M[12];const si=[M[13],M[13]],ri=this.textStates[N],Kt=ri.font,Jt=[ri.scale[0]*Ni,ri.scale[1]*Ni];let xe;Kt in this.widths_?xe=this.widths_[Kt]:(xe={},this.widths_[Kt]=xe);const v=Qr(h,Ht,qt,2),m=Math.abs(Jt[0])*Ss(Kt,T,xe);if(xn||m<=v){const E=this.textStates[N].textAlign,w=(v-m)*di[E],A=ph(h,Ht,qt,2,T,w,yn,Math.abs(Jt[0]),Ss,Kt,xe,B?0:this.viewRotation_);t:if(A){const F=[];let O,b,V,X,L;if(Z)for(O=0,b=A.length;O<b;++O){L=A[O],V=L[4],X=this.createLabel(V,N,"",Z),g=L[2]+(Jt[0]<0?-pe:pe),_=me*X.height+(.5-me)*2*pe*Jt[1]/Jt[0]-ni;const K=this.calculateImageOrLabelDimensions_(X.width,X.height,L[0],L[1],X.width,X.height,g,_,0,0,L[3],si,!1,Ee,!1,J);if(l&&l.collides(K.declutterBox))break t;F.push([t,e,X,K,1,null,null])}if(y)for(O=0,b=A.length;O<b;++O){L=A[O],V=L[4],X=this.createLabel(V,N,y,""),g=L[2],_=me*X.height-ni;const K=this.calculateImageOrLabelDimensions_(X.width,X.height,L[0],L[1],X.width,X.height,g,_,0,0,L[3],si,!1,Ee,!1,J);if(l&&l.collides(K.declutterBox))break t;F.push([t,e,X,K,1,null,null])}l&&l.load(F.map(ir));for(let K=0,_t=F.length;K<_t;++K)this.replayImageOrLabel_.apply(this,F[K])}}++c;break;case G.END_GEOMETRY:if(o!==void 0){J=M[1];const E=o(J,Ct);if(E)return E}++c;break;case G.FILL:z?H++:this.fill_(t),++c;break;case G.MOVE_TO_LINE_TO:for(d=M[1],f=M[2],ct=h[d],ut=h[d+1],S=ct+.5|0,I=ut+.5|0,(S!==p||I!==x)&&(t.moveTo(ct,ut),p=S,x=I),d+=2;d<f;d+=2)ct=h[d],ut=h[d+1],S=ct+.5|0,I=ut+.5|0,(d==f-2||S!==p||I!==x)&&(t.lineTo(ct,ut),p=S,x=I);++c;break;case G.SET_FILL_STYLE:j=M,this.alignFill_=M[2],H&&(this.fill_(t),H=0,q&&(t.stroke(),q=0)),t.fillStyle=M[1],++c;break;case G.SET_STROKE_STYLE:W=M,q&&(t.stroke(),q=0),this.setStrokeStyle_(t,M),++c;break;case G.STROKE:z?q++:t.stroke(),++c;break;default:++c;break}}H&&this.fill_(t),q&&t.stroke()}execute(t,e,i,s,r,o){this.viewRotation_=s,this.execute_(t,e,i,this.instructions,r,void 0,void 0,o)}executeHitDetection(t,e,i,s,r){return this.viewRotation_=i,this.execute_(t,1,e,this.hitDetectionInstructions,!0,s,r)}}const Sh=vh,Ln=["Polygon","Circle","LineString","Image","Text","Default"];class Ch{constructor(t,e,i,s,r,o){this.maxExtent_=t,this.overlaps_=s,this.pixelRatio_=i,this.resolution_=e,this.renderBuffer_=o,this.executorsByZIndex_={},this.hitDetectionContext_=null,this.hitDetectionTransform_=he(),this.createExecutors_(r)}clip(t,e){const i=this.getClipCoords(e);t.beginPath(),t.moveTo(i[0],i[1]),t.lineTo(i[2],i[3]),t.lineTo(i[4],i[5]),t.lineTo(i[6],i[7]),t.clip()}createExecutors_(t){for(const e in t){let i=this.executorsByZIndex_[e];i===void 0&&(i={},this.executorsByZIndex_[e]=i);const s=t[e];for(const r in s){const o=s[r];i[r]=new Sh(this.resolution_,this.pixelRatio_,this.overlaps_,o)}}}hasExecutors(t){for(const e in this.executorsByZIndex_){const i=this.executorsByZIndex_[e];for(let s=0,r=t.length;s<r;++s)if(t[s]in i)return!0}return!1}forEachFeatureAtCoordinate(t,e,i,s,r,o){s=Math.round(s);const a=s*2+1,l=Di(this.hitDetectionTransform_,s+.5,s+.5,1/e,-1/e,-i,-t[0],-t[1]),h=!this.hitDetectionContext_;h&&(this.hitDetectionContext_=kt(a,a,void 0,{willReadFrequently:!0}));const c=this.hitDetectionContext_;c.canvas.width!==a||c.canvas.height!==a?(c.canvas.width=a,c.canvas.height=a):h||c.clearRect(0,0,a,a);let u;this.renderBuffer_!==void 0&&(u=Le(),Ar(u,t),cn(u,e*(this.renderBuffer_+s),u));const d=Eh(s);let f;function g(T,N){const Z=c.getImageData(0,0,a,a).data;for(let y=0,H=d.length;y<H;y++)if(Z[d[y]]>0){if(!o||f!=="Image"&&f!=="Text"||o.includes(T)){const q=(d[y]-3)/4,j=s-q%a,W=s-(q/a|0),R=r(T,N,j*j+W*W);if(R)return R}c.clearRect(0,0,a,a);break}}const _=Object.keys(this.executorsByZIndex_).map(Number);_.sort(gi);let p,x,S,I,D;for(p=_.length-1;p>=0;--p){const T=_[p].toString();for(S=this.executorsByZIndex_[T],x=Ln.length-1;x>=0;--x)if(f=Ln[x],I=S[f],I!==void 0&&(D=I.executeHitDetection(c,l,i,g,u),D))return D}}getClipCoords(t){const e=this.maxExtent_;if(!e)return null;const i=e[0],s=e[1],r=e[2],o=e[3],a=[i,s,i,o,r,o,r,s];return Ae(a,0,8,2,t,a),a}isEmpty(){return mi(this.executorsByZIndex_)}execute(t,e,i,s,r,o,a){const l=Object.keys(this.executorsByZIndex_).map(Number);l.sort(gi),this.maxExtent_&&(t.save(),this.clip(t,i)),o=o||Ln;let h,c,u,d,f,g;for(a&&l.reverse(),h=0,c=l.length;h<c;++h){const _=l[h].toString();for(f=this.executorsByZIndex_[_],u=0,d=o.length;u<d;++u){const p=o[u];g=f[p],g!==void 0&&g.execute(t,e,i,s,r,a)}}this.maxExtent_&&t.restore()}}const bn={};function Eh(n){if(bn[n]!==void 0)return bn[n];const t=n*2+1,e=n*n,i=new Array(e+1);for(let r=0;r<=n;++r)for(let o=0;o<=n;++o){const a=r*r+o*o;if(a>e)break;let l=i[a];l||(l=[],i[a]=l),l.push(((n+r)*t+(n+o))*4+3),r>0&&l.push(((n-r)*t+(n+o))*4+3),o>0&&(l.push(((n+r)*t+(n-o))*4+3),r>0&&l.push(((n-r)*t+(n-o))*4+3))}const s=[];for(let r=0,o=i.length;r<o;++r)i[r]&&s.push(...i[r]);return bn[n]=s,s}const sr=Ch;class Rh extends $r{constructor(t,e,i,s,r,o,a){super(),this.context_=t,this.pixelRatio_=e,this.extent_=i,this.transform_=s,this.transformRotation_=s?Eo(Math.atan2(s[1],s[0]),10):0,this.viewRotation_=r,this.squaredTolerance_=o,this.userTransform_=a,this.contextFillState_=null,this.contextStrokeState_=null,this.contextTextState_=null,this.fillState_=null,this.strokeState_=null,this.image_=null,this.imageAnchorX_=0,this.imageAnchorY_=0,this.imageHeight_=0,this.imageOpacity_=0,this.imageOriginX_=0,this.imageOriginY_=0,this.imageRotateWithView_=!1,this.imageRotation_=0,this.imageScale_=[0,0],this.imageWidth_=0,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=!1,this.textRotation_=0,this.textScale_=[0,0],this.textFillState_=null,this.textStrokeState_=null,this.textState_=null,this.pixelCoordinates_=[],this.tmpLocalTransform_=he()}drawImages_(t,e,i,s){if(!this.image_)return;const r=Ae(t,e,i,s,this.transform_,this.pixelCoordinates_),o=this.context_,a=this.tmpLocalTransform_,l=o.globalAlpha;this.imageOpacity_!=1&&(o.globalAlpha=l*this.imageOpacity_);let h=this.imageRotation_;this.transformRotation_===0&&(h-=this.viewRotation_),this.imageRotateWithView_&&(h+=this.viewRotation_);for(let c=0,u=r.length;c<u;c+=2){const d=r[c]-this.imageAnchorX_,f=r[c+1]-this.imageAnchorY_;if(h!==0||this.imageScale_[0]!=1||this.imageScale_[1]!=1){const g=d+this.imageAnchorX_,_=f+this.imageAnchorY_;Di(a,g,_,1,1,h,-g,-_),o.setTransform.apply(o,a),o.translate(g,_),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.setTransform(1,0,0,1,0,0)}else o.drawImage(this.image_,this.imageOriginX_,this.imageOriginY_,this.imageWidth_,this.imageHeight_,d,f,this.imageWidth_,this.imageHeight_)}this.imageOpacity_!=1&&(o.globalAlpha=l)}drawText_(t,e,i,s){if(!this.textState_||this.text_==="")return;this.textFillState_&&this.setContextFillState_(this.textFillState_),this.textStrokeState_&&this.setContextStrokeState_(this.textStrokeState_),this.setContextTextState_(this.textState_);const r=Ae(t,e,i,s,this.transform_,this.pixelCoordinates_),o=this.context_;let a=this.textRotation_;for(this.transformRotation_===0&&(a-=this.viewRotation_),this.textRotateWithView_&&(a+=this.viewRotation_);e<i;e+=s){const l=r[e]+this.textOffsetX_,h=r[e+1]+this.textOffsetY_;a!==0||this.textScale_[0]!=1||this.textScale_[1]!=1?(o.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.setTransform(1,0,0,1,0,0)):(this.textStrokeState_&&o.strokeText(this.text_,l,h),this.textFillState_&&o.fillText(this.text_,l,h))}}moveToLineTo_(t,e,i,s,r){const o=this.context_,a=Ae(t,e,i,s,this.transform_,this.pixelCoordinates_);o.moveTo(a[0],a[1]);let l=a.length;r&&(l-=2);for(let h=2;h<l;h+=2)o.lineTo(a[h],a[h+1]);return r&&o.closePath(),i}drawRings_(t,e,i,s){for(let r=0,o=i.length;r<o;++r)e=this.moveToLineTo_(t,e,i[r],s,!0);return e}drawCircle(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!Dt(this.extent_,t.getExtent())){if(this.fillState_||this.strokeState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=rl(t,this.transform_,this.pixelCoordinates_),i=e[2]-e[0],s=e[3]-e[1],r=Math.sqrt(i*i+s*s),o=this.context_;o.beginPath(),o.arc(e[0],e[1],r,0,2*Math.PI),this.fillState_&&o.fill(),this.strokeState_&&o.stroke()}this.text_!==""&&this.drawText_(t.getCenter(),0,2,2)}}setStyle(t){this.setFillStrokeStyle(t.getFill(),t.getStroke()),this.setImageStyle(t.getImage()),this.setTextStyle(t.getText())}setTransform(t){this.transform_=t}drawGeometry(t){switch(t.getType()){case"Point":this.drawPoint(t);break;case"LineString":this.drawLineString(t);break;case"Polygon":this.drawPolygon(t);break;case"MultiPoint":this.drawMultiPoint(t);break;case"MultiLineString":this.drawMultiLineString(t);break;case"MultiPolygon":this.drawMultiPolygon(t);break;case"GeometryCollection":this.drawGeometryCollection(t);break;case"Circle":this.drawCircle(t);break}}drawFeature(t,e){const i=e.getGeometryFunction()(t);!i||(this.setStyle(e),this.drawGeometry(i))}drawGeometryCollection(t){const e=t.getGeometriesArray();for(let i=0,s=e.length;i<s;++i)this.drawGeometry(e[i])}drawPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getFlatCoordinates(),i=t.getStride();this.image_&&this.drawImages_(e,0,e.length,i),this.text_!==""&&this.drawText_(e,0,e.length,i)}drawMultiPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getFlatCoordinates(),i=t.getStride();this.image_&&this.drawImages_(e,0,e.length,i),this.text_!==""&&this.drawText_(e,0,e.length,i)}drawLineString(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!Dt(this.extent_,t.getExtent())){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);const e=this.context_,i=t.getFlatCoordinates();e.beginPath(),this.moveToLineTo_(i,0,i.length,t.getStride(),!1),e.stroke()}if(this.text_!==""){const e=t.getFlatMidpoint();this.drawText_(e,0,2,2)}}}drawMultiLineString(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getExtent();if(!!Dt(this.extent_,e)){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);const i=this.context_,s=t.getFlatCoordinates();let r=0;const o=t.getEnds(),a=t.getStride();i.beginPath();for(let l=0,h=o.length;l<h;++l)r=this.moveToLineTo_(s,r,o[l],a,!1);i.stroke()}if(this.text_!==""){const i=t.getFlatMidpoints();this.drawText_(i,0,i.length,2)}}}drawPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!Dt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=this.context_;e.beginPath(),this.drawRings_(t.getOrientedFlatCoordinates(),0,t.getEnds(),t.getStride()),this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){const e=t.getFlatInteriorPoint();this.drawText_(e,0,2,2)}}}drawMultiPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!Dt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=this.context_,i=t.getOrientedFlatCoordinates();let s=0;const r=t.getEndss(),o=t.getStride();e.beginPath();for(let a=0,l=r.length;a<l;++a){const h=r[a];s=this.drawRings_(i,s,h,o)}this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){const e=t.getFlatInteriorPoints();this.drawText_(e,0,e.length,2)}}}setContextFillState_(t){const e=this.context_,i=this.contextFillState_;i?i.fillStyle!=t.fillStyle&&(i.fillStyle=t.fillStyle,e.fillStyle=t.fillStyle):(e.fillStyle=t.fillStyle,this.contextFillState_={fillStyle:t.fillStyle})}setContextStrokeState_(t){const e=this.context_,i=this.contextStrokeState_;i?(i.lineCap!=t.lineCap&&(i.lineCap=t.lineCap,e.lineCap=t.lineCap),be(i.lineDash,t.lineDash)||e.setLineDash(i.lineDash=t.lineDash),i.lineDashOffset!=t.lineDashOffset&&(i.lineDashOffset=t.lineDashOffset,e.lineDashOffset=t.lineDashOffset),i.lineJoin!=t.lineJoin&&(i.lineJoin=t.lineJoin,e.lineJoin=t.lineJoin),i.lineWidth!=t.lineWidth&&(i.lineWidth=t.lineWidth,e.lineWidth=t.lineWidth),i.miterLimit!=t.miterLimit&&(i.miterLimit=t.miterLimit,e.miterLimit=t.miterLimit),i.strokeStyle!=t.strokeStyle&&(i.strokeStyle=t.strokeStyle,e.strokeStyle=t.strokeStyle)):(e.lineCap=t.lineCap,e.setLineDash(t.lineDash),e.lineDashOffset=t.lineDashOffset,e.lineJoin=t.lineJoin,e.lineWidth=t.lineWidth,e.miterLimit=t.miterLimit,e.strokeStyle=t.strokeStyle,this.contextStrokeState_={lineCap:t.lineCap,lineDash:t.lineDash,lineDashOffset:t.lineDashOffset,lineJoin:t.lineJoin,lineWidth:t.lineWidth,miterLimit:t.miterLimit,strokeStyle:t.strokeStyle})}setContextTextState_(t){const e=this.context_,i=this.contextTextState_,s=t.textAlign?t.textAlign:Si;i?(i.font!=t.font&&(i.font=t.font,e.font=t.font),i.textAlign!=s&&(i.textAlign=s,e.textAlign=s),i.textBaseline!=t.textBaseline&&(i.textBaseline=t.textBaseline,e.textBaseline=t.textBaseline)):(e.font=t.font,e.textAlign=s,e.textBaseline=t.textBaseline,this.contextTextState_={font:t.font,textAlign:s,textBaseline:t.textBaseline})}setFillStrokeStyle(t,e){if(!t)this.fillState_=null;else{const i=t.getColor();this.fillState_={fillStyle:Pt(i||Zt)}}if(!e)this.strokeState_=null;else{const i=e.getColor(),s=e.getLineCap(),r=e.getLineDash(),o=e.getLineDashOffset(),a=e.getLineJoin(),l=e.getWidth(),h=e.getMiterLimit(),c=r||pi;this.strokeState_={lineCap:s!==void 0?s:$i,lineDash:this.pixelRatio_===1?c:c.map(u=>u*this.pixelRatio_),lineDashOffset:(o||xi)*this.pixelRatio_,lineJoin:a!==void 0?a:qe,lineWidth:(l!==void 0?l:Ci)*this.pixelRatio_,miterLimit:h!==void 0?h:yi,strokeStyle:Pt(i||vi)}}}setImageStyle(t){let e;if(!t||!(e=t.getSize())){this.image_=null;return}const i=t.getPixelRatio(this.pixelRatio_),s=t.getAnchor(),r=t.getOrigin();this.image_=t.getImage(this.pixelRatio_),this.imageAnchorX_=s[0]*i,this.imageAnchorY_=s[1]*i,this.imageHeight_=e[1]*i,this.imageOpacity_=t.getOpacity(),this.imageOriginX_=r[0],this.imageOriginY_=r[1],this.imageRotateWithView_=t.getRotateWithView(),this.imageRotation_=t.getRotation();const o=t.getScaleArray();this.imageScale_=[o[0]*this.pixelRatio_/i,o[1]*this.pixelRatio_/i],this.imageWidth_=e[0]*i}setTextStyle(t){if(!t)this.text_="";else{const e=t.getFill();if(!e)this.textFillState_=null;else{const f=e.getColor();this.textFillState_={fillStyle:Pt(f||Zt)}}const i=t.getStroke();if(!i)this.textStrokeState_=null;else{const f=i.getColor(),g=i.getLineCap(),_=i.getLineDash(),p=i.getLineDashOffset(),x=i.getLineJoin(),S=i.getWidth(),I=i.getMiterLimit();this.textStrokeState_={lineCap:g!==void 0?g:$i,lineDash:_||pi,lineDashOffset:p||xi,lineJoin:x!==void 0?x:qe,lineWidth:S!==void 0?S:Ci,miterLimit:I!==void 0?I:yi,strokeStyle:Pt(f||vi)}}const s=t.getFont(),r=t.getOffsetX(),o=t.getOffsetY(),a=t.getRotateWithView(),l=t.getRotation(),h=t.getScaleArray(),c=t.getText(),u=t.getTextAlign(),d=t.getTextBaseline();this.textState_={font:s!==void 0?s:Er,textAlign:u!==void 0?u:Si,textBaseline:d!==void 0?d:tn},this.text_=c!==void 0?Array.isArray(c)?c.reduce((f,g,_)=>f+=_%2?" ":g,""):c:"",this.textOffsetX_=r!==void 0?this.pixelRatio_*r:0,this.textOffsetY_=o!==void 0?this.pixelRatio_*o:0,this.textRotateWithView_=a!==void 0?a:!1,this.textRotation_=l!==void 0?l:0,this.textScale_=[this.pixelRatio_*h[0],this.pixelRatio_*h[1]]}}}const wh=Rh,Ot=.5;function Ih(n,t,e,i,s,r,o){const a=n[0]*Ot,l=n[1]*Ot,h=kt(a,l);h.imageSmoothingEnabled=!1;const c=h.canvas,u=new wh(h,Ot,s,null,o),d=e.length,f=Math.floor((256*256*256-1)/d),g={};for(let p=1;p<=d;++p){const x=e[p-1],S=x.getStyleFunction()||i;if(!i)continue;let I=S(x,r);if(!I)continue;Array.isArray(I)||(I=[I]);const T=(p*f).toString(16).padStart(7,"#00000");for(let N=0,Z=I.length;N<Z;++N){const y=I[N],H=y.getGeometryFunction()(x);if(!H||!Dt(s,H.getExtent()))continue;const q=y.clone(),j=q.getFill();j&&j.setColor(T);const W=q.getStroke();W&&(W.setColor(T),W.setLineDash(null)),q.setText(void 0);const R=y.getImage();if(R&&R.getOpacity()!==0){const z=R.getImageSize();if(!z)continue;const J=kt(z[0],z[1],void 0,{alpha:!1}),ct=J.canvas;J.fillStyle=T,J.fillRect(0,0,ct.width,ct.height),q.setImage(new Or({img:ct,imgSize:z,anchor:R.getAnchor(),anchorXUnits:"pixels",anchorYUnits:"pixels",offset:R.getOrigin(),opacity:1,size:R.getSize(),scale:R.getScale(),rotation:R.getRotation(),rotateWithView:R.getRotateWithView()}))}const at=q.getZIndex()||0;let B=g[at];B||(B={},g[at]=B,B.Polygon=[],B.Circle=[],B.LineString=[],B.Point=[]);const Y=H.getType();if(Y==="GeometryCollection"){const z=H.getGeometriesArrayRecursive();for(let J=0,ct=z.length;J<ct;++J){const ut=z[J];B[ut.getType().replace("Multi","")].push(ut,q)}}else B[Y.replace("Multi","")].push(H,q)}}const _=Object.keys(g).map(Number).sort(gi);for(let p=0,x=_.length;p<x;++p){const S=g[_[p]];for(const I in S){const D=S[I];for(let T=0,N=D.length;T<N;T+=2){u.setStyle(D[T+1]);for(let Z=0,y=t.length;Z<y;++Z)u.setTransform(t[Z]),u.drawGeometry(D[T])}}}return h.getImageData(0,0,c.width,c.height)}function Mh(n,t,e){const i=[];if(e){const s=Math.floor(Math.round(n[0])*Ot),r=Math.floor(Math.round(n[1])*Ot),o=(yt(s,0,e.width-1)+yt(r,0,e.height-1)*e.width)*4,a=e.data[o],l=e.data[o+1],c=e.data[o+2]+256*(l+256*a),u=Math.floor((256*256*256-1)/t.length);c&&c%u===0&&i.push(t[c/u-1])}return i}const Ah=.5,to={Point:Gh,LineString:Fh,Polygon:Nh,MultiPoint:Bh,MultiLineString:Oh,MultiPolygon:Ph,GeometryCollection:kh,Circle:Th};function Lh(n,t){return parseInt(nt(n),10)-parseInt(nt(t),10)}function bh(n,t){const e=Wn(n,t);return e*e}function Wn(n,t){return Ah*n/t}function Th(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(r||o){const l=n.getBuilder(e.getZIndex(),"Circle");l.setFillStrokeStyle(r,o),l.drawCircle(t,i)}const a=e.getText();if(a&&a.getText()){const l=(s||n).getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i)}}function rr(n,t,e,i,s,r,o){let a=!1;const l=e.getImage();if(l){const h=l.getImageState();h==ht.LOADED||h==ht.ERROR?l.unlistenImageChange(s):(h==ht.IDLE&&l.load(),l.listenImageChange(s),a=!0)}return Dh(n,t,e,i,r,o),a}function Dh(n,t,e,i,s,r){const o=e.getGeometryFunction()(t);if(!o)return;const a=o.simplifyTransformed(i,s);if(e.getRenderer())eo(n,a,e,t);else{const h=to[a.getType()];h(n,a,e,t,r)}}function eo(n,t,e,i){if(t.getType()=="GeometryCollection"){const r=t.getGeometries();for(let o=0,a=r.length;o<a;++o)eo(n,r[o],e,i);return}n.getBuilder(e.getZIndex(),"Default").drawCustom(t,i,e.getRenderer(),e.getHitDetectionRenderer())}function kh(n,t,e,i,s){const r=t.getGeometriesArray();let o,a;for(o=0,a=r.length;o<a;++o){const l=to[r[o].getType()];l(n,r[o],e,i,s)}}function Fh(n,t,e,i,s){const r=e.getStroke();if(r){const a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,r),a.drawLineString(t,i)}const o=e.getText();if(o&&o.getText()){const a=(s||n).getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i)}}function Oh(n,t,e,i,s){const r=e.getStroke();if(r){const a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,r),a.drawMultiLineString(t,i)}const o=e.getText();if(o&&o.getText()){const a=(s||n).getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i)}}function Ph(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(o||r){const l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(r,o),l.drawMultiPolygon(t,i)}const a=e.getText();if(a&&a.getText()){const l=(s||n).getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i)}}function Gh(n,t,e,i,s){const r=e.getImage(),o=e.getText();let a;if(r){if(r.getImageState()!=ht.LOADED)return;let l=n;if(s){const c=r.getDeclutterMode();if(c!=="none")if(l=s,c==="obstacle"){const u=n.getBuilder(e.getZIndex(),"Image");u.setImageStyle(r,a),u.drawPoint(t,i)}else o&&o.getText()&&(a={})}const h=l.getBuilder(e.getZIndex(),"Image");h.setImageStyle(r,a),h.drawPoint(t,i)}if(o&&o.getText()){let l=n;s&&(l=s);const h=l.getBuilder(e.getZIndex(),"Text");h.setTextStyle(o,a),h.drawText(t,i)}}function Bh(n,t,e,i,s){const r=e.getImage(),o=e.getText();let a;if(r){if(r.getImageState()!=ht.LOADED)return;let l=n;if(s){const c=r.getDeclutterMode();if(c!=="none")if(l=s,c==="obstacle"){const u=n.getBuilder(e.getZIndex(),"Image");u.setImageStyle(r,a),u.drawMultiPoint(t,i)}else o&&o.getText()&&(a={})}const h=l.getBuilder(e.getZIndex(),"Image");h.setImageStyle(r,a),h.drawMultiPoint(t,i)}if(o&&o.getText()){let l=n;s&&(l=s);const h=l.getBuilder(e.getZIndex(),"Text");h.setTextStyle(o,a),h.drawText(t,i)}}function Nh(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(r||o){const l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(r,o),l.drawPolygon(t,i)}const a=e.getText();if(a&&a.getText()){const l=(s||n).getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i)}}class Xh extends Ql{constructor(t){super(t),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.animatingOrInteracting_,this.hitDetectionImageData_=null,this.renderedFeatures_=null,this.renderedRevision_=-1,this.renderedResolution_=NaN,this.renderedExtent_=Le(),this.wrappedRenderedExtent_=Le(),this.renderedRotation_,this.renderedCenter_=null,this.renderedProjection_=null,this.renderedRenderOrder_=null,this.replayGroup_=null,this.replayGroupChanged=!0,this.declutterExecutorGroup=null,this.clipping=!0,this.compositionContext_=null,this.opacity_=1}renderWorlds(t,e,i){const s=e.extent,r=e.viewState,o=r.center,a=r.resolution,l=r.projection,h=r.rotation,c=l.getExtent(),u=this.getLayer().getSource(),d=e.pixelRatio,f=e.viewHints,g=!(f[Mt.ANIMATING]||f[Mt.INTERACTING]),_=this.compositionContext_,p=Math.round(e.size[0]*d),x=Math.round(e.size[1]*d),S=u.getWrapX()&&l.canWrapX(),I=S?At(c):null,D=S?Math.ceil((s[2]-c[2])/I)+1:1;let T=S?Math.floor((s[0]-c[0])/I):0;do{const N=this.getRenderTransform(o,a,h,d,p,x,T*I);t.execute(_,1,N,h,g,void 0,i)}while(++T<D)}setupCompositionContext_(){if(this.opacity_!==1){const t=kt(this.context.canvas.width,this.context.canvas.height,qs);this.compositionContext_=t}else this.compositionContext_=this.context}releaseCompositionContext_(){if(this.opacity_!==1){const t=this.context.globalAlpha;this.context.globalAlpha=this.opacity_,this.context.drawImage(this.compositionContext_.canvas,0,0),this.context.globalAlpha=t,To(this.compositionContext_),qs.push(this.compositionContext_.canvas),this.compositionContext_=null}}renderDeclutter(t){this.declutterExecutorGroup&&(this.setupCompositionContext_(),this.renderWorlds(this.declutterExecutorGroup,t,t.declutterTree),this.releaseCompositionContext_())}renderFrame(t,e){const i=t.pixelRatio,s=t.layerStatesArray[t.layerIndex];qa(this.pixelTransform,1/i,1/i),Ka(this.inversePixelTransform,this.pixelTransform);const r=Qa(this.pixelTransform);this.useContainer(e,r,this.getBackground(t));const o=this.context,a=o.canvas,l=this.replayGroup_,h=this.declutterExecutorGroup;if((!l||l.isEmpty())&&(!h||h.isEmpty()))return null;const c=Math.round(t.size[0]*i),u=Math.round(t.size[1]*i);a.width!=c||a.height!=u?(a.width=c,a.height=u,a.style.transform!==r&&(a.style.transform=r)):this.containerReused||o.clearRect(0,0,c,u),this.preRender(o,t);const d=t.viewState;d.projection,this.opacity_=s.opacity,this.setupCompositionContext_();let f=!1,g=!0;if(s.extent&&this.clipping){const _=Ze(s.extent);g=Dt(_,t.extent),f=g&&!ze(_,t.extent),f&&this.clipUnrotated(this.compositionContext_,t,_)}return g&&this.renderWorlds(l,t),f&&this.compositionContext_.restore(),this.releaseCompositionContext_(),this.postRender(o,t),this.renderedRotation_!==d.rotation&&(this.renderedRotation_=d.rotation,this.hitDetectionImageData_=null),this.container}getFeatures(t){return new Promise(e=>{if(!this.hitDetectionImageData_&&!this.animatingOrInteracting_){const i=[this.context.canvas.width,this.context.canvas.height];St(this.pixelTransform,i);const s=this.renderedCenter_,r=this.renderedResolution_,o=this.renderedRotation_,a=this.renderedProjection_,l=this.wrappedRenderedExtent_,h=this.getLayer(),c=[],u=i[0]*Ot,d=i[1]*Ot;c.push(this.getRenderTransform(s,r,o,Ot,u,d,0).slice());const f=h.getSource(),g=a.getExtent();if(f.getWrapX()&&a.canWrapX()&&!ze(g,l)){let _=l[0];const p=At(g);let x=0,S;for(;_<g[0];)--x,S=p*x,c.push(this.getRenderTransform(s,r,o,Ot,u,d,S).slice()),_+=p;for(x=0,_=l[2];_>g[2];)++x,S=p*x,c.push(this.getRenderTransform(s,r,o,Ot,u,d,S).slice()),_-=p}this.hitDetectionImageData_=Ih(i,c,this.renderedFeatures_,h.getStyleFunction(),l,r,o)}e(Mh(t,this.renderedFeatures_,this.hitDetectionImageData_))})}forEachFeatureAtCoordinate(t,e,i,s,r){if(!this.replayGroup_)return;const o=e.viewState.resolution,a=e.viewState.rotation,l=this.getLayer(),h={},c=function(f,g,_){const p=nt(f),x=h[p];if(x){if(x!==!0&&_<x.distanceSq){if(_===0)return h[p]=!0,r.splice(r.lastIndexOf(x),1),s(f,l,g);x.geometry=g,x.distanceSq=_}}else{if(_===0)return h[p]=!0,s(f,l,g);r.push(h[p]={feature:f,layer:l,geometry:g,distanceSq:_,callback:s})}};let u;const d=[this.replayGroup_];return this.declutterExecutorGroup&&d.push(this.declutterExecutorGroup),d.some(f=>u=f.forEachFeatureAtCoordinate(t,o,a,i,c,f===this.declutterExecutorGroup&&e.declutterTree?e.declutterTree.all().map(g=>g.value):null)),u}handleFontsChanged(){const t=this.getLayer();t.getVisible()&&this.replayGroup_&&t.changed()}handleStyleImageChange_(t){this.renderIfReadyAndVisible()}prepareFrame(t){const e=this.getLayer(),i=e.getSource();if(!i)return!1;const s=t.viewHints[Mt.ANIMATING],r=t.viewHints[Mt.INTERACTING],o=e.getUpdateWhileAnimating(),a=e.getUpdateWhileInteracting();if(this.ready&&!o&&s||!a&&r)return this.animatingOrInteracting_=!0,!0;this.animatingOrInteracting_=!1;const l=t.extent,h=t.viewState,c=h.projection,u=h.resolution,d=t.pixelRatio,f=e.getRevision(),g=e.getRenderBuffer();let _=e.getRenderOrder();_===void 0&&(_=Lh);const p=h.center.slice(),x=cn(l,g*u),S=x.slice(),I=[x.slice()],D=c.getExtent();if(i.getWrapX()&&c.canWrapX()&&!ze(D,t.extent)){const B=At(D),Y=Math.max(At(x)/2,B);x[0]=D[0]-Y,x[2]=D[2]+Y,Aa(p,c);const z=Fr(I[0],c);z[0]<D[0]&&z[2]<D[2]?I.push([z[0]+B,z[1],z[2]+B,z[3]]):z[0]>D[0]&&z[2]>D[2]&&I.push([z[0]-B,z[1],z[2]-B,z[3]])}if(this.ready&&this.renderedResolution_==u&&this.renderedRevision_==f&&this.renderedRenderOrder_==_&&ze(this.wrappedRenderedExtent_,x))return be(this.renderedExtent_,S)||(this.hitDetectionImageData_=null,this.renderedExtent_=S),this.renderedCenter_=p,this.replayGroupChanged=!1,!0;this.replayGroup_=null;const T=new er(Wn(u,d),x,u,d);let N;this.getLayer().getDeclutter()&&(N=new er(Wn(u,d),x,u,d));let Z;for(let B=0,Y=I.length;B<Y;++B)i.loadFeatures(I[B],u,c);const y=bh(u,d);let H=!0;const q=B=>{let Y;const z=B.getStyleFunction()||e.getStyleFunction();if(z&&(Y=z(B,u)),Y){const J=this.renderFeature(B,y,Y,T,Z,N);H=H&&!J}},j=is(x),W=i.getFeaturesInExtent(j);_&&W.sort(_);for(let B=0,Y=W.length;B<Y;++B)q(W[B]);this.renderedFeatures_=W,this.ready=H;const R=T.finish(),at=new sr(x,u,d,i.getOverlaps(),R,e.getRenderBuffer());return N&&(this.declutterExecutorGroup=new sr(x,u,d,i.getOverlaps(),N.finish(),e.getRenderBuffer())),this.renderedResolution_=u,this.renderedRevision_=f,this.renderedRenderOrder_=_,this.renderedExtent_=S,this.wrappedRenderedExtent_=x,this.renderedCenter_=p,this.renderedProjection_=c,this.replayGroup_=at,this.hitDetectionImageData_=null,this.replayGroupChanged=!0,!0}renderFeature(t,e,i,s,r,o){if(!i)return!1;let a=!1;if(Array.isArray(i))for(let l=0,h=i.length;l<h;++l)a=rr(s,t,i[l],e,this.boundHandleStyleImageChange_,r,o)||a;else a=rr(s,t,i,e,this.boundHandleStyleImageChange_,r,o);return a}}const Wh=Xh;class Yh extends sh{constructor(t){super(t)}createRenderer(){return new Wh(this)}}const io=Yh,Yt={SINGLECLICK:"singleclick",CLICK:vt.CLICK,DBLCLICK:vt.DBLCLICK,POINTERDRAG:"pointerdrag",POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"},or={ACTIVE:"active"};class zh extends ue{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(or.ACTIVE)}getMap(){return this.map_}handleEvent(t){return!0}setActive(t){this.set(or.ACTIVE,t)}setMap(t){this.map_=t}}const Vh=zh;class Zh extends Vh{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==Yt.POINTERDRAG)this.handleDragEvent(t),t.originalEvent.preventDefault();else if(t.type==Yt.POINTERUP){const i=this.handleUpEvent(t);this.handlingDownUpSequence=i&&this.targetPointers.length>0}}else if(t.type==Yt.POINTERDOWN){const i=this.handleDownEvent(t);this.handlingDownUpSequence=i,e=this.stopDown(i)}else t.type==Yt.POINTERMOVE&&this.handleMoveEvent(t);return!e}handleMoveEvent(t){}handleUpEvent(t){return!1}stopDown(t){return t}updateTrackedPointers_(t){t.activePointers&&(this.targetPointers=t.activePointers)}}const jh=Zh,Uh=function(n){const t=n.originalEvent;return t.altKey&&!(t.metaKey||t.ctrlKey)&&!t.shiftKey},Hh=yr,qh=function(n){return n.type==Yt.SINGLECLICK},Kh=function(n){const t=n.originalEvent;return ft(t!==void 0,56),t.isPrimary&&t.button===0},ar=0,fi=1,lr=[0,0,0,0],He=[],Tn={MODIFYSTART:"modifystart",MODIFYEND:"modifyend"};class Dn extends ti{constructor(t,e,i){super(t),this.features=e,this.mapBrowserEvent=i}}class Jh extends jh{constructor(t){super(t),this.on,this.once,this.un,this.boundHandleFeatureChange_=this.handleFeatureChange_.bind(this),this.condition_=t.condition?t.condition:Kh,this.defaultDeleteCondition_=function(i){return Uh(i)&&qh(i)},this.deleteCondition_=t.deleteCondition?t.deleteCondition:this.defaultDeleteCondition_,this.insertVertexCondition_=t.insertVertexCondition?t.insertVertexCondition:Hh,this.vertexFeature_=null,this.vertexSegments_=null,this.lastPixel_=[0,0],this.ignoreNextSingleClick_=!1,this.featuresBeingModified_=null,this.rBush_=new Nn,this.pixelTolerance_=t.pixelTolerance!==void 0?t.pixelTolerance:10,this.snappedToVertex_=!1,this.changingFeature_=!1,this.dragSegments_=[],this.overlay_=new io({source:new Hr({useSpatialIndex:!1,wrapX:!!t.wrapX}),style:t.style?t.style:$h(),updateWhileAnimating:!0,updateWhileInteracting:!0}),this.SEGMENT_WRITERS_={Point:this.writePointGeometry_.bind(this),LineString:this.writeLineStringGeometry_.bind(this),LinearRing:this.writeLineStringGeometry_.bind(this),Polygon:this.writePolygonGeometry_.bind(this),MultiPoint:this.writeMultiPointGeometry_.bind(this),MultiLineString:this.writeMultiLineStringGeometry_.bind(this),MultiPolygon:this.writeMultiPolygonGeometry_.bind(this),Circle:this.writeCircleGeometry_.bind(this),GeometryCollection:this.writeGeometryCollectionGeometry_.bind(this)},this.source_=null,this.hitDetection_=null;let e;if(t.features?e=t.features:t.source&&(this.source_=t.source,e=new Bn(this.source_.getFeatures()),this.source_.addEventListener(Rt.ADDFEATURE,this.handleSourceAdd_.bind(this)),this.source_.addEventListener(Rt.REMOVEFEATURE,this.handleSourceRemove_.bind(this))),!e)throw new Error("The modify interaction requires features, a source or a layer");t.hitDetection&&(this.hitDetection_=t.hitDetection),this.features_=e,this.features_.forEach(this.addFeature_.bind(this)),this.features_.addEventListener(oe.ADD,this.handleFeatureAdd_.bind(this)),this.features_.addEventListener(oe.REMOVE,this.handleFeatureRemove_.bind(this)),this.lastPointerEvent_=null,this.delta_=[0,0],this.snapToPointer_=t.snapToPointer===void 0?!this.hitDetection_:t.snapToPointer}addFeature_(t){const e=t.getGeometry();if(e){const s=this.SEGMENT_WRITERS_[e.getType()];s&&s(t,e)}const i=this.getMap();i&&i.isRendered()&&this.getActive()&&this.handlePointerAtPixel_(this.lastPixel_,i),t.addEventListener(vt.CHANGE,this.boundHandleFeatureChange_)}willModifyFeatures_(t,e){if(!this.featuresBeingModified_){this.featuresBeingModified_=new Bn;const i=this.featuresBeingModified_.getArray();for(let s=0,r=e.length;s<r;++s){const o=e[s];for(let a=0,l=o.length;a<l;++a){const h=o[a].feature;h&&!i.includes(h)&&this.featuresBeingModified_.push(h)}}this.featuresBeingModified_.getLength()===0?this.featuresBeingModified_=null:this.dispatchEvent(new Dn(Tn.MODIFYSTART,this.featuresBeingModified_,t))}}removeFeature_(t){this.removeFeatureSegmentData_(t),this.vertexFeature_&&this.features_.getLength()===0&&(this.overlay_.getSource().removeFeature(this.vertexFeature_),this.vertexFeature_=null),t.removeEventListener(vt.CHANGE,this.boundHandleFeatureChange_)}removeFeatureSegmentData_(t){const e=this.rBush_,i=[];e.forEach(function(s){t===s.feature&&i.push(s)});for(let s=i.length-1;s>=0;--s){const r=i[s];for(let o=this.dragSegments_.length-1;o>=0;--o)this.dragSegments_[o][0]===r&&this.dragSegments_.splice(o,1);e.remove(r)}}setActive(t){this.vertexFeature_&&!t&&(this.overlay_.getSource().removeFeature(this.vertexFeature_),this.vertexFeature_=null),super.setActive(t)}setMap(t){this.overlay_.setMap(t),super.setMap(t)}getOverlay(){return this.overlay_}handleSourceAdd_(t){t.feature&&this.features_.push(t.feature)}handleSourceRemove_(t){t.feature&&this.features_.remove(t.feature)}handleFeatureAdd_(t){this.addFeature_(t.element)}handleFeatureChange_(t){if(!this.changingFeature_){const e=t.target;this.removeFeature_(e),this.addFeature_(e)}}handleFeatureRemove_(t){this.removeFeature_(t.element)}writePointGeometry_(t,e){const i=e.getCoordinates(),s={feature:t,geometry:e,segment:[i,i]};this.rBush_.insert(e.getExtent(),s)}writeMultiPointGeometry_(t,e){const i=e.getCoordinates();for(let s=0,r=i.length;s<r;++s){const o=i[s],a={feature:t,geometry:e,depth:[s],index:s,segment:[o,o]};this.rBush_.insert(e.getExtent(),a)}}writeLineStringGeometry_(t,e){const i=e.getCoordinates();for(let s=0,r=i.length-1;s<r;++s){const o=i.slice(s,s+2),a={feature:t,geometry:e,index:s,segment:o};this.rBush_.insert(Nt(o),a)}}writeMultiLineStringGeometry_(t,e){const i=e.getCoordinates();for(let s=0,r=i.length;s<r;++s){const o=i[s];for(let a=0,l=o.length-1;a<l;++a){const h=o.slice(a,a+2),c={feature:t,geometry:e,depth:[s],index:a,segment:h};this.rBush_.insert(Nt(h),c)}}}writePolygonGeometry_(t,e){const i=e.getCoordinates();for(let s=0,r=i.length;s<r;++s){const o=i[s];for(let a=0,l=o.length-1;a<l;++a){const h=o.slice(a,a+2),c={feature:t,geometry:e,depth:[s],index:a,segment:h};this.rBush_.insert(Nt(h),c)}}}writeMultiPolygonGeometry_(t,e){const i=e.getCoordinates();for(let s=0,r=i.length;s<r;++s){const o=i[s];for(let a=0,l=o.length;a<l;++a){const h=o[a];for(let c=0,u=h.length-1;c<u;++c){const d=h.slice(c,c+2),f={feature:t,geometry:e,depth:[a,s],index:c,segment:d};this.rBush_.insert(Nt(d),f)}}}}writeCircleGeometry_(t,e){const i=e.getCenter(),s={feature:t,geometry:e,index:ar,segment:[i,i]},r={feature:t,geometry:e,index:fi,segment:[i,i]},o=[s,r];s.featureSegments=o,r.featureSegments=o,this.rBush_.insert(qi(i),s);let a=e;this.rBush_.insert(a.getExtent(),r)}writeGeometryCollectionGeometry_(t,e){const i=e.getGeometriesArray();for(let s=0;s<i.length;++s){const r=i[s],o=this.SEGMENT_WRITERS_[r.getType()];o(t,r)}}createOrUpdateVertexFeature_(t,e,i){let s=this.vertexFeature_;return s?s.getGeometry().setCoordinates(t):(s=new ks(new Ai(t)),this.vertexFeature_=s,this.overlay_.getSource().addFeature(s)),s.set("features",e),s.set("geometries",i),s}handleEvent(t){if(!t.originalEvent)return!0;this.lastPointerEvent_=t;let e;return!t.map.getView().getInteracting()&&t.type==Yt.POINTERMOVE&&!this.handlingDownUpSequence&&this.handlePointerMove_(t),this.vertexFeature_&&this.deleteCondition_(t)&&(t.type!=Yt.SINGLECLICK||!this.ignoreNextSingleClick_?e=this.removePoint():e=!0),t.type==Yt.SINGLECLICK&&(this.ignoreNextSingleClick_=!1),super.handleEvent(t)&&!e}handleDragEvent(t){this.ignoreNextSingleClick_=!1,this.willModifyFeatures_(t,this.dragSegments_);const e=[t.coordinate[0]+this.delta_[0],t.coordinate[1]+this.delta_[1]],i=[],s=[];for(let r=0,o=this.dragSegments_.length;r<o;++r){const a=this.dragSegments_[r],l=a[0],h=l.feature;i.includes(h)||i.push(h);const c=l.geometry;s.includes(c)||s.push(c);const u=l.depth;let d;const f=l.segment,g=a[1];for(;e.length<c.getStride();)e.push(f[g][e.length]);switch(c.getType()){case"Point":d=e,f[0]=e,f[1]=e;break;case"MultiPoint":d=c.getCoordinates(),d[l.index]=e,f[0]=e,f[1]=e;break;case"LineString":d=c.getCoordinates(),d[l.index+g]=e,f[g]=e;break;case"MultiLineString":d=c.getCoordinates(),d[u[0]][l.index+g]=e,f[g]=e;break;case"Polygon":d=c.getCoordinates(),d[u[0]][l.index+g]=e,f[g]=e;break;case"MultiPolygon":d=c.getCoordinates(),d[u[1]][u[0]][l.index+g]=e,f[g]=e;break;case"Circle":if(f[0]=e,f[1]=e,l.index===ar)this.changingFeature_=!0,c.setCenter(e),this.changingFeature_=!1;else{this.changingFeature_=!0,t.map.getView().getProjection();let _=Ls(xt(c.getCenter()),xt(e));c.setRadius(_),this.changingFeature_=!1}break}d&&this.setGeometryCoordinates_(c,d)}this.createOrUpdateVertexFeature_(e,i,s)}handleDownEvent(t){if(!this.condition_(t))return!1;const e=t.coordinate;this.handlePointerAtPixel_(t.pixel,t.map,e),this.dragSegments_.length=0,this.featuresBeingModified_=null;const i=this.vertexFeature_;if(i){t.map.getView().getProjection();const s=[],r=i.getGeometry().getCoordinates(),o=Nt([r]),a=this.rBush_.getInExtent(o),l={};a.sort(Qh);for(let h=0,c=a.length;h<c;++h){const u=a[h],d=u.segment;let f=nt(u.geometry);const g=u.depth;if(g&&(f+="-"+g.join("-")),l[f]||(l[f]=new Array(2)),u.geometry.getType()==="Circle"&&u.index===fi){const _=cr(e,u);Tt(_,r)&&!l[f][0]&&(this.dragSegments_.push([u,0]),l[f][0]=u);continue}if(Tt(d[0],r)&&!l[f][0]){this.dragSegments_.push([u,0]),l[f][0]=u;continue}if(Tt(d[1],r)&&!l[f][1]){if(l[f][0]&&l[f][0].index===0){let _=u.geometry.getCoordinates();switch(u.geometry.getType()){case"LineString":case"MultiLineString":continue;case"MultiPolygon":_=_[g[1]];case"Polygon":if(u.index!==_[g[0]].length-2)continue;break}}this.dragSegments_.push([u,1]),l[f][1]=u;continue}nt(d)in this.vertexSegments_&&!l[f][0]&&!l[f][1]&&this.insertVertexCondition_(t)&&s.push(u)}s.length&&this.willModifyFeatures_(t,[s]);for(let h=s.length-1;h>=0;--h)this.insertVertex_(s[h],r)}return!!this.vertexFeature_}handleUpEvent(t){for(let e=this.dragSegments_.length-1;e>=0;--e){const i=this.dragSegments_[e][0],s=i.geometry;if(s.getType()==="Circle"){const r=s.getCenter(),o=i.featureSegments[0],a=i.featureSegments[1];o.segment[0]=r,o.segment[1]=r,a.segment[0]=r,a.segment[1]=r,this.rBush_.update(qi(r),o);let l=s;this.rBush_.update(l.getExtent(),a)}else this.rBush_.update(Nt(i.segment),i)}return this.featuresBeingModified_&&(this.dispatchEvent(new Dn(Tn.MODIFYEND,this.featuresBeingModified_,t)),this.featuresBeingModified_=null),!1}handlePointerMove_(t){this.lastPixel_=t.pixel,this.handlePointerAtPixel_(t.pixel,t.map,t.coordinate)}handlePointerAtPixel_(t,e,i){const s=i||e.getCoordinateFromPixel(t);e.getView().getProjection();const r=function(l,h){return hr(s,l)-hr(s,h)};let o,a;if(this.hitDetection_){const l=typeof this.hitDetection_=="object"?h=>h===this.hitDetection_:void 0;e.forEachFeatureAtPixel(t,(h,c,u)=>{u&&(u=new Ai(Mi(u.getCoordinates())));const d=u||h.getGeometry();if(d.getType()==="Point"&&h instanceof ks&&this.features_.getArray().includes(h)){a=d;const f=h.getGeometry().getFlatCoordinates().slice(0,2);o=[{feature:h,geometry:a,segment:[f,f]}]}return!0},{layerFilter:l})}if(!o){const l=Ze(qi(s,lr)),h=e.getView().getResolution()*this.pixelTolerance_,c=is(cn(l,h,lr));o=this.rBush_.getInExtent(c)}if(o&&o.length>0){const l=o.sort(r)[0],h=l.segment;let c=cr(s,l);const u=e.getPixelFromCoordinate(c);let d=Ls(t,u);if(a||d<=this.pixelTolerance_){const f={};if(f[nt(h)]=!0,this.snapToPointer_||(this.delta_[0]=c[0]-s[0],this.delta_[1]=c[1]-s[1]),l.geometry.getType()==="Circle"&&l.index===fi)this.snappedToVertex_=!0,this.createOrUpdateVertexFeature_(c,[l.feature],[l.geometry]);else{const g=e.getPixelFromCoordinate(h[0]),_=e.getPixelFromCoordinate(h[1]),p=Ii(u,g),x=Ii(u,_);d=Math.sqrt(Math.min(p,x)),this.snappedToVertex_=d<=this.pixelTolerance_,this.snappedToVertex_&&(c=p>x?h[1]:h[0]),this.createOrUpdateVertexFeature_(c,[l.feature],[l.geometry]);const S={};S[nt(l.geometry)]=!0;for(let I=1,D=o.length;I<D;++I){const T=o[I].segment;if(Tt(h[0],T[0])&&Tt(h[1],T[1])||Tt(h[0],T[1])&&Tt(h[1],T[0])){const N=nt(o[I].geometry);N in S||(S[N]=!0,f[nt(T)]=!0)}else break}}this.vertexSegments_=f;return}}this.vertexFeature_&&(this.overlay_.getSource().removeFeature(this.vertexFeature_),this.vertexFeature_=null)}insertVertex_(t,e){const i=t.segment,s=t.feature,r=t.geometry,o=t.depth,a=t.index;let l;for(;e.length<r.getStride();)e.push(0);switch(r.getType()){case"MultiLineString":l=r.getCoordinates(),l[o[0]].splice(a+1,0,e);break;case"Polygon":l=r.getCoordinates(),l[o[0]].splice(a+1,0,e);break;case"MultiPolygon":l=r.getCoordinates(),l[o[1]][o[0]].splice(a+1,0,e);break;case"LineString":l=r.getCoordinates(),l.splice(a+1,0,e);break;default:return}this.setGeometryCoordinates_(r,l);const h=this.rBush_;h.remove(t),this.updateSegmentIndices_(r,a,o,1);const c={segment:[i[0],e],feature:s,geometry:r,depth:o,index:a};h.insert(Nt(c.segment),c),this.dragSegments_.push([c,1]);const u={segment:[e,i[1]],feature:s,geometry:r,depth:o,index:a+1};h.insert(Nt(u.segment),u),this.dragSegments_.push([u,0]),this.ignoreNextSingleClick_=!0}removePoint(){if(this.lastPointerEvent_&&this.lastPointerEvent_.type!=Yt.POINTERDRAG){const t=this.lastPointerEvent_;this.willModifyFeatures_(t,this.dragSegments_);const e=this.removeVertex_();return this.featuresBeingModified_&&this.dispatchEvent(new Dn(Tn.MODIFYEND,this.featuresBeingModified_,t)),this.featuresBeingModified_=null,e}return!1}removeVertex_(){const t=this.dragSegments_,e={};let i=!1,s,r,o,a,l,h,c,u,d,f,g;for(l=t.length-1;l>=0;--l)o=t[l],f=o[0],g=nt(f.feature),f.depth&&(g+="-"+f.depth.join("-")),g in e||(e[g]={}),o[1]===0?(e[g].right=f,e[g].index=f.index):o[1]==1&&(e[g].left=f,e[g].index=f.index+1);for(g in e){switch(d=e[g].right,c=e[g].left,h=e[g].index,u=h-1,c!==void 0?f=c:f=d,u<0&&(u=0),a=f.geometry,r=a.getCoordinates(),s=r,i=!1,a.getType()){case"MultiLineString":r[f.depth[0]].length>2&&(r[f.depth[0]].splice(h,1),i=!0);break;case"LineString":r.length>2&&(r.splice(h,1),i=!0);break;case"MultiPolygon":s=s[f.depth[1]];case"Polygon":s=s[f.depth[0]],s.length>4&&(h==s.length-1&&(h=0),s.splice(h,1),i=!0,h===0&&(s.pop(),s.push(s[0]),u=s.length-1));break}if(i){this.setGeometryCoordinates_(a,r);const _=[];if(c!==void 0&&(this.rBush_.remove(c),_.push(c.segment[0])),d!==void 0&&(this.rBush_.remove(d),_.push(d.segment[1])),c!==void 0&&d!==void 0){const p={depth:f.depth,feature:f.feature,geometry:f.geometry,index:u,segment:_};this.rBush_.insert(Nt(p.segment),p)}this.updateSegmentIndices_(a,h,f.depth,-1),this.vertexFeature_&&(this.overlay_.getSource().removeFeature(this.vertexFeature_),this.vertexFeature_=null),t.length=0}}return i}setGeometryCoordinates_(t,e){this.changingFeature_=!0,t.setCoordinates(e),this.changingFeature_=!1}updateSegmentIndices_(t,e,i,s){this.rBush_.forEachInExtent(t.getExtent(),function(r){r.geometry===t&&(i===void 0||r.depth===void 0||be(r.depth,i))&&r.index>e&&(r.index+=s)})}}function Qh(n,t){return n.index-t.index}function hr(n,t,e){const i=t.geometry;if(i.getType()==="Circle"){let r=i;if(t.index===fi){const o=Ii(r.getCenter(),xt(n)),a=Math.sqrt(o)-r.getRadius();return a*a}}const s=xt(n);return He[0]=xt(t.segment[0]),He[1]=xt(t.segment[1]),Ma(s,He)}function cr(n,t,e){const i=t.geometry;if(i.getType()==="Circle"&&t.index===fi)return Mi(i.getClosestPoint(xt(n)));const s=xt(n);return He[0]=xt(t.segment[0]),He[1]=xt(t.segment[1]),Mi(Br(s,He))}function $h(){const n=ca();return function(t,e){return n.Point}}const tc=Jh;const jt=n=>(go("data-v-5f0277c2"),n=n(),_o(),n),ec={class:"center"},ic=jt(()=>P("div",{style:{width:"100%",height:"100%"},id:"cesiumContainer"},null,-1)),nc={class:"rightWra"},sc={class:"rightTop"},rc=jt(()=>P("div",{class:"title"},[P("span",null,"\u4F4D\u7F6E\u5B9A\u4F4D")],-1)),oc={class:"depth"},ac={class:"rightCenter"},lc={key:0,class:"zoning"},hc={key:1,class:"LonAndLat"},cc={class:"LonAndLatDiv"},uc={class:"LonAndLatDiv"},dc={key:2,class:"LonAndLat"},fc={class:"LonDiv"},gc={class:"inputDiv"},_c={class:"LatDiv"},mc={class:"inputDiv"},pc={class:"seach_button"},xc={class:"rightbottom"},yc=jt(()=>P("div",{class:"title"},[P("span",null,"\u4FE1\u606F\u7EDF\u8BA1")],-1)),vc=["id"],Sc={key:0,style:{width:"14px"},src:Qe},Cc={key:1,style:{width:"14px"},src:$e},Ec=["id"],Rc={key:0,style:{width:"14px"},src:Qe},wc={key:1,style:{width:"14px"},src:$e},Ic=["id"],Mc={key:0,style:{width:"14px"},src:Qe},Ac={key:1,style:{width:"14px"},src:$e},Lc=["id"],bc={key:0,style:{width:"14px"},src:Qe},Tc={key:1,style:{width:"14px"},src:$e},Dc=["id"],kc={key:0,style:{width:"14px"},src:Qe},Fc={key:1,style:{width:"14px"},src:$e},Oc=["id"],Pc={key:0,style:{width:"14px"},src:Qe},Gc={key:1,style:{width:"14px"},src:$e},Bc={class:"chart_div"},Nc={class:"chart_div_title"},Xc=jt(()=>P("img",{src:no,style:{width:"14px",height:"14px",cursor:"pointer"}},null,-1)),Wc={key:0,class:"Involution"},Yc=jt(()=>P("img",{src:dr},null,-1)),zc={key:0},Vc=jt(()=>P("img",{src:dr},null,-1)),Zc={key:0,src:ur,alt:""},jc={key:0,class:"imgrotate",src:ur,alt:""},Uc={class:"tool"},Hc=jt(()=>P("img",{src:so,alt:""},null,-1)),qc=jt(()=>P("img",{src:ro,alt:""},null,-1)),Kc=jt(()=>P("img",{src:xo,alt:""},null,-1)),Jc={class:"treeDiv"},Qc=["id"],$c={class:"farmlandTimeDivCenter"},tu=fo('<div id="popup" class="ol-popup" data-v-5f0277c2><div class="pophead" style="width:100%;" data-v-5f0277c2><div id="popup-title" style="font-size:20px;font-weight:400;letter-spacing:1px;color:rgba(246, 255, 255, 1);line-height:42px;padding-left:45px;" data-v-5f0277c2></div><a href="#" id="popup-closer" class="ol-popup-closer" data-v-5f0277c2></a></div><div id="popup-background" data-v-5f0277c2><div id="popup-content" style="padding:10px;font-size:14px;" data-v-5f0277c2></div><div id="popup-pagination" data-v-5f0277c2><button id="popup-prev" data-v-5f0277c2>\u4E0A\u4E00\u5C42</button><button id="popup-next" data-v-5f0277c2>\u4E0B\u4E00\u5C42</button></div></div></div>',1),eu={__name:"index",setup(n){U([]),U(!1);let t=U(!1),e=U(!0),i=U(""),s=U([]),r=U("");U(""),U("");let o=U({Lon:"",Lat:""}),a=U({Lon:{londu:"",lonfen:"",lonmiao:""},Lat:{latdu:"",latfen:"",latmiao:""}});const l=U("null");let h=U(null),c=U([]),u=U("2"),d=U([]),f=U(1),g=U([]);const _={children:"children",label:"label"};let p=U(!0);U([]);let x=U([]),S=U([]),I=U([]),D=U("");U({});let T=U(""),N=U(""),Z=U("\u9AD8\u6807\u51C6\u519C\u7530");ao(()=>d.value,(v,m)=>{if(console.log(v,m),v.length>m.length){const E=v.filter(w=>{if(m.findIndex(F=>F===w)<0)return w});console.log(E),E.forEach(w=>{j[w]?De(j[w]):W[w]&&De(W[w])}),console.log(R.getLayers().getArray())}else v.length<m.length&&m.filter(w=>{if(v.findIndex(F=>F===w)<0)return w}).forEach(w=>{j[w]?R.getLayers().getArray().forEach((A,F)=>{A.A.name&&A.A.name==j[w].name&&R.getLayers().removeAt(F)}):W[w]&&R.getLayers().getArray().forEach((A,F)=>{A.A.name&&A.A.name==W[w].name&&R.getLayers().removeAt(F)})})});let y=U([]);const H=[{label:"\u9AD8\u6807\u51C6\u519C\u7530",children:[{label:"\u9AD8\u6807\u51C6\u519C\u7530"}]},{label:"\u6C38\u4E45\u57FA\u672C\u519C\u7530",children:[{label:"\u6C38\u4E45\u57FA\u672C\u519C\u7530"}]},{label:"\u8015\u5730",children:[{label:"\u8015\u5730"}]},{label:"\u7CAE\u98DF\u529F\u80FD\u533A",children:[{label:"\u7247\u5757\u4FE1\u606F"},{label:"\u5730\u5757\u4FE1\u606F"}]},{label:"\u571F\u5730\u786E\u6743",children:[{label:"\u571F\u5730\u786E\u6743"}]}];let q=U({2012:!0,2013:!0,2014:!0,2015:!0,2016:!0,2017:!0,2018:!0,2019:!0,2020:!0,2021:!0,2022:!0}),j={2012:{setOf:"T2012@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2013:{setOf:"T2013@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2014:{setOf:"T2014@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2015:{setOf:"T2015@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2016:{setOf:"T2016@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2017:{setOf:"T2017@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2018:{setOf:"T2018@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2019:{setOf:"T2019@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2020:{setOf:"T2020@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2021:{setOf:"T2021@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"},2022:{setOf:"T2022@gaobiaozhunnongtianxk",name:"map-gaobiaozhunnongtianxk"}},W={\u6C38\u4E45\u57FA\u672C\u519C\u7530:{setOf:"yongnongSanqusanxianWGS84@yongjiujibennongtianxk",name:"map-yongjiujibennongtianxk"},\u8015\u5730:{setOf:"gengbaoSanqusanxianWGS84@gengdibaohuxk",name:"map-gengdibaohuxk"},\u7247\u5757\u4FE1\u606F:{setOf:"LQPK3702112019WGS84@liangqupiankuaixk",name:"map-liangqupiankuaixk"},\u5730\u5757\u4FE1\u606F:{setOf:"LQDK3702112019WGS84@liangqudikuaixk",name:"map-liangqudikuaixk"},\u571F\u5730\u786E\u6743:{setOf:"DK3702112022WGS84@tudiquequanxk",name:"map-tudiquequanxk"}};lo(()=>{z(),J(),M(),Fe(),ii(),Gt("\u9AD8\u6807\u51C6\u519C\u7530")}),ho(()=>{document.querySelector(".mode").style.display="none",window.document.querySelector("#screenfull").style.display="block"});let R=U(null);U(null);let at=U(null),B=U(null),Y=U(null);function z(){var v=document.querySelector(".center"),m=document.getElementById("cesiumContainer");R=new ol.Map({target:"cesiumContainer",controls:[],view:new ol.View({center:[119.88661841637813,35.85667692242919],zoom:11,maxZoom:16.5,projection:"EPSG:4326"}),layers:[new ol.layer.Tile({source:new ol.source.Tianditu({layerType:"img",key:"1d109683f4d84198e37a38c442d68311"})})]}),fn(),Oi(),R.on("moveend",function(w){var A=R.getView().getZoom();A>=13?h.setVisible(!0):h.setVisible(!1)}),R.on("singleclick",function(w){y=U([]);var A=w.coordinate,F=A[0],O=A[1],b=R.getView(),V=R.getView().getZoom();b.animate({center:[F,O],duration:1e3}),console.log(V,"zoom========================"),d.value.forEach(X=>{W[X]?Ct(w,W[X].setOf,`http://192.168.0.113:8090/iserver/services/${W[X].name}/rest/maps/${W[X].setOf}`,X):j[X]&&Ct(w,j[X].setOf,`http://192.168.0.113:8090/iserver/services/${j[X].name}/rest/maps/${j[X].setOf}`,X)})});var E=new ResizeObserver(function(w){w.forEach(function(A){var F=A.contentRect.width,O=A.contentRect.height;m.style.width=F+"px",m.style.height=O+"px",R.updateSize()})});E.observe(v)}function J(){co.get("/json/huangdao.json").then(({data:v})=>{const E=new ol.format.GeoJSON().readFeatures(v)[0];ct(E.getGeometry().getCoordinates())})}function ct(v){let m=new ol.source.Vector;var E=new ol.layer.Vector({id:"zhezhaos",source:m,style:new ol.style.Style({fill:new ol.style.Fill({color:"rgba( 255, 255, 255, 0.7)"})})});const w=ut(v),A=new ol.Feature({geometry:w});E.getSource().addFeature(A),R.addLayer(E)}function ut(v){const m=[-180,-90,180,90],E=ol.geom.Polygon.fromExtent(m);return v.forEach(A=>{const F=new ol.geom.LinearRing(A[0]);E.appendLinearRing(F)}),E}function Ct(v,m,E,w){var A=new ol.geom.Point(v.coordinate),F=new ol.supermap.QueryByGeometryParameters({queryParams:{name:m},geometry:A});let O=document.querySelector("#popup-title"),b=U(null);var V=1,X=1;new ol.supermap.QueryService(E).queryByGeometry(F,function(K){if(K.result.currentCount>0){y.value.push({name:w,information:K.result.recordsets[0].features.features[0].properties}),console.log(y.value[0]),K.result.recordsets[0].features&&(Y.setPosition(A.flatCoordinates),y.value[0].name>=2019?(console.log(y.value[0].information),O.innerHTML="\u9AD8\u6807\u51C6\u519C\u7530",at.innerHTML='<div class="content-children"><p>\u9879\u76EE\u7F16\u53F7: '+y.value[0].information.XMBH+'</p><p id="P-id">\u9879\u76EE\u540D\u79F0: '+y.value[0].information.XMMC+"</p><p>\u9879\u76EE\u9762\u79EF: "+y.value[0].information.XMMJ+"</p><p>\u5730\u5757\u9762\u79EF: "+y.value[0].information.DKMJ+"</p><p>\u6807\u8BC6\u7801: "+y.value[0].information.BSM+"</p><p>\u5730\u5757\u7F16\u53F7: "+y.value[0].information.DKBH+"</p><p>\u5730\u5757\u540D\u79F0: "+y.value[0].information.DKMC+"</p><p>\u9879\u76EE\u5E74\u4EFD: "+y.value[0].information.XMNF+"</p></div>"):y.value[0].name>=2011&&y.value[0].name<=2018?(O.innerHTML="\u9AD8\u6807\u51C6\u519C\u7530",at.innerHTML='<div class="content-children"><p>\u6807\u8BC6\u7801: '+y.value[0].information.BSM+"</p><p>\u5730\u5757\u9762\u79EF: "+y.value[0].information.DIKUAIAREA+"</p><p>\u5730\u5757\u7528\u9014/\u7C7B\u578B: "+y.value[0].information.DLBM+"</p><p>\u9879\u76EE\u7F16\u53F7: "+y.value[0].information.XMBH+'</p><p id="P-id">\u9879\u76EE\u540D\u79F0:'+y.value[0].information.XMMC+"</p></div>"):y.value[0].name=="\u6C38\u4E45\u57FA\u672C\u519C\u7530"?(O.innerHTML="\u6C38\u4E45\u57FA\u672C\u519C\u7530",at.innerHTML='<div class="content-children"><p>\u7C7B\u578B: '+y.value[0].name+"</p><p>\u5730\u7C7B\u540D\u79F0: "+y.value[0].information.DLMC+"</p><p>\u6743\u5C5E\u6027\u8D28: "+y.value[0].information.QSXZ+"</p><p>\u6743\u5C5E\u5355\u4F4D\u540D\u79F0: "+y.value[0].information.QSDWMC+"</p><p>\u5750\u843D\u5355\u4F4D\u540D\u79F0: "+y.value[0].information.ZLDWMC+"</p><p>\u6263\u9664\u5730\u7C7B\u7F16\u7801: "+y.value[0].information.KCDLBM+"</p><p>\u6263\u9664\u7CFB\u6570: "+y.value[0].information.KCXS+"</p><p>\u6263\u9664\u9762\u79EF: "+y.value[0].information.KCMJ+"</p><p>\u8015\u5730\u7C7B\u578B: "+y.value[0].information.GDLX+"</p><p>\u8015\u5730\u5761\u5EA6\u7EA7\u522B: "+y.value[0].information.GDPDJB+"</p><p>\u79CD\u690D\u5C5E\u6027\u4EE3\u7801: "+y.value[0].information.ZZSXDM+"</p><p>\u79CD\u690D\u5C5E\u6027\u540D\u79F0: "+y.value[0].information.ZZSXMC+"</p><p>\u8015\u5730\u7B49\u7EA7: "+y.value[0].information.GDDJ+"</p><p>\u6570\u636E\u5E74\u4EFD: "+y.value[0].information.SJNF+"</p><p>\u4FDD\u62A4\u5F00\u59CB\u65F6\u95F4: "+y.value[0].information.BHKSSJ+"</p><p>\u6C38\u4E45\u57FA\u672C\u519C\u7530\u9762\u79EF: "+(y.value[0].information.YJJBNTMJ_Y/666).toFixed(2)+"(\u4EA9)</p></div>"):y.value[0].name=="\u8015\u5730"?(O.innerHTML="\u8015\u5730",at.innerHTML='<div class="content-children"><p>\u5730\u7C7B\u540D\u79F0: '+y.value[0].information.DLMC+"</p><p>\u6743\u5C5E\u5355\u4F4D\u540D\u79F0: "+y.value[0].information.QSDWMC+"</p><p>\u5750\u843D\u5355\u4F4D\u540D\u79F0: "+y.value[0].information.ZLDWMC+"</p><p>\u6263\u9664\u5730\u7C7B\u7F16\u7801: "+y.value[0].information.KCDLBM+"</p><p>\u6263\u9664\u7CFB\u6570: "+y.value[0].information.KCXS+"</p><p>\u6263\u9664\u9762\u79EF: "+y.value[0].information.KCMJ+"</p><p>\u8015\u5730\u7C7B\u578B: "+y.value[0].information.GDLX+"</p><p>\u8015\u5730\u5761\u5EA6\u7EA7\u522B: "+y.value[0].information.GDPDJB+"</p><p>\u79CD\u690D\u5C5E\u6027\u4EE3\u7801: "+y.value[0].information.ZZSXDM+"</p><p>\u79CD\u690D\u5C5E\u6027\u540D\u79F0: "+y.value[0].information.ZZSXMC+"</p><p>\u6570\u636E\u5E74\u4EFD: "+y.value[0].information.SJNF+"</p><p>\u56FE\u6591\u9762\u79EF: "+(y.value[0].information.TBMJ_YS/666).toFixed(2)+"(\u4EA9)</p><p>\u56FE\u6591\u5730\u7C7B\u9762\u79EF: "+(y.value[0].information.TBDLMJ_YS/666).toFixed(2)+"(\u4EA9)</p></div>"):y.value[0].name=="\u7247\u5757\u4FE1\u606F"?(O.innerHTML="\u7247\u5757\u4FE1\u606F",at.innerHTML='<div class="content-children"><p>\u6807\u8BC6\u7801: '+y.value[0].information.BSM+"</p><p>\u8981\u7D20\u4EE3\u7801: "+y.value[0].information.YSDM+"</p><p>\u4E24\u533A\u4EE3\u7801: "+y.value[0].information.LQDM+"</p><p>\u4E24\u533A\u7247\u5757\u4EE3\u7801: "+y.value[0].information.LQPKDM+"</p><p>\u4E24\u533A\u7247\u5757\u9762\u79EF(\u4EA9): "+y.value[0].information.LQPKMJM+"</p><p>\u7247\u5757\u7C7B\u578B: "+y.value[0].information.PKLX+"</p></div>"):y.value[0].name=="\u5730\u5757\u4FE1\u606F"?(O.innerHTML="\u5730\u5757\u4FE1\u606F",at.innerHTML='<div class="content-children"><p>\u6807\u8BC6\u7801: '+y.value[0].information.BSM+"</p><p>\u8981\u7D20\u4EE3\u7801: "+y.value[0].information.YSDM+"</p><p>\u4E24\u533A\u7247\u5757\u4EE3\u7801: "+y.value[0].information.LQPKDM+"</p><p>\u4E24\u533A\u7C7B\u578B: "+y.value[0].information.LQLX+"</p><p>\u533A\u57DF\u5212\u5206\u7C7B\u578B: "+y.value[0].information.QYHFLX+"</p><p>\u4E24\u533A\u5730\u5757\u4EE3\u7801: "+y.value[0].information.LQDKDM+"</p><p>\u4E24\u533A\u5730\u5757\u540D\u79F0: "+y.value[0].information.LQDKMC+"</p><p>\u4E24\u533A\u5730\u5757\u9762\u79EF(\u4EA9): "+y.value[0].information.LQDKMJM+"</p><p>\u98DE\u5165\u5730\u6807\u8BC6: "+y.value[0].information.FRDES+"</p><p>\u5761\u5EA6\u7EA7\u522B: "+y.value[0].information.PDJB+"</p><p>\u662F\u5426\u9AD8\u6807\u51C6\u519C\u7530: "+y.value[0].information.SFGBZNT+"</p><p>\u7ECF\u8425\u4E3B\u4F53\u7C7B\u578B: "+y.value[0].information.JYZTLX+"</p></div>"):y.value[0].name=="\u571F\u5730\u786E\u6743"&&(O.innerHTML="\u571F\u5730\u786E\u6743",ms({dkbm:y.value[0].information.DKBM}).then(dt=>{let Qt=[];dt.data[0].cbdkxxes.forEach(ye=>{Qt.push(ye.cyxm)}),at.innerHTML='<div class="content-children"><p>\u8981\u7D20\u4EE3\u7801: '+y.value[0].information.YSDM+"</p><p>\u5730\u5757\u7F16\u7801: "+y.value[0].information.DKBM+"</p><p>\u5730\u5757\u540D\u79F0: "+y.value[0].information.DKMC+"</p><p>\u6240\u6709\u6743\u6027\u8D28: "+y.value[0].information.SYQXZ+"</p><p>\u5730\u5757\u7C7B\u522B:"+y.value[0].information.DKLB+"</p><p>\u571F\u5730\u5229\u7528\u7C7B\u578B: "+y.value[0].information.TDLYLX+"</p><p>\u5730\u529B\u7B49\u7EA7: "+y.value[0].information.DLDJ+"</p><p>\u571F\u5730\u7528\u9014: "+y.value[0].information.TDYT+"</p><p>\u662F\u5426\u57FA\u672C\u519C\u7530: "+y.value[0].information.SFJBNT+"</p><p>\u5B9E\u6D4B\u9762\u79EF\u4EA9: "+(y.value[0].information.SCMJ/666).toFixed(2)+"</p><p>\u627F\u5305\u65B9: "+dt.data[0].cbfmc+"</p><p>\u627F\u5305\u65B9\u5BB6\u5EAD\u6210\u5458:"+Qt.join(",")+"</p></div>"})));var _t=R.getLayers().getArray().find(dt=>dt.get("id")==="zhezhao");R.removeLayer(_t),b=R.getLayers().getArray().find(dt=>dt.get("id")==="dianjigaoliang"),R.removeLayer(b);var It=new ol.format.GeoJSON().readFeatures(K.result.recordsets[0].features),Q=new ol.source.Vector;Q.addFeatures(It);const C=new ol.style.Style({stroke:new ol.style.Stroke({color:"rgba(255, 219, 113, 1.0)",width:5})});var st=new ol.layer.Vector({id:"dianjigaoliang",source:Q,zIndex:9999});st.setStyle(C),R.addLayer(st)}}),B.addEventListener("click",function(){b=R.getLayers().getArray().find(K=>K.get("id")==="dianjigaoliang"),R.removeLayer(b),Y.setPosition(void 0)}),document.getElementById("popup-prev").addEventListener("click",function(){V>1&&(V--,L())}),document.getElementById("popup-next").addEventListener("click",function(K){var _t=y.value.length,It=Math.ceil(_t/X);V<It&&(V++,L())});function L(){var K=(V-1)*X,_t=K+X,It=y.value;let Q=document.getElementById("popup-content");for(var st=K;st<_t&&st<It.length;st++){var C=It[st];C.name>=2019?(O.innerHTML="\u9AD8\u6807\u51C6\u519C\u7530",Q.innerHTML='<div class="content-children"><p>\u7C7B\u578B: \u9AD8\u6807\u51C6\u519C\u7530</p><p>\u9879\u76EE\u7F16\u53F7: '+C.information.XMBH+'</p><p id="P-id">\u9879\u76EE\u540D\u79F0: '+C.information.XMMC+"</p><p>\u9879\u76EE\u9762\u79EF: "+C.information.XMMJ+"</p><p>\u5730\u5757\u9762\u79EF: "+C.information.DKMJ+"</p><p>\u6807\u8BC6\u7801: "+C.information.BSM+"</p><p>\u5730\u5757\u7F16\u53F7: "+C.information.DKBH+"</p><p>\u5730\u5757\u540D\u79F0: "+C.information.DKMC+"</p><p>\u9879\u76EE\u5E74\u4EFD: "+C.information.XMNF+"</p></div>"):C.name>=2011&&C.name<=2018?(O.innerHTML="\u9AD8\u6807\u51C6\u519C\u7530",Q.innerHTML='<div class="content-children"><p>\u6807\u8BC6\u7801: '+C.information.BSM+"</p><p>\u5730\u5757\u9762\u79EF: "+C.information.DIKUAIAREA+"</p><p>\u5730\u5757\u7528\u9014/\u7C7B\u578B: "+C.information.DLBM+"</p><p>\u9879\u76EE\u7F16\u53F7: "+C.information.XMBH+'</p><p id="P-id">\u9879\u76EE\u540D\u79F0:'+C.information.XMMC+"</p></div>"):C.name=="\u6C38\u4E45\u57FA\u672C\u519C\u7530"?(O.innerHTML="\u6C38\u4E45\u57FA\u672C\u519C\u7530",Q.innerHTML='<div class="content-children"><p>\u7C7B\u578B: '+C.name+"</p><p>\u5730\u7C7B\u540D\u79F0: "+C.information.DLMC+"</p><p>\u6743\u5C5E\u6027\u8D28: "+C.information.QSXZ+"</p><p>\u6743\u5C5E\u5355\u4F4D\u540D\u79F0: "+C.information.QSDWMC+"</p><p>\u5750\u843D\u5355\u4F4D\u540D\u79F0: "+C.information.ZLDWMC+"</p><p>\u6263\u9664\u5730\u7C7B\u7F16\u7801: "+C.information.KCDLBM+"</p><p>\u6263\u9664\u7CFB\u6570: "+C.information.KCXS+"</p><p>\u6263\u9664\u9762\u79EF: "+C.information.KCMJ+"</p><p>\u8015\u5730\u7C7B\u578B: "+C.information.GDLX+"</p><p>\u8015\u5730\u5761\u5EA6\u7EA7\u522B: "+C.information.GDPDJB+"</p><p>\u79CD\u690D\u5C5E\u6027\u4EE3\u7801: "+C.information.ZZSXDM+"</p><p>\u79CD\u690D\u5C5E\u6027\u540D\u79F0: "+C.information.ZZSXMC+"</p><p>\u8015\u5730\u7B49\u7EA7: "+C.information.GDDJ+"</p><p>\u6570\u636E\u5E74\u4EFD: "+C.information.SJNF+"</p><p>\u4FDD\u62A4\u5F00\u59CB\u65F6\u95F4: "+C.information.BHKSSJ+"</p><p>\u6C38\u4E45\u57FA\u672C\u519C\u7530\u9762\u79EF: "+(C.information.YJJBNTMJ_Y/666).toFixed(2)+"(\u4EA9)</p></div>"):C.name=="\u8015\u5730"?(O.innerHTML="\u8015\u5730",Q.innerHTML='<div class="content-children"><p>\u7C7B\u578B: '+C.name+"</p><p>\u5730\u7C7B\u540D\u79F0: "+C.information.DLMC+"</p><p>\u6743\u5C5E\u5355\u4F4D\u540D\u79F0: "+C.information.QSDWMC+"</p><p>\u5750\u843D\u5355\u4F4D\u540D\u79F0: "+C.information.ZLDWMC+"</p><p>\u6263\u9664\u5730\u7C7B\u7F16\u7801: "+C.information.KCDLBM+"</p><p>\u6263\u9664\u7CFB\u6570: "+C.information.KCXS+"</p><p>\u6263\u9664\u9762\u79EF: "+C.information.KCMJ+"</p><p>\u8015\u5730\u7C7B\u578B: "+C.information.GDLX+"</p><p>\u8015\u5730\u5761\u5EA6\u7EA7\u522B: "+C.information.GDPDJB+"</p><p>\u79CD\u690D\u5C5E\u6027\u4EE3\u7801: "+C.information.ZZSXDM+"</p><p>\u79CD\u690D\u5C5E\u6027\u540D\u79F0: "+C.information.ZZSXMC+"</p><p>\u6570\u636E\u5E74\u4EFD: "+C.information.SJNF+"</p><p>\u56FE\u6591\u9762\u79EF: "+(C.information.TBMJ_YS/666).toFixed(2)+"(\u4EA9)</p><p>\u56FE\u6591\u5730\u7C7B\u9762\u79EF: "+(C.information.TBDLMJ_YS/666).toFixed(2)+"(\u4EA9)</p></div>"):C.name=="\u7247\u5757\u4FE1\u606F"?(O.innerHTML="\u7247\u5757\u4FE1\u606F",Q.innerHTML='<div class="content-children"><p>\u7C7B\u578B: '+C.name+"</p><p>\u6807\u8BC6\u7801: "+C.information.BSM+"</p><p>\u8981\u7D20\u4EE3\u7801: "+C.information.YSDM+"</p><p>\u4E24\u533A\u4EE3\u7801: "+C.information.LQDM+"</p><p>\u4E24\u533A\u7247\u5757\u4EE3\u7801: "+C.information.LQPKDM+"</p><p>\u4E24\u533A\u7247\u5757\u9762\u79EF(\u4EA9): "+C.information.LQPKMJM+"</p><p>\u7247\u5757\u7C7B\u578B: "+C.information.PKLX+"</p></div>"):C.name=="\u5730\u5757\u4FE1\u606F"?(O.innerHTML="\u5730\u5757\u4FE1\u606F",Q.innerHTML='<div class="content-children"><p>\u7C7B\u578B: '+C.name+"</p><p>\u6807\u8BC6\u7801: "+C.information.BSM+"</p><p>\u8981\u7D20\u4EE3\u7801: "+C.information.YSDM+"</p><p>\u4E24\u533A\u7247\u5757\u4EE3\u7801: "+C.information.LQPKDM+"</p><p>\u4E24\u533A\u7C7B\u578B: "+C.information.LQLX+"</p><p>\u533A\u57DF\u5212\u5206\u7C7B\u578B: "+C.information.QYHFLX+"</p><p>\u4E24\u533A\u5730\u5757\u4EE3\u7801: "+C.information.LQDKDM+"</p><p>\u4E24\u533A\u5730\u5757\u540D\u79F0: "+C.information.LQDKMC+"</p><p>\u4E24\u533A\u5730\u5757\u9762\u79EF(\u4EA9): "+C.information.LQDKMJM+"</p><p>\u98DE\u5165\u5730\u6807\u8BC6: "+C.information.FRDES+"</p><p>\u5761\u5EA6\u7EA7\u522B: "+C.information.PDJB+"</p><p>\u662F\u5426\u9AD8\u6807\u51C6\u519C\u7530: "+C.information.SFGBZNT+"</p><p>\u7ECF\u8425\u4E3B\u4F53\u7C7B\u578B: "+C.information.JYZTLX+"</p></div>"):C.name=="\u571F\u5730\u786E\u6743"&&(O.innerHTML="\u571F\u5730\u786E\u6743",ms({dkbm:C.information.DKBM}).then(dt=>{let Qt=[];dt.data[0].cbdkxxes.forEach(ye=>{Qt.push(ye.cyxm)}),Q.innerHTML='<div class="content-children"><p>\u7C7B\u578B: '+C.name+"</p><p>\u8981\u7D20\u4EE3\u7801: "+C.information.YSDM+"</p><p>\u5730\u5757\u7F16\u7801: "+C.information.DKBM+"</p><p>\u5730\u5757\u540D\u79F0: "+C.information.DKMC+"</p><p>\u6240\u6709\u6743\u6027\u8D28: "+C.information.SYQXZ+"</p><p>\u5730\u5757\u7C7B\u522B:"+C.information.DKLB+"</p><p>\u571F\u5730\u5229\u7528\u7C7B\u578B: "+C.information.TDLYLX+"</p><p>\u5730\u529B\u7B49\u7EA7: "+C.information.DLDJ+"</p><p>\u571F\u5730\u7528\u9014: "+C.information.TDYT+"</p><p>\u662F\u5426\u57FA\u672C\u519C\u7530: "+C.information.SFJBNT+"</p><p>\u5B9E\u6D4B\u9762\u79EF\u4EA9: "+(C.information.SCMJ/666).toFixed(2)+"</p><p>\u627F\u5305\u65B9: "+dt.data[0].cbfmc+"</p><p>\u627F\u5305\u65B9\u5BB6\u5EAD\u6210\u5458:"+Qt.join(",")+"</p></div>"}))}}}const M=()=>{document.getElementById("popup"),at=document.getElementById("popup-content"),B=document.getElementById("popup-closer"),Y=new ol.Overlay({element:document.getElementById("popup"),positioning:"bottom-center",stopEvent:!0,offset:[0,-10]}),R.addOverlay(Y)};function Te(v,m){var E=R.getView();E.animate({center:[v,m],duration:1e3,zoom:17})}function Et(v){let m="",E="",w="",A="",F="";!v.villageValue&&v.value?(E="http://192.168.0.113:8090/iserver/services/data-liangquhuadingWGS84/rest/data",m=v.value,w="XJQY3702112019WGS84",A="liangquhuadingWGS84",F="XJQYMC"):v.value&&v.villageValue&&(E="http://192.168.0.113:8090/iserver/services/data-liangquhuadingWGS84/rest/data",m=v.villageValue,w="CJQY3702112019WGS84",A="liangquhuadingWGS84",F="CJQYMC");var O=new ol.supermap.GetFeaturesBySQLParameters({queryParameter:{name:`${w}@${A}`,attributeFilter:`${F} like '%${m}%'`},datasetNames:[`${A}:${w}`]});new ol.supermap.FeatureService(E).getFeaturesBySQL(O,function(b){if(b.result.featureCount!=0){console.log(O),console.log(b,"serviceResult######");var V=R.getLayers().getArray().find(Q=>Q.get("id")==="zhezhao");R.removeLayer(V);var X=R.getLayers().getArray().find(Q=>Q.get("id")==="dianjigaoliang");R.removeLayer(X);var L=new ol.format.GeoJSON().readFeatures(b.result.features),K=new ol.source.Vector;K.addFeatures(L);const It=new ol.style.Style({stroke:new ol.style.Stroke({color:"rgba(85, 255, 255, 1.0)",width:2})});var _t=new ol.layer.Vector({id:"dianjigaoliang",source:K});_t.setStyle(It),R.addLayer(_t),R.getView().fit(K.getExtent())}})}function Lt(v,m){console.log(v,m);const E=[];E.push(v.Lon),E.push(v.Lat),console.log(E),dn(E,m.setOf,`http://192.168.0.113:8090/iserver/services/${m.name}/rest/maps/${m.setOf}`)}function dn(v,m,E){console.log(v);var w=new ol.geom.Point(v);console.log(w,"###qqqqqqqqqqqqqq");var A=new ol.supermap.QueryByGeometryParameters({queryParams:{name:m},geometry:w});new ol.supermap.QueryService(E).queryByGeometry(A,function(F){if(F.result.currentCount>0){console.log(F.result,"\u56FE\u5C42\u4FE1\u606F");var O=R.getLayers().getArray().find(_t=>_t.get("id")==="zhezhao");R.removeLayer(O);var b=R.getLayers().getArray().find(_t=>_t.get("id")==="dianjigaoliang");R.removeLayer(b);var V=new ol.format.GeoJSON().readFeatures(F.result.recordsets[0].features),X=new ol.source.Vector;X.addFeatures(V);const K=new ol.style.Style({fill:new ol.style.Fill({color:"rgba(0, 255, 0, 0.1)"}),stroke:new ol.style.Stroke({color:"rgba(85, 255, 255, 1.0)",width:2})});var L=new ol.layer.Vector({id:"dianjigaoliang",source:X});L.setStyle(K),R.addLayer(L),R.getView().fit(X.getExtent())}else console.log(v),Te(v[0],v[1])})}const fn=()=>{h=new ol.layer.Tile({source:new ol.source.TileSuperMapRest({url:"http://36.134.44.75:8090/iserver/services/map-huangdaoqu_bianjie/rest/maps/CJQY3702112019WGS84%40huangdaoqu_bianjie",cacheEnabled:!1}),name:"huangdaoqu_village",projection:"EPSG:4326",zIndex:9999}),R.addLayer(h)},Oi=()=>{var v=new ol.layer.Tile({source:new ol.source.TileSuperMapRest({url:"http://36.134.44.75:8090/iserver/services/map-huangdaoqu_bianjie/rest/maps/XJQY3702112019WGS84%40huangdaoqu_bianjie",cacheEnabled:!1}),projection:"EPSG:4326",zIndex:9999});R.addLayer(v)},De=v=>{console.log(v);let m=new ol.layer.Tile({source:new ol.source.TileSuperMapRest({url:`http://192.168.0.113:8090/iserver/services/${v.name}/rest/maps/${v.setOf}`,cacheEnabled:!1}),name:v.name,projection:"EPSG:4326",zIndex:v.name=="map-liangqudikuaixk"?9998:999});R.addLayer(m)};U({label:[]});function Pi(){if(e.value=!e.value,e.value){let v=document.querySelector(".rightWra");v.style.transform="translate(0,0)"}else{let v=document.querySelector(".rightWra");v.style.transform="translate(107%,0)"}}const gn=(v,m)=>{let E=!1;if(c.value.forEach((w,A)=>{if(v.label==w)c.value.splice(A,1),E=!0;else if(v.label=="\u9AD8\u6807\u51C6\u519C\u7530")for(const F in j)c.value.indexOf(F)!==-1&&(c.value.splice(c.value.indexOf(F),1),E=!0,g.value=[])}),!E)if(v.label=="\u9AD8\u6807\u51C6\u519C\u7530")for(const w in j)c.value.push(w);else for(const w in W)v.label==w&&c.value.push(w);v.label=="\u9AD8\u6807\u51C6\u519C\u7530"&&(p.value=!p.value,p.value?q=U({2012:!1,2013:!1,2014:!1,2015:!1,2016:!1,2017:!1,2018:!1,2019:!1,2020:!1,2021:!1,2022:!1}):q=U({2012:!0,2013:!0,2014:!0,2015:!0,2016:!0,2017:!0,2018:!0,2019:!0,2020:!0,2021:!0,2022:!0})),console.log(c.value),g.value.forEach(w=>{c.value.indexOf(w)!==-1&&c.value.splice(c.value.indexOf(w),1)}),console.log(g.value),d.value=JSON.parse(JSON.stringify(c.value))},_n=(v,{node:m,data:E})=>{if(m.data.children)return v("span",{class:{gbz:!E.children}},m.label);switch(m.label){case"\u9AD8\u6807\u51C6\u519C\u7530":return v("span",{class:{gbz:!E.children},style:{"border-radius":"2px",background:" rgba(42, 167, 44, 1)",border:"2px solid rgba(254, 255, 181, 1)",padding:"5px 15px 5px 15px"}},m.label);case"\u6C38\u4E45\u57FA\u672C\u519C\u7530":return v("span",{class:{yjjbnt:!E.children},style:{"border-radius":"2px",background:"rgba(242, 145, 61, 1)",border:"2px solid rgba(254, 255, 181, 1)",padding:"5px 15px 5px 15px"}},m.label);case"\u8015\u5730":return v("span",{class:{gd:!E.children},style:{"border-radius":"2px",background:"rgba(242, 221, 61, 1)",border:"2px solid rgba(254, 255, 181, 1)",padding:"5px 15px 5px 15px"}},m.label);case"\u7247\u5757\u4FE1\u606F":return v("span",{class:{pkxx:!E.children},style:{"border-radius":"2px",background:"rgba(255, 151, 148, 1)",border:"2px solid rgba(254, 255, 181, 1)",padding:"5px 15px 5px 15px"}},m.label);case"\u5730\u5757\u4FE1\u606F":return v("span",{class:{dkxx:!E.children},style:{"border-radius":"2px",background:"rgba(114, 138, 223, 1)",border:"2px solid rgba(254, 255, 181, 1)",padding:"5px 15px 5px 15px"}},m.label);case"\u7CAE\u98DF\u529F\u80FD\u533A":return v("span",{class:{gbz:!E.children},style:{"border-radius":"2px",background:"rgba(242, 145, 61, 1)",border:"2px solid rgba(254, 255, 181, 1)",padding:"5px 15px 5px 15px"}},m.label);case"\u571F\u5730\u786E\u6743":return v("span",{class:{tdqq:!E.children},style:{"border-radius":"2px",background:"rgba(56, 192, 255, 1)",border:"2px solid rgba(254, 255, 181, 1)",padding:"5px 15px 5px 15px"}},m.label)}},ke=v=>{u.value=v},de=()=>{i.value="",r.value="",o.value.Lon="",o.value.Lat="",a.value.Lon.londu="",a.value.Lon.lonfen="",a.value.Lon.lonmiao="",a.value.Lat.latdu="",a.value.Lat.latfen="",a.value.Lat.latmiao="";var v=R.getLayers().getArray().find(E=>E.get("id")==="dianjigaoliang");R.removeLayer(v);var m=R.getView();m.animate({center:["119.88661841637813","35.85667692242919"],duration:1e3,zoom:11})},ei=()=>{u.value==1?Et({villageValue:i.value,value:r.value}):u.value==2?Et({villageValue:i.value,value:D.value}):u.value==3?c.value.length>0?c.value.forEach(v=>{W[v]?(Lt(o.value,W[v]),console.log(W[v])):j[v]&&Lt(o.value,j[v])}):o.value.Lon.length>0&&o.value.Lat.length>0?Te(o.value.Lon,o.value.Lat):gs.error("\u8BF7\u8F93\u5165\u7ECF\u7EAC\u5EA6"):u.value==4&&(console.log(a.value),c.value.lengt>0?c.value.forEach(v=>{W[v]?(Lt({Lon:Ut(a.value.Lon.londu,a.value.Lon.lonfen,a.value.Lon.lonmiao),Lat:Ut(a.value.Lat.latdu,a.value.Lat.latfen,a.value.Lat.latmiao)},W[v]),console.log(W[v])):j[v]&&(console.log(W[v]),Lt({Lon:Ut(a.value.Lon.londu,a.value.Lon.lonfen,a.value.Lon.lonmiao),Lat:Ut(a.value.Lat.latdu,a.value.Lat.latfen,a.value.Lat.latmiao)},j[v]))}):a.value.Lon.londu.length>0&&a.value.Lon.lonfen.length>0&&a.value.Lon.lonmiao.length>0&&a.value.Lat.latdu.length>0&&a.value.Lat.latfen.length>0&&a.value.Lat.latmiao.length>0?Te(Ut(a.value.Lon.londu,a.value.Lon.lonfen,a.value.Lon.lonmiao),Ut(a.value.Lat.latdu,a.value.Lat.latfen,a.value.Lat.latmiao)):gs.error("\u8BF7\u8F93\u5165\u7ECF\u7EAC\u5EA6"))};function Ut(v,m,E){var w=0;E!=null&&E!==""&&(w=Number(E/60));var A=0;m!=null&&m!==""?A=(Number(m)+w)/60:A=w;var F=0;return v!=null&&v!==""?F=(Number(v)+A).toFixed(6):F=A.toFixed(6),F}const mn=v=>{let m=v.target.innerText;q.value[m]=!q.value[m],d.value.indexOf(m)==-1?(d.value.push(m),De(j[m]),g.value.indexOf(m)!==-1&&g.value.splice(g.value.indexOf(m),1),console.log(g.value)):(g.value.push(m),d.value.splice(d.value.indexOf(m),1),R.getLayers().getArray().forEach((E,w)=>{E.A.name&&E.A.source.options.url==`http://192.168.0.113:8090/iserver/services/${j[m].name}/rest/maps/${j[m].setOf}`&&R.getLayers().removeAt(w)}))},pn=v=>{switch(v.target.innerText){case"\u9AD8\u6807\u51C6\u519C\u7530":f.value=1,Z.value="\u9AD8\u6807\u51C6\u519C\u7530",Gt("\u9AD8\u6807\u51C6\u519C\u7530");break;case"\u6C38\u4E45\u57FA\u672C\u519C\u7530":f.value=2,Z.value="\u6C38\u4E45\u57FA\u672C\u519C\u7530",Gt("\u6C38\u4E45\u57FA\u672C\u519C\u7530");break;case"\u8015\u5730":f.value=3,Z.value="\u8015\u5730",Gt("\u8015\u5730");break;case"\u7247\u5757\u4FE1\u606F":f.value=4,Z.value="\u7247\u5757\u4FE1\u606F",Gt("\u4E24\u533A\u7247\u5757");break;case"\u5730\u5757\u4FE1\u606F":f.value=5,Z.value="\u5730\u5757\u4FE1\u606F",Gt("\u4E24\u533A\u5730\u5757");break;case"\u571F\u5730\u786E\u6743":f.value=6,Z.value="\u571F\u5730\u786E\u6743",Gt("\u571F\u5730\u786E\u6743");break}},Gi=v=>{I.value.forEach(m=>{m.cjqydm==r.value&&(D.value=m.cjqymc)}),Cn({divisions:r.value}).then(m=>{s.value=m.data})},ii=()=>{Cn().then(v=>{I.value=v.data})},Gt=v=>{ve({flag:v}).then(m=>{N.value=m.data[m.data.length-1].zSum,T.value=m.data[m.data.length-1].zQuantity,x.value=m.data,xe()})},Fe=v=>{Cn().then(m=>{S.value=m.data,console.log(m.data)})},Bi=v=>{switch(f.value){case 1:ve({flag:"\u9AD8\u6807\u51C6\u519C\u7530",whetherToDownload:!0}).then(m=>{Pe(m.data[m.data.length-1].downloadPath)});break;case 2:ve({flag:"\u6C38\u4E45\u57FA\u672C\u519C\u7530",whetherToDownload:!0}).then(m=>{console.log(m.data[m.data.length-1].downloadPath),Pe(m.data[m.data.length-1].downloadPath)});break;case 3:ve({flag:"\u8015\u5730",whetherToDownload:!0}).then(m=>{Pe(m.data[m.data.length-1].downloadPath)});break;case 4:ve({flag:"\u4E24\u533A\u7247\u5757",whetherToDownload:!0}).then(m=>{Pe(m.data[m.data.length-1].downloadPath)});break;case 5:ve({flag:"\u4E24\u533A\u5730\u5757",whetherToDownload:!0}).then(m=>{Pe(m.data[m.data.length-1].downloadPath)});break;case 6:ve({flag:"\u571F\u5730\u786E\u6743",whetherToDownload:!0}).then(m=>{Pe(m.data[m.data.length-1].downloadPath)});break}},fe=new se({fill:new mt({color:"rgba(255, 255, 255, 0.2)"}),stroke:new le({color:"rgba(255, 219, 113, 1.0)",lineDash:[10,10],width:2}),image:new Ei({radius:5,stroke:new le({color:"rgba(0, 0, 0, 0.7)"}),fill:new mt({color:"rgba(255, 255, 255, 0.2)"})})}),Oe=new se({text:new hi({font:"12px Calibri,sans-serif",fill:new mt({color:"rgba(255, 255, 255, 1)"}),backgroundFill:new mt({color:"rgba(0, 0, 0, 0.4)"}),padding:[2,2,2,2],textBaseline:"bottom",offsetY:-12}),image:new nn({radius:6,points:3,angle:Math.PI,displacement:[0,8],fill:new mt({color:"rgba(0, 0, 0, 0.4)"})})}),ge=new se({image:new Ei({radius:5,stroke:new le({color:"rgba(0, 0, 0, 0.7)"}),fill:new mt({color:"rgba(0, 0, 0, 0.4)"})}),text:new hi({text:"Drag to modify",font:"12px Calibri,sans-serif",fill:new mt({color:"rgba(255, 255, 255, 1)"}),backgroundFill:new mt({color:"rgba(0, 0, 0, 0.7)"}),padding:[2,2,2,2],textAlign:"left",offsetX:15})}),Ft=[Oe];var _e,Bt,Ht,qt;function me(){qt&&(R.removeLayer(qt),qt=null),Bt&&(R.removeInteraction(Bt),Bt=null),Ht=null}function xn(){t.value=!t.value,me(),Jt("length")}function yn(){t.value=!t.value,me(),Jt("area")}function Ni(){t.value=!t.value,me()}const ni=new se({text:new hi({font:"12px Calibri,sans-serif",fill:new mt({color:"red"}),backgroundFill:new mt({color:"rgba(0, 0, 0, 0.4)"}),padding:[2,2,2,2],textAlign:"left",offsetX:15})}),pe=new se({text:new hi({font:"14px Calibri,sans-serif",fill:new mt({color:"rgba(255, 255, 255, 1)"}),backgroundFill:new mt({color:"rgba(0, 0, 0, 0.4)"}),padding:[3,3,3,3],textBaseline:"bottom",offsetY:-15}),image:new nn({radius:8,points:3,angle:Math.PI,displacement:[0,10],fill:new mt({color:"rgba(0, 0, 0, 0.4)"})})});var si=function(v){var m=Nr(v,{projection:R.getView().getProjection()}),E;return m>1e3?E=Math.round(m/1e3*100)/100+" km":E=Math.round(m*100)/100+" m",E},ri=function(v){var m=Xr(v,{projection:R.getView().getProjection()}),E;return m>1e4?E=Math.round(m/1e6*100)/100+" km\xB2":E=Math.round(m*100)/100+" m\xB2",E};function Kt(v,m,E,w){const A=[fe],F=v.getGeometry(),O=F.getType();let b,V,X;if((!E||E===O)&&(O==="Polygon"?(b=F.getInteriorPoint(),V=ri(F),X=new Ks(F.getCoordinates()[0])):O==="LineString"&&(b=new Ai(F.getLastCoordinate()),V=si(F),X=F)),m&&X){let L=0;X.forEachSegment(function(K,_t){const It=new Ks([K,_t]),Q=si(It);Ft.length-1<L&&Ft.push(Oe.clone());const st=new Ai(It.getCoordinateAt(.5));Ft[L].setGeometry(st),Ft[L].getText().setText(Q),A.push(Ft[L]),L++})}return V&&(pe.setGeometry(b),pe.getText().setText(V),A.push(pe)),w&&O==="Point"&&!Ht.getOverlay().getSource().getFeatures().length&&(_e=F,ni.getText().setText(w),A.push(ni)),A}function Jt(v){let m=v==="area"?"Polygon":"LineString",E="\u53CC\u51FB\u53F3\u952E\u7ED3\u675F\u7ED8\u5236",w="\u8BF7\u70B9\u51FB\u9F20\u6807\u53F3\u952E\u5F00\u59CB\u7ED8\u5236",A=w,F=new Hr;Ht=new tc({source:F,style:ge}),qt=new io({source:F,zIndex:9998,style:function(O){return Kt(O,!0)}}),R.addLayer(qt),Bt=new ol.interaction.Draw({source:F,type:m,style:function(O){return Kt(O,!0,m,A)},condition:function(O){return O.originalEvent.buttons===2}}),R.addInteraction(Bt),Bt.on("drawstart",function(O){F.clear(),Ht.setActive(!1),A=E},this),Bt.on("drawend",function(){ge.setGeometry(_e),Ht.setActive(!0),R.once("pointermove",function(){ge.setGeometry()}),A=w},this)}function xe(){const v=po(l.value);let m=[],E=[],w=[],A=[{type:"bar",yAxisIndex:0,name:"\u9762\u79EF(\u4EA9)",barWidth:"15",itemStyle:{normal:{color:new oi(0,0,0,1,[{offset:0,color:"rgba(33, 187, 251, 0.8)"},{offset:1,color:"rgba(33, 187, 251, 0)"}],!1),barBorderRadius:[100,100,0,0]}},renderItem:function(b,V){console.log(b,V)},data:E}];f.value=="1"?x.value.forEach(b=>{m.indexOf(b.year)==-1&&(m.push(b.name),E.push(b.sum))}):f.value=="2"?x.value.forEach(b=>{m.push(b.name),E.push(b.sum),w.push(b.quantity?b.quantity:0)}):f.value=="3"?(x.value.forEach(b=>{m.push(b.name),E.push(b.sum),w.push(b.quantity?b.quantity:0)}),A.push({type:"bar",yAxisIndex:0,name:"\u6570\u91CF(\u4E2A)",barWidth:"15",itemStyle:{normal:{color:new oi(0,0,0,1,[{offset:0,color:"rgba(0, 209, 195, 0.8)"},{offset:1,color:"rgba(0, 209, 195, 0)"}],!1),barBorderRadius:[100,100,0,0]}},renderItem:function(b,V){console.log(b,V)},data:w})):f.value=="4"?(x.value.forEach(b=>{m.push(b.name),E.push(b.sum),w.push(b.quantity?b.quantity:0)}),A.push({type:"bar",yAxisIndex:0,name:"\u6570\u91CF(\u4E2A)",barWidth:"15",itemStyle:{normal:{color:new oi(0,0,0,1,[{offset:0,color:"rgba(0, 209, 195, 0.8)"},{offset:1,color:"rgba(0, 209, 195, 0)"}],!1),barBorderRadius:[100,100,0,0]}},renderItem:function(b,V){console.log(b,V)},data:w})):f.value=="5"?(x.value.forEach(b=>{m.push(b.name),E.push(b.sum),w.push(b.quantity?b.quantity:0)}),A.push({type:"bar",yAxisIndex:0,name:"\u6570\u91CF(\u4E2A)",barWidth:"15",itemStyle:{normal:{color:new oi(0,0,0,1,[{offset:0,color:"rgba(0, 209, 195, 0.8)"},{offset:1,color:"rgba(0, 209, 195, 0)"}],!1),barBorderRadius:[100,100,0,0]}},renderItem:function(b,V){console.log(b,V)},data:w})):f.value=="6"&&(x.value.forEach(b=>{m.push(b.name),E.push(b.sum),w.push(b.quantity?b.quantity:0)}),A.push({type:"bar",yAxisIndex:0,name:"\u6570\u91CF(\u4E2A)",barWidth:"15",itemStyle:{normal:{color:new oi(0,0,0,1,[{offset:0,color:"rgba(0, 209, 195, 0.8)"},{offset:1,color:"rgba(0, 209, 195, 0)"}],!1),barBorderRadius:[100,100,0,0]}},renderItem:function(b,V){console.log(b,V)},data:w}));let F=10/m.length*100;if(f.value==1){let L=function(Q,st){const C=[];return Q.forEach((dt,Qt)=>{const ye=[];for(let us=0;us<Qt;us++)ye.push("");dt&&(ye.push(dt),C.push({name:st,type:"bar",xAxisIndex:Qt,barWidth:10,data:ye}))}),C},b=[],V=[],X=[];x.value.forEach(Q=>{b.indexOf(Q.year)==-1&&b.push(Q.year)}),x.value.forEach(Q=>{let st=[];b.forEach((C,dt)=>{C==Q.year?st.push(Q.sum):st.push(void 0)}),V.push(st)}),V.forEach((Q,st)=>{X.push(...L(V[st],`${x.value[st].name}`))});let K={xAxis:b.map((Q,st)=>{const C=Array(b.length).fill("");return C[st]=Q+"\u5E74",{type:"category",position:"bottom",data:C,axisLine:{lineStyle:{color:"rgba(207, 227, 252, 1)"}}}}),grid:{top:"10%",left:"5%",right:"5%",bottom:"0%",containLabel:!0},yAxis:{type:"value",axisLabel:{interval:0,color:"rgba(207, 227, 252, 1)"}},tooltip:{trigger:"axis",triggerOn:"click",enterable:!0,hideDelay:200,extraCssText:"max-width:200%;max-height:83%; overflow: auto;",axisPointer:{type:"shadow"},textStyle:{color:"#CFE3FC"},borderWidth:1,formatter:function(Q){var st='<div class="aaa" style="height: auto;max-height: 240px;overflow-y: auto;">';return Q.forEach(C=>{if(C.value>0){for(let dt=0;dt<x.value.length;dt++)x.value[dt].name==C.seriesName&&(st+=`<div style='height: auto;color:${C.color};border:1px solid${C.color};margin:5px 0;padding:5px'><div>${x.value[dt].name}:</div>
|
|
\u6295\u8D44\u91D1\u989D\uFF1A${x.value[dt].quantity} \u4E07\u5143<br/>
|
|
\u9762\u79EF\uFF1A${x.value[dt].sum} \u4EA9
|
|
</div>`);st+="</div>"}}),st}},dataZoom:[{type:"slider",width:"40%",zoomLock:!0,top:"78%",start:0,end:F/3,show:!0,showDataShadow:!1,showDetail:!1,fillerColor:"rgba(64, 158, 255)",borderRadius:"50%",moveHandleSize:0,moveHandleStyle:{},left:"35%",height:12,handleSize:"80%",handleIcon:"path://M512,512m-448,0a448,448,0,1,0,896,0a448,448,0,1,0,-896,0Z",handleStyle:{borderWidth:0,color:"rgba(64, 158, 255)"}},{type:"inside"}],series:X},_t=window.document.querySelector(".Farmland_area");_t.style.height="350px",K&&v.setOption(K,{notMerge:!0,grid:{bottom:20}}),_s(v,K),mo().listenTo(l.value,()=>{uo(()=>{v.resize()})})}else{var O={tooltip:{trigger:"axis",axisPointer:{type:"shadow"},backgroundColor:"rgba(9, 24, 48, 0.5)",borderColor:"rgba(75, 253, 238, 0.4)",textStyle:{color:"#CFE3FC"},borderWidth:1},grid:{left:"10px",right:"10px",top:"10px",bottom:"10px",containLabel:!0},toolbox:{show:!0,orient:"vertical",x:"right",y:"center"},dataZoom:[{type:"slider",width:"40%",zoomLock:!0,top:"90%",start:0,end:F/3,show:!1,showDataShadow:!1,showDetail:!1,fillerColor:"rgba(64, 158, 255)",borderRadius:"50%",moveHandleSize:0,moveHandleStyle:{},left:"35%",height:12,handleSize:"80%",handleIcon:"path://M512,512m-448,0a448,448,0,1,0,896,0a448,448,0,1,0,-896,0Z",handleStyle:{borderWidth:0,color:"rgba(64, 158, 255)"}},{type:"inside"}],xAxis:[{type:"category",boundaryGap:!0,axisTick:{show:!1},data:m,axisLine:{lineStyle:{color:"rgba(120, 160, 236, 1)"}},axisLabel:{interval:0,color:"rgba(207, 227, 252, 1)",fontSize:14}}],yAxis:[{type:"value",axisTick:{show:!0},axisLine:{show:!0,lineStyle:{color:"rgba(120, 160, 236, 1)"},symbol:["none","arrow"],symbolSize:[5,12],symbolOffset:[0,10]},max:102,axisLabel:{interval:0,color:"rgba(207, 227, 252, 1)"},splitLine:{show:!1,lineStyle:{color:"rgba(39, 57, 75, 1)",width:1,type:"solid"}}}],series:A};let b=window.document.querySelector(".Farmland_area");b.style.height="70%",O&&v.setOption(O,{notMerge:!0,grid:{bottom:20}}),_s(v,O)}}return(v,m)=>{const E=$t("el-option"),w=$t("el-select"),A=$t("el-input"),F=$t("el-button"),O=$t("el-col"),b=$t("el-row"),V=$t("el-tooltip"),X=$t("el-tree");return et(),rt("div",ec,[ic,P("div",nc,[P("div",sc,[rc,P("div",oc,[P("p",{class:Xi(k(u)=="2"?"SelectedDiv":""),onClick:m[0]||(m[0]=L=>ke(2))},"\u884C\u653F\u533A",2),P("p",{class:Xi(k(u)=="3"?"SelectedDiv":""),onClick:m[1]||(m[1]=L=>ke(3))},"\u7ECF\u7EAC\u5EA6",2),P("p",{class:Xi(k(u)=="4"?"SelectedDiv":""),onClick:m[2]||(m[2]=L=>ke(4))},"\u5EA6\u5206\u79D2",2)]),P("div",ac,[k(u)=="2"?(et(),rt("div",lc,[it(w,{onChange:m[3]||(m[3]=L=>Gi()),"popper-class":"select_city",modelValue:k(r),"onUpdate:modelValue":m[4]||(m[4]=L=>fs(r)?r.value=L:r=L),placeholder:"\u8BF7\u9009\u62E9\u9547"},{default:ot(()=>[(et(!0),rt(vn,null,Sn(k(S),L=>(et(),ds(E,{key:L.cjqydm,label:L.cjqymc,value:L.cjqydm},null,8,["label","value"]))),128))]),_:1},8,["modelValue"]),it(w,{"popper-class":"select_city",modelValue:k(i),"onUpdate:modelValue":m[5]||(m[5]=L=>fs(i)?i.value=L:i=L),placeholder:"\u8BF7\u9009\u62E9\u6751"},{default:ot(()=>[(et(!0),rt(vn,null,Sn(k(s),L=>(et(),ds(E,{key:L.cjqydm,label:L.cjqymc,value:L.cjqymc},null,8,["label","value"]))),128))]),_:1},8,["modelValue"])])):gt("",!0),k(u)=="3"?(et(),rt("div",hc,[P("div",cc,[lt(" \u7ECF\u5EA6\uFF1A "),it(A,{class:"seach_input",modelValue:k(o).Lon,"onUpdate:modelValue":m[6]||(m[6]=L=>k(o).Lon=L),placeholder:"\u8BF7\u8F93\u5165\u7ECF\u5EA6",clearable:""},null,8,["modelValue"])]),P("div",uc,[lt(" \u7EAC\u5EA6\uFF1A "),it(A,{class:"seach_input",modelValue:k(o).Lat,"onUpdate:modelValue":m[7]||(m[7]=L=>k(o).Lat=L),placeholder:"\u8BF7\u8F93\u5165\u7EAC\u5EA6",clearable:""},null,8,["modelValue"])])])):gt("",!0),k(u)=="4"?(et(),rt("div",dc,[P("div",fc,[lt(" \u7ECF\u5EA6\uFF1A "),P("div",gc,[it(A,{class:"seach_input",modelValue:k(a).Lon.londu,"onUpdate:modelValue":m[8]||(m[8]=L=>k(a).Lon.londu=L),placeholder:"\u5EA6",clearable:""},{append:ot(()=>[lt("\xB0")]),_:1},8,["modelValue"]),it(A,{class:"seach_input",modelValue:k(a).Lon.lonfen,"onUpdate:modelValue":m[9]||(m[9]=L=>k(a).Lon.lonfen=L),placeholder:"\u5206",clearable:""},{append:ot(()=>[lt("\u2032")]),_:1},8,["modelValue"]),it(A,{class:"seach_input",modelValue:k(a).Lon.lonmiao,"onUpdate:modelValue":m[10]||(m[10]=L=>k(a).Lon.lonmiao=L),placeholder:"\u79D2",clearable:""},{append:ot(()=>[lt("\u2033")]),_:1},8,["modelValue"])])]),P("div",_c,[lt(" \u7EAC\u5EA6\uFF1A "),P("div",mc,[it(A,{class:"seach_input",modelValue:k(a).Lat.latdu,"onUpdate:modelValue":m[11]||(m[11]=L=>k(a).Lat.latdu=L),placeholder:"\u5EA6",clearable:""},{append:ot(()=>[lt("\xB0")]),_:1},8,["modelValue"]),it(A,{class:"seach_input",modelValue:k(a).Lat.latfen,"onUpdate:modelValue":m[12]||(m[12]=L=>k(a).Lat.latfen=L),placeholder:"\u5206",clearable:""},{append:ot(()=>[lt("\u2032")]),_:1},8,["modelValue"]),it(A,{class:"seach_input",modelValue:k(a).Lat.latmiao,"onUpdate:modelValue":m[13]||(m[13]=L=>k(a).Lat.latmiao=L),placeholder:"\u79D2",clearable:""},{append:ot(()=>[lt("\u2033")]),_:1},8,["modelValue"])])])])):gt("",!0)]),P("div",pc,[it(F,{class:"seach",onClick:m[14]||(m[14]=L=>ei())},{default:ot(()=>[lt("\u67E5\u8BE2")]),_:1}),it(F,{class:"resetting",onClick:m[15]||(m[15]=L=>de())},{default:ot(()=>[lt("\u91CD\u7F6E")]),_:1})])]),P("div",xc,[yc,P("div",{class:"overview",onClick:m[16]||(m[16]=L=>pn(L))},[it(b,{gutter:10},{default:ot(()=>[it(O,{span:8},{default:ot(()=>[P("div",{id:k(f)==1?"overviewItemSelect":"",class:"overviewItem"},[k(f)==1?(et(),rt("img",Sc)):gt("",!0),lt(" \u9AD8\u6807\u51C6\u519C\u7530 "),k(f)==1?(et(),rt("img",Cc)):gt("",!0)],8,vc)]),_:1}),it(O,{span:8},{default:ot(()=>[P("div",{id:k(f)==2?"overviewItemSelect":"",class:"overviewItem"},[k(f)==2?(et(),rt("img",Rc)):gt("",!0),lt(" \u6C38\u4E45\u57FA\u672C\u519C\u7530 "),k(f)==2?(et(),rt("img",wc)):gt("",!0)],8,Ec)]),_:1}),it(O,{span:8},{default:ot(()=>[P("div",{id:k(f)==3?"overviewItemSelect":"",class:"overviewItem"},[k(f)==3?(et(),rt("img",Mc)):gt("",!0),lt(" \u8015\u5730 "),k(f)==3?(et(),rt("img",Ac)):gt("",!0)],8,Ic)]),_:1})]),_:1}),it(b,{gutter:10},{default:ot(()=>[it(O,{span:8},{default:ot(()=>[P("div",{id:k(f)==4?"overviewItemSelect":"",class:"overviewItem"},[k(f)==4?(et(),rt("img",bc)):gt("",!0),lt(" \u7247\u5757\u4FE1\u606F "),k(f)==4?(et(),rt("img",Tc)):gt("",!0)],8,Lc)]),_:1}),it(O,{span:8},{default:ot(()=>[P("div",{id:k(f)==5?"overviewItemSelect":"",class:"overviewItem"},[k(f)==5?(et(),rt("img",kc)):gt("",!0),lt(" \u5730\u5757\u4FE1\u606F "),k(f)==5?(et(),rt("img",Fc)):gt("",!0)],8,Dc)]),_:1}),it(O,{span:8},{default:ot(()=>[P("div",{id:k(f)==6?"overviewItemSelect":"",class:"overviewItem"},[k(f)==6?(et(),rt("img",Pc)):gt("",!0),lt(" \u571F\u5730\u786E\u6743 "),k(f)==6?(et(),rt("img",Gc)):gt("",!0)],8,Oc)]),_:1})]),_:1})]),P("div",Bc,[P("div",Nc,[P("span",null,Wi(k(Z)),1),P("p",{onClick:m[17]||(m[17]=L=>Bi())},[lt(" \u4E0B\u8F7D \xA0 "),Xc])]),k(f)!==1?(et(),rt("div",Wc,[P("p",null,[Yc,lt(" \u603B\u9762\u79EF\uFF1A "),P("span",null,Wi(k(N)?k(N):0)+" \u4EA9",1)]),[3,4,5,6].includes(k(f))?(et(),rt("p",zc,[Vc,lt(" \u603B\u4E2A\u6570\uFF1A "),P("span",null,Wi(k(T)?k(T):0),1)])):gt("",!0)])):gt("",!0),P("div",{ref_key:"Farmland_area",ref:l,class:"Farmland_area"},null,512)])]),P("div",{class:"rightFoldDiv",onClick:m[18]||(m[18]=L=>Pi())},[it(V,{disabled:!k(e),"hide-after":"0","show-arrow":!1,"show-after":"200",class:"box-item",effect:"dark",content:"\u6536\u8D77",placement:"top"},{default:ot(()=>[k(e)?(et(),rt("img",Zc)):gt("",!0)]),_:1},8,["disabled"]),it(V,{disabled:k(e),"hide-after":"0","show-arrow":!1,"show-after":"200",class:"box-item",effect:"dark",content:"\u5C55\u5F00",placement:"top"},{default:ot(()=>[k(e)?gt("",!0):(et(),rt("img",jc))]),_:1},8,["disabled"])]),P("div",Uc,[P("span",{onClick:xn},[it(V,{class:"box-item",disabled:k(t),"show-arrow":!1,"hide-after":"0","show-after":"200",effect:"dark",content:"\u6D4B\u91CF\u7EBF",placement:"left",offset:"1"},{default:ot(()=>[Hc]),_:1},8,["disabled"])]),P("span",{onClick:yn},[it(V,{class:"box-item",disabled:k(t),"show-arrow":!1,"hide-after":"0","show-after":"200",effect:"dark",content:"\u6D4B\u91CF\u9762",placement:"left",offset:"1"},{default:ot(()=>[qc]),_:1},8,["disabled"])]),P("span",{onClick:Ni},[it(V,{class:"box-item",disabled:k(t),"show-arrow":!1,"hide-after":"0","show-after":"200",effect:"dark",content:"\u6E05\u9664",placement:"left",offset:"1"},{default:ot(()=>[Kc]),_:1},8,["disabled"])])])]),P("div",Jc,[it(X,{props:_,data:H,onCheck:gn,"render-content":_n,"show-checkbox":""})]),P("div",{class:"farmlandTimeDiv",id:k(p)?"appear":"",onClick:m[19]||(m[19]=L=>mn(L))},[P("div",$c,[(et(!0),rt(vn,null,Sn(k(j),(L,K)=>(et(),rt("div",{class:Xi({flag:k(q)[K]==!0}),key:L},Wi(K),3))),128))])],8,Qc),tu])}}},du=oo(eu,[["__scopeId","data-v-5f0277c2"]]);export{du as default};
|