@taichina/map-sdk 1.0.0 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +19 -17
- package/package.json +2 -4
- package/teee-sdk/teee-map-sdk.es.js +47 -34
- package/teee-sdk/teee-map-sdk.umd.js +2 -2
- package/teee-sdk/index.d.ts +0 -181
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
(function(e,t){typeof exports==`object`&&typeof module<`u`?t(exports,require(`maplibre-gl`),require(`@turf/bbox`)):typeof define==`function`&&define.amd?define([`exports`,`maplibre-gl`,`@turf/bbox`],t):(e=typeof globalThis<`u`?globalThis:e||self,t(e.TeeeMapSDK={},e.maplibregl,e.turfBbox))})(this,function(e,t,n){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var r=Object.create,i=Object.defineProperty,a=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.getPrototypeOf,c=Object.prototype.hasOwnProperty,l=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var s=o(t),l=0,u=s.length,d;l<u;l++)d=s[l],!c.call(e,d)&&d!==n&&i(e,d,{get:(e=>t[e]).bind(null,d),enumerable:!(r=a(t,d))||r.enumerable});return e},u=(e,t,n)=>(n=e==null?{}:r(s(e)),l(t||!e||!e.__esModule?i(n,`default`,{value:e,enumerable:!0}):n,e));t=u(t,1),n=u(n,1);var d=async()=>{let e=document.createElement(`canvas`);e.width=25,e.height=17;let t=e.getContext(`2d`);if(!t)throw Error(`无法获取 Canvas 上下文`);t.rect(0,0,e.width,e.height),t.fillStyle=`rgba(0, 0, 0, 0)`,t.fill(),t.strokeStyle=`red`,t.lineWidth=3,t.stroke();let n=new Image;return n.src=e.toDataURL(),new Promise((e,t)=>{n.onload=()=>e(n),n.onerror=()=>t(Error(`Failed to load redBoxIcon image`))})},f=async()=>{let e=document.createElement(`canvas`);e.width=64,e.height=64;let t=e.getContext(`2d`);if(!t)throw Error(`无法获取 Canvas 上下文`);let n=e.width/2,r=e.height/2;t.beginPath(),t.arc(n,r,20,0,Math.PI*2),t.fillStyle=`rgba(0, 0, 0, 0)`,t.fill(),t.strokeStyle=`#ffffff`,t.lineWidth=3,t.setLineDash([6,6]),t.lineCap=`round`,t.lineJoin=`round`,t.stroke();let i=new Image;return i.src=e.toDataURL(),new Promise((e,t)=>{i.onload=()=>e(i),i.onerror=()=>t(Error(`Failed to load dashCircle image`))})},p=async(e=`h`,t=`r`,n=``,r=``)=>{let i=e===`h`,a=t===`r`,o=`transparent`,s=n||o,c=r||o,l=27*.5,u=3*1.75,d=i?27*1.25:27,f=12*1.2,p=3+(i?f:0)+54+u,m=d+l,h=document.createElement(`canvas`);h.width=p,h.height=m;let g=h.getContext(`2d`);if(!g)throw Error(`无法获取 Canvas 上下文`);g.clearRect(0,0,p,m),g.save(),a||(g.translate(p/2,m/2),g.scale(1,-1),g.translate(-p/2,-m/2)),g.strokeStyle=`rgb(255,255,255)`,g.fillStyle=`rgb(255,255,255)`,3/2-u/2+5;let _=m-l;g.beginPath(),g.rect(3.875,_,u,l),g.fill(),g.beginPath(),g.lineWidth=3;let v=6.5,y=m-l-d,ee=m-l;g.moveTo(v,y),g.lineTo(v,ee),g.stroke(),g.lineWidth=2;let b=y+27/2,x=16+(i?f:0)+5,te=x+27-1;if(g.beginPath(),g.strokeStyle=`rgb(255,255,255)`,g.lineWidth=2,g.fillStyle=s,g.arc(x,b,12,0,Math.PI*2),g.fill(),g.stroke(),g.beginPath(),g.strokeStyle=`rgb(255,255,255)`,g.lineWidth=2,g.fillStyle=c,g.arc(te,b,12,0,Math.PI*2),g.fill(),g.stroke(),i){g.beginPath(),g.lineWidth=2,g.strokeStyle=`rgb(255,255,255)`,v+3/2;let e=x-12-2/2,t=b;g.moveTo(8,t),g.lineTo(e,t),g.stroke()}g.restore();let ne=new Image;return ne.src=h.toDataURL(),new Promise((e,t)=>{ne.onload=()=>e(ne),ne.onerror=t})},m=async(e=`h`,t=`r`)=>{let n=e===`h`,r=t===`r`,i=12*1.2,a=27*.5,o=n?27*1.25:27,s=3+(n?i:0)+54+5.25+8,c=o+a+8,l=document.createElement(`canvas`);l.width=s,l.height=c;let u=l.getContext(`2d`);if(!u)throw Error(`无法获取 Canvas 上下文`);u.clearRect(0,0,s,c),u.save(),r||(u.translate(s/2,c/2),u.scale(1,-1),u.translate(-s/2,-c/2));let d=c-a-o-4+27/2,f=16+(n?i:0)+4+27,p=1.5,m=f+12+4*1.5,h=d-12,g=d+12+8;u.beginPath(),u.setLineDash([8,8]),u.strokeStyle=`#ffffff`,u.lineWidth=3,u.rect(p,h,m-p,g-h),u.stroke(),u.restore();let _=new Image;return _.src=l.toDataURL(),new Promise((e,t)=>{_.onload=()=>e(_),_.onerror=t})},h=async(e=`h`,t=`r`,n=!0)=>{let r=e===`h`,i=t===`r`,a=12*1.2,o=27*.5,s=r?27*1.25:27,c=3+(r?a:0)+54+5.25,l=s+o,u=document.createElement(`canvas`);u.width=c,u.height=l;let d=u.getContext(`2d`);if(!d)throw Error(`无法获取 Canvas 上下文`);d.clearRect(0,0,c,l),d.save(),i||(d.translate(c/2,l/2),d.scale(1,-1),d.translate(-c/2,-l/2));let f=l-o-s+27/2,p=16+(r?a:0)+5,m=p+27;d.lineWidth=4,d.strokeStyle=`#ff0000`,n&&(d.beginPath(),d.moveTo(p-12,f-12),d.lineTo(p+12,f+12),d.moveTo(p+12,f-12),d.lineTo(p-12,f+12),d.stroke()),n&&(d.beginPath(),d.moveTo(m-12,f-12),d.lineTo(m+12,f+12),d.moveTo(m+12,f-12),d.lineTo(m-12,f+12),d.stroke()),d.restore();let h=new Image;return h.src=u.toDataURL(),new Promise((e,t)=>{h.onload=()=>e(h),h.onerror=t})},g=async(e=`h`,t=`r`,n,r)=>{let i=e===`h`,a=t===`r`,o=12*1.2,s=27*.5,c=i?27*1.25:27,l=3+(i?o:0)+54+5.25,u=c+s,d=document.createElement(`canvas`);d.width=l,d.height=u;let f=d.getContext(`2d`);if(!f)throw Error(`无法获取 Canvas 上下文`);f.clearRect(0,0,l,u),f.save(),a||(f.translate(l/2,u/2),f.scale(1,-1),f.translate(-l/2,-u/2));let p=u-s-c+27/2,m=16+(i?o:0)+27+5;f.save(),f.translate(m,p),f.fillStyle=n;let h=r?12:24;f.fillRect(-12,-12,h,24),r&&(f.fillStyle=r,f.fillRect(0,-12,12,24)),f.strokeStyle=`white`,f.lineWidth=2,f.strokeRect(-12,-12,24,24),f.restore(),f.restore();let g=new Image;return g.src=d.toDataURL(),new Promise((e,t)=>{g.onload=()=>e(g),g.onerror=t})},_=`data:image/svg+xml,%3c?xml%20version='1.0'%20standalone='no'?%3e%3c!DOCTYPE%20svg%20PUBLIC%20'-//W3C//DTD%20SVG%201.1//EN'%20'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3csvg%20t='1776081402940'%20class='icon'%20viewBox='0%200%201024%201024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20p-id='9172'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20width='32'%20height='32'%3e%3cpath%20d='M675.84%20409.6v-102.4a163.84%20163.84%200%201%200-327.68%200v102.4h327.68z%20m-409.6%200v-102.4c0-135.72096%20110.03904-245.76%20245.76-245.76s245.76%20110.03904%20245.76%20245.76v102.4a81.92%2081.92%200%200%201%2081.92%2081.92v225.28c0%20135.72096-110.03904%20245.76-245.76%20245.76h-163.84c-135.72096%200-245.76-110.03904-245.76-245.76V491.52a81.92%2081.92%200%200%201%2081.92-81.92z%20m286.72%20348.16v-51.87584a40.96%2040.96%200%200%201%2014.19264-30.98624%2081.92%2081.92%200%201%200-113.07008-2.56c0.79872%200.79872%201.72032%201.6384%202.7648%202.56A40.96%2040.96%200%200%201%20471.04%20705.88416V757.76a40.96%2040.96%200%201%200%2081.92%200z'%20p-id='9173'%20fill='%23ffffff'%3e%3c/path%3e%3c/svg%3e`,v={BASE_COLOR:`rgb(85,120,182)`,BG_COLOR:`rgb(0,0,0)`},y=(e,t,n)=>{let r=document.createElement(`canvas`);r.width=66,r.height=64;let i=r.getContext(`2d`);return i.clearRect(0,0,r.width,r.height),n===2&&(i.translate(66,0),i.scale(-1,1)),e===1?(i.beginPath(),i.arc(46,20,20-4/2,0,Math.PI*2),i.fillStyle=t||`rgb(255,255,255,0)`,i.strokeStyle=t||v.BASE_COLOR,i.lineWidth=4,i.fill(),i.stroke(),i.beginPath(),i.moveTo(6,40/2),i.lineTo(26,40/2),i.lineWidth=4,i.strokeStyle=v.BASE_COLOR,i.stroke(),i.beginPath(),i.lineCap=`round`,i.moveTo(8/2,0),i.lineTo(8/2,40),i.lineWidth=4,i.strokeStyle=v.BASE_COLOR,i.stroke(),i.beginPath(),i.moveTo(8/2,40),i.lineTo(8/2,64),i.lineWidth=8,i.strokeStyle=v.BASE_COLOR,i.stroke(),r):(i.beginPath(),i.arc(26,20,20-4/2,0,Math.PI*2),i.fillStyle=t||`rgb(255,255,255,0)`,i.strokeStyle=t||v.BASE_COLOR,i.lineWidth=4,i.fill(),i.stroke(),i.beginPath(),i.lineCap=`round`,i.moveTo(8/2,0),i.lineTo(8/2,40),i.lineWidth=4,i.strokeStyle=v.BASE_COLOR,i.stroke(),i.beginPath(),i.moveTo(8/2,40),i.lineTo(8/2,64),i.lineWidth=8,i.strokeStyle=v.BASE_COLOR,i.stroke(),r)},ee=()=>{let e=document.createElement(`canvas`);e.width=24,e.height=64;let t=e.getContext(`2d`);return t.fillStyle=v.BG_COLOR,t.fillRect(0,0,24,64),t.strokeStyle=v.BASE_COLOR,t.lineWidth=8,t.strokeRect(0,0,24,64),e},b=()=>{let e=document.createElement(`canvas`);e.width=15,e.height=40;let t=e.getContext(`2d`);return t.clearRect(0,0,e.width,e.height),t.beginPath(),t.moveTo(0,4/2),t.lineTo(15-4/2,4/2),t.moveTo(4/2,4/2),t.lineTo(4/2,36),t.moveTo(0,36),t.lineTo(15-4/2,36),t.lineWidth=4,t.strokeStyle=v.BASE_COLOR,t.stroke(),e},x=async(e=`h`,t=`r`,n=``)=>{let r=y(e==`h`?1:2,n,t==`l`?1:2),i=new Image;return i.src=r.toDataURL(),new Promise((e,t)=>{i.onload=()=>e(i),i.onerror=t})},te=async()=>{let e=ee(),t=new Image;return t.src=e.toDataURL(),new Promise((e,n)=>{t.onload=()=>e(t),t.onerror=n})},ne=async()=>{let e=b(),t=new Image;return t.src=e.toDataURL(),new Promise((e,n)=>{t.onload=()=>e(t),t.onerror=n})},S=function(e){return e.Blue=`blue`,e.Green=`green`,e.Red=`red`,e.Yellow=`yellow`,e.Gray=`gray`,e.Purple=`purple`,e.Red_Purple=`red-purple`,e}({}),C=function(e){return e.Red=`red`,e.Red_Yellow=`red-yellow`,e.Yellow=`yellow`,e.Yellow_Yellow=`yellow-yellow`,e.Yellow_Green=`yellow-green`,e.Green=`green`,e.Blue=`blue`,e.White=`white`,e}({}),re=async()=>{let[e,t,n,r]=await Promise.all([x(`h`,`r`,``),x(`h`,`l`,``),x(`l`,`r`,``),x(`l`,`l`,``)]),i=new Image;i.src=_;let[a,o,s]=await Promise.all([ne(),d(),f()]),[c,l,u,v]=await Promise.all([p(`h`,`r`,``),p(`h`,`l`,``),p(`l`,`r`,``),p(`l`,`l`,``)]),[y,ee,b,re]=await Promise.all([m(`h`,`r`),m(`h`,`l`),m(`l`,`r`),m(`l`,`l`)]),[w,ie,ae,oe]=await Promise.all([h(`h`,`r`),h(`h`,`l`),h(`l`,`r`),h(`l`,`l`)]),se=[`h`,`l`],ce=[`r`,`l`],le=[S.Blue,S.Green,S.Red,S.Yellow,S.Gray,S.Purple,S.Red_Purple],ue=se.flatMap(e=>ce.flatMap(t=>le.map(n=>({height:e,dir:t,color:n})))),de=await Promise.all(ue.map(({height:e,dir:t,color:n})=>g(e,t,n===S.Red_Purple?`red`:n,n===S.Red_Purple?`purple`:void 0))),fe=[C.Red,C.Red_Yellow,C.Yellow,C.Yellow_Yellow,C.Yellow_Green,C.Green,C.Blue,C.White],pe=se.flatMap(e=>ce.flatMap(t=>fe.map(n=>({height:e,dir:t,color:n})))),me=await Promise.all(pe.map(({height:e,dir:t,color:n})=>{let r=n,i;return n===C.Red_Yellow?(r=`red`,i=`yellow`):n===C.Yellow_Yellow?(r=`yellow`,i=`yellow`):n===C.Yellow_Green&&(r=`yellow`,i=`green`),p(e,t,r,i)})),T=[C.Red,C.Green,C.White,C.Blue],he=se.flatMap(e=>ce.flatMap(t=>T.map(n=>({height:e,dir:t,color:n})))),ge=await Promise.all(he.map(({height:e,dir:t,color:n})=>x(e,t,n))),_e=await te();return[{id:`icon-signal-h-r`,image:e},{id:`icon-signal-h-l`,image:t},{id:`icon-signal-l-r`,image:n},{id:`icon-signal-l-l`,image:r},{id:`icon-lock`,image:i},{id:`icon-bumper`,image:a},{id:`icon-red-box`,image:o},{id:`icon-dash-circle`,image:s},{id:`icon-ctc-signal-h-r`,image:c},{id:`icon-ctc-signal-h-l`,image:l},{id:`icon-ctc-signal-l-r`,image:u},{id:`icon-ctc-signal-l-l`,image:v},{id:`icon-ctc-box-h-r`,image:y},{id:`icon-ctc-box-h-l`,image:ee},{id:`icon-ctc-box-l-r`,image:b},{id:`icon-ctc-box-l-l`,image:re},{id:`icon-ctc-x-h-r`,image:w},{id:`icon-ctc-x-h-l`,image:ie},{id:`icon-ctc-x-l-r`,image:ae},{id:`icon-ctc-x-l-l`,image:oe},{id:`icon-jcw`,image:_e},...de.map((e,t)=>{let n=ue[t];return{id:`icon-ctc-s-${n.height}-${n.dir}-${n.color}`,image:e}}),...me.map((e,t)=>{let n=pe[t];return{id:`icon-ctc-signal-${n.height}-${n.dir}-${n.color}`,image:e}}),...ge.map((e,t)=>{let n=he[t];return{id:`icon-signal-${n.height}-${n.dir}-${n.color}`,image:e}})]},w={geojson:e=>({type:`geojson`,data:e||{type:`FeatureCollection`,features:[]},promoteId:`code`}),raster:e=>({type:`raster`,tiles:[e],scheme:`tms`,tileSize:256}),graph:e=>({type:`vector`,tiles:[e],scheme:`tms`,promoteId:`code`}),geom:e=>({type:`vector`,tiles:[e],scheme:`tms`,promoteId:`code`}),image:(e,t)=>({type:`image`,url:e,coordinates:t}),video:(e,t)=>({type:`video`,urls:e,coordinates:t}),canvas:(e,t)=>({type:`canvas`,canvas:e,coordinates:t}),mbtiles:e=>({type:`vector`,tiles:[e]})},ie={background:(e,t)=>({id:`${e.id}_${t}`,type:`background`,paint:{"background-color":`#131212`}}),track:(e,t)=>[{id:`${e.id}_${t}_lock`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#a7009e`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_lock_icon`,type:`symbol`,source:e.id,"source-layer":t,layout:{"symbol-placement":`line-center`,"icon-anchor":`top`,"icon-image":`icon-lock`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.2,15,.5,16,.6,17,.8],"icon-offset":[0,5],"icon-allow-overlap":!0,"icon-rotation-alignment":`viewport`,"icon-rotate":0},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_poweroff_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_poweroff_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_catenery_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_catenery_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_select_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#ffffff`,"line-dasharray":[.5,.5],"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}_hitarea`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],track_circuit:(e,t)=>[{id:`${e.id}_${t}_poweroff_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`subState1`],`1`],1,0]}},{id:`${e.id}_${t}_poweroff_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`subState1`],`1`],1,0]}},{id:`${e.id}_${t}_select_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#ffffff`,"line-dasharray":[.4,.4],"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}_hitarea`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":3}},{id:`${e.id}_${t}_red`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`red`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_white`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_grey`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`,visibility:`none`},paint:{"line-color":`grey`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_subpath`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`burlywood`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`4`],1,0]}},{id:`${e.id}_${t}_mainpath`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`5`],1,0]}}],signal:(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,.2,16,.6,18,.8,20,1.5],r=[];[S.Blue,S.Green,S.Red,S.Yellow,S.Gray,S.Purple,S.Red_Purple].forEach(i=>{r.push({id:`${e.id}_${t}_square_${i}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-s-h-r-${i}`,`icon-ctc-s-h-l-${i}`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-s-l-r-${i}`,`icon-ctc-s-l-l-${i}`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-right`,`top-right`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`subState1`],i],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})});let i=[];return[C.Red,C.Red_Yellow,C.Yellow,C.Yellow_Yellow,C.Yellow_Green,C.Green,C.Blue,C.White].forEach(r=>{i.push({id:`${e.id}_${t}_${r}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-h-r-${r}`,`icon-ctc-signal-h-l-${r}`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-l-r-${r}`,`icon-ctc-signal-l-l-${r}`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],r],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})}),[...i,{id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-h-r`,`icon-ctc-signal-h-l`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-l-r`,`icon-ctc-signal-l-l`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}},{id:`${e.id}_${t}_box`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-box-h-r`,`icon-ctc-box-h-l`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-box-l-r`,`icon-ctc-box-l-l`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`select`],!0],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}},{id:`${e.id}_${t}_x`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-x-h-r`,`icon-ctc-x-h-l`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-x-l-r`,`icon-ctc-x-l-l`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`subState2`],`off`],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}},...r]},bumper:(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-bumper`,"icon-size":.3,"icon-allow-overlap":!0},paint:{"icon-opacity":0}}),switch:(e,t)=>[{id:`${e.id}_${t}_hitarea`,type:`circle`,source:e.id,"source-layer":t,paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,11],"circle-color":`red`,"circle-opacity":0}},{id:`${e.id}_${t}_dash_circle`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-dash-circle`,"icon-allow-overlap":!0,"icon-size":[`interpolate`,[`linear`],[`zoom`],17,.5]},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,11,22,15],"text-font":[`Open Sans Regular`],"text-anchor":`top`,"text-offset":[0,.5],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":[`match`,[`feature-state`,`state`],`2`,`lightgreen`,`3`,`darkorange`,`4`,`red`,`white`]}},{id:`${e.id}_${t}_lock`,type:`circle`,source:e.id,"source-layer":t,layout:{visibility:`visible`},paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,8],"circle-stroke-width":1.7,"circle-stroke-color":[`match`,[`feature-state`,`state`],`2`,`green`,`3`,`darkorange`,`4`,`red`,`white`],"circle-color":`transparent`,"circle-stroke-opacity":[`case`,[`==`,[`feature-state`,`subState2`],`1`],1,0]}},{id:`${e.id}_${t}_danfen`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-red-box`,"icon-allow-overlap":!0,"icon-offset":[0,15],"icon-size":[`interpolate`,[`linear`],[`zoom`],5,.2,10,.5,18,1]},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`subState3`],`1`],1,0]}}],switch_loc:(e,t)=>[{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":5,"line-color":`#000000`}},{id:`${e.id}_${t}_normal`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`green`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_reverse`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`darkorange`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_fourway`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":4,"line-color":`#000000`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`4`],1,0]}},{id:`${e.id}_${t}_normal_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_reverse_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_normal_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}},{id:`${e.id}_${t}_reverse_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}}],insulation:(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,1,15,1.5,16,2,17,4];return{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],paint:{"circle-radius":n,"circle-stroke-width":n,"circle-stroke-color":`#ffbb00`},layout:{visibility:`none`}}},label:(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],10,[`==`,[`get`,`category`],96],8,7],22,[`case`,[`==`,[`get`,`category`],50],16,[`==`,[`get`,`category`],96],12,13]],"text-font":[`Open Sans Regular`],"text-anchor":[`case`,[`==`,[`get`,`angle`],90],`bottom-left`,`top-right`],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`#C0C33F`}}),prevention:(e,t)=>[{id:`${e.id}_${t}_circle`,type:`circle`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[`2`,`8`,`20`,`87`],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,3,20,10],"circle-stroke-width":2,"circle-stroke-color":`red`},layout:{visibility:`none`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[`2`,`8`,`20`,`87`],!0,!1],layout:{"text-field":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`2`],`网`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`8`],`停`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`20`],`界`,`门`],"text-font":[`Open Sans Regular`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,2,20,12],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0,visibility:`none`},paint:{"text-color":`white`}}]},ae=e=>{let t=[];return e.layers.forEach((n,r)=>{let i=ie[n],a=e.sourceLayers[r];if(i){let n=i(e,a);Array.isArray(n)?t.push(...n):t.push(n)}else console.warn(`图层 ${n} 尚未实现`)}),t},oe=(e,t)=>({id:`${e.id}_${t}`,type:`background`,paint:{"background-color":`#131212`}}),se=(e,t)=>[{id:`${e.id}_${t}_lock`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#a7009e`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_lock_icon`,type:`symbol`,source:e.id,"source-layer":t,layout:{"symbol-placement":`line-center`,"icon-anchor":`top`,"icon-image":`icon-lock`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.2,15,.5,16,.6,17,.8],"icon-offset":[0,5],"icon-allow-overlap":!0,"icon-rotation-alignment":`viewport`,"icon-rotate":0},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_poweroff_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_poweroff_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_catenery_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_catenery_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],ce=(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,2,16,3.5,18,4.5,20,5];return[{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":3}},{id:`${e.id}_${t}_red`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`red`,"line-width":n,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_white`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":n,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_grey`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`,visibility:`none`},paint:{"line-color":`grey`,"line-width":n,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_white_label`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_red_label`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`red`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}}]},le=(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,.2,16,.6,18,.8,20,1.5],r=[];return[C.Red,C.Green,C.White,C.Blue].forEach(i=>{r.push({id:`${e.id}_${t}_${i}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-h-l-${i}`,`icon-signal-h-r-${i}`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-l-l-${i}`,`icon-signal-l-r-${i}`]],"icon-size":n,"icon-rotate":[`case`,[`==`,[`get`,`posi_side`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],i],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})}),[...r,{id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-h-l`,`icon-signal-h-r`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-l-l`,`icon-signal-l-r`]],"icon-size":n,"icon-rotate":[`case`,[`==`,[`get`,`posi_side`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}}]},ue=(e,t)=>[{id:`${e.id}_${t}_hitarea`,type:`circle`,source:e.id,"source-layer":t,paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,11],"circle-color":`red`,"circle-opacity":0}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,11,22,15],"text-font":[`Open Sans Regular`],"text-anchor":`top`,"text-offset":[0,.5],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":[`match`,[`feature-state`,`state`],`2`,`lightgreen`,`3`,`darkorange`,`4`,`red`,`white`]}},{id:`${e.id}_${t}_lock`,type:`circle`,source:e.id,"source-layer":t,layout:{visibility:`visible`},paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,8],"circle-stroke-width":1.7,"circle-stroke-color":[`match`,[`feature-state`,`state`],`2`,`green`,`3`,`darkorange`,`4`,`red`,`white`],"circle-color":`transparent`,"circle-stroke-opacity":[`case`,[`==`,[`feature-state`,`subState2`],`1`],1,0]}},{id:`${e.id}_${t}_danfen`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-red-box`,"icon-allow-overlap":!0,"icon-offset":[0,15],"icon-size":[`interpolate`,[`linear`],[`zoom`],5,.2,10,.5,18,1]},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`subState3`],`1`],1,0]}}],de=(e,t)=>[{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":5,"line-color":`#000000`}},{id:`${e.id}_${t}_normal`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`green`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_reverse`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`darkorange`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_fourway`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":4,"line-color":`#000000`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`4`],1,0]}},{id:`${e.id}_${t}_normal_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_reverse_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_normal_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}},{id:`${e.id}_${t}_reverse_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}}],fe=(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-bumper`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-rotate":[`get`,`angle`],"icon-allow-overlap":!0,"icon-anchor":`left`}}),pe=(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],10,[`==`,[`get`,`category`],96],8,7],22,[`case`,[`==`,[`get`,`category`],50],16,[`==`,[`get`,`category`],96],12,13]],"text-font":[`Open Sans Regular`],"text-anchor":[`case`,[`==`,[`get`,`angle`],90],`bottom-left`,`top-right`],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`#C0C33F`}}),me=(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,1,15,1.5,16,2,17,4];return{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],paint:{"circle-radius":n,"circle-stroke-width":n,"circle-stroke-color":`#ffbb00`},layout:{visibility:`none`}}},T=function(e){return e[e.NULL=0]=`NULL`,e[e.BUMPER=1]=`BUMPER`,e[e.CONTACTLINEEND=2]=`CONTACTLINEEND`,e[e.FIXEDDERAILER=3]=`FIXEDDERAILER`,e[e.CONTACTLINENOSTOP=4]=`CONTACTLINENOSTOP`,e[e.CONTACTLINENOSTOPIN=5]=`CONTACTLINENOSTOPIN`,e[e.OTHERPROMPT=6]=`OTHERPROMPT`,e[e.OTHERBRAKE=7]=`OTHERBRAKE`,e[e.ONESTOP=8]=`ONESTOP`,e[e.SPEEDLIMITED=9]=`SPEEDLIMITED`,e[e.SPEEDNOTICE=10]=`SPEEDNOTICE`,e[e.CROSSSPEEDLIMITED=11]=`CROSSSPEEDLIMITED`,e[e.CONTACTLINEPSS=12]=`CONTACTLINEPSS`,e[e.SSG=13]=`SSG`,e[e.CONTACTLINEPSSIN=14]=`CONTACTLINEPSSIN`,e[e.CONTACTLINENOAREA=15]=`CONTACTLINENOAREA`,e[e.HIGHPOSTSIGNAL=16]=`HIGHPOSTSIGNAL`,e[e.RESCUEVEHICLE=17]=`RESCUEVEHICLE`,e[e.RAILWAYCROSS=18]=`RAILWAYCROSS`,e[e.TRAIN=19]=`TRAIN`,e[e.STATIONBOUND=20]=`STATIONBOUND`,e[e.SHORTPOSTSIGNAL=21]=`SHORTPOSTSIGNAL`,e[e.BRIDGE=22]=`BRIDGE`,e[e.WHITE=23]=`WHITE`,e[e.WHITEBLUE=24]=`WHITEBLUE`,e[e.BLUE=25]=`BLUE`,e[e.BLUEWHITE=26]=`BLUEWHITE`,e[e.SLOPE=27]=`SLOPE`,e[e.PEOPLE=28]=`PEOPLE`,e[e.TUNNEL=29]=`TUNNEL`,e[e.DANGER=30]=`DANGER`,e[e.SIGNAL=31]=`SIGNAL`,e[e.SWERVE=32]=`SWERVE`,e[e.SWITCH=33]=`SWITCH`,e[e.FOULINGPOST=38]=`FOULINGPOST`,e[e.CUNCHE=39]=`CUNCHE`,e[e.STATIONBOUNDEXTEND=40]=`STATIONBOUNDEXTEND`,e[e.RED=41]=`RED`,e[e.GREEN=42]=`GREEN`,e[e.YELLOW=43]=`YELLOW`,e[e.BLOCKLINE=50]=`BLOCKLINE`,e[e.WORKAREA=51]=`WORKAREA`,e[e.ROUTELINE=52]=`ROUTELINE`,e[e.PARK=53]=`PARK`,e[e.WORKBUOND=54]=`WORKBUOND`,e[e.WORKBUONDCROSS=55]=`WORKBUONDCROSS`,e[e.LEFTHIGHPLATFORM=61]=`LEFTHIGHPLATFORM`,e[e.RIGHTHIGHPLATFORM=62]=`RIGHTHIGHPLATFORM`,e[e.BOTHSIDEHIGHPLATFORM=63]=`BOTHSIDEHIGHPLATFORM`,e[e.TGQ=47]=`TGQ`,e[e.DOOR=87]=`DOOR`,e[e.OTHER=95]=`OTHER`,e[e.SIDE=253]=`SIDE`,e[e.NONE=254]=`NONE`,e[e.MAX=255]=`MAX`,e[e.ISOLATE=35]=`ISOLATE`,e[e.ISOLATESWITCH=100]=`ISOLATESWITCH`,e}({}),he={background:oe,signal:le,track:se,track_circuit:ce,bumper:fe,switch:ue,switch_loc:de,insulation:me,label:pe,prevention:(e,t)=>[{id:`${e.id}_${t}_jcw`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],String(T.CONTACTLINEEND)],`icon-jcw`,``],"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-allow-overlap":!0,"icon-anchor":`left`}},{id:`${e.id}_${t}_circle`,type:`circle`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[String(T.ONESTOP),String(T.STATIONBOUND),String(T.DOOR)],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,6,20,18],"circle-stroke-width":2,"circle-stroke-color":`red`},layout:{visibility:`visible`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[String(T.CONTACTLINEEND),String(T.ONESTOP),String(T.STATIONBOUND),String(T.DOOR)],!0,!1],layout:{"text-field":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],String(T.ONESTOP)],`停`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],String(T.STATIONBOUND)],`界`,``],"text-font":[`Open Sans Regular`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,20,18],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0,visibility:`visible`},paint:{"text-color":`white`}}]},ge=e=>{let t=[];return e.layers.forEach((n,r)=>{let i=he[n],a=e.sourceLayers[r];if(i){let n=i(e,a);Array.isArray(n)?t.push(...n):t.push(n)}else console.warn(`图层 ${n} 尚未实现`)}),t},_e={background:(e,t)=>({id:`${e.id}_${t}`,type:`background`,paint:{"background-color":`#131212`}}),signal:(e,t)=>[{id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],2],`icon-signal-h-r`,`icon-signal-h-l`],[`case`,[`==`,[`get`,`posi_side`],2],`icon-signal-l-r`,`icon-signal-l-l`]],"icon-allow-overlap":!0,"icon-rotate":[`case`,[`==`,[`get`,`posi_side`],2],[`-`,270,[`to-number`,[`get`,`angle`]]],[`-`,90,[`to-number`,[`get`,`angle`]]]],"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,0,16,.3,18,.5,20,1],"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`bottom-right`],"icon-offset":[0,2]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`get`,`name`],"text-font":[`Arial Unicode MS Bold`],"text-size":[`interpolate`,[`linear`],[`zoom`],12,5,14,8,18,14],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0,"text-offset":[0,.6]},paint:{"text-color":`gold`}}],track:(e,t)=>[{id:`${e.id}_${t}_hitarea`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],track_circuit:null,bumper:(e,t)=>[{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,3,12,3,14,5,16,6,20,8],"circle-stroke-width":2,"circle-stroke-color":`red`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":`档`,"text-font":[`Arial Unicode MS Bold`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,12,8,14,10,16,12,20,12],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`}}],switch:null,switch_loc:null,insulation:null,label:null,prevention:(e,t)=>[{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[`2`,`8`,`20`,`87`],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,3,12,3,14,5,16,6,20,8],"circle-stroke-width":2,"circle-stroke-color":`red`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`2`],`网`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`8`],`停`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`20`],`界`,`门`],"text-font":[`Arial Unicode MS Bold`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,12,8,14,10,16,12,20,12],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`}}]},ve=e=>{let t=[];return e.layers.forEach((n,r)=>{let i=_e[n],a=e.sourceLayers[r];if(i){let n=i(e,a);Array.isArray(n)?t.push(...n):t.push(n)}else console.warn(`图层 ${n} 尚未实现`)}),t},ye=e=>[{id:`${e}_raster_layer`,type:`raster`,source:e,paint:{"raster-opacity":.8}}],be={background:e=>({id:`${e}_background`,type:`background`,paint:{"background-color":`#131212`}}),signal:e=>{let t=[`interpolate`,[`exponential`,2],[`zoom`],12,.2,16,.6,18,.8,20,1.5];return[...[C.Red,C.Green,C.White,C.Blue].map(n=>({id:`${e}_signal_${n}`,type:`symbol`,source:e,layout:{"icon-image":[`case`,[`==`,[`get`,`installType`],1],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-h-l-${n}`,`icon-signal-h-r-${n}`],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-l-l-${n}`,`icon-signal-l-r-${n}`]],"icon-size":t,"icon-rotate":[`case`,[`==`,[`get`,`positionSide`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`positionSide`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],n],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})),{id:`${e}_signal`,type:`symbol`,source:e,layout:{"icon-image":[`case`,[`==`,[`get`,`installType`],1],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-h-l`,`icon-signal-h-r`],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-l-l`,`icon-signal-l-r`]],"icon-size":t,"icon-rotate":[`case`,[`==`,[`get`,`positionSide`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`positionSide`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}}]},track:e=>[{id:`${e}_track_lock`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`#a7009e`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e}_track_lock_icon`,type:`symbol`,source:e,layout:{"symbol-placement":`line-center`,"icon-anchor":`top`,"icon-image":`icon-lock`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.2,15,.5,16,.6,17,.8],"icon-offset":[0,5],"icon-allow-overlap":!0,"icon-rotation-alignment":`viewport`,"icon-rotate":0},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e}_track_poweroff_border`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e}_track_poweroff_fill`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e}_track_catenery_border`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e}_track_catenery_fill`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e}_track`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],track_circuit:e=>{let t=[`interpolate`,[`exponential`,2],[`zoom`],12,2,16,3.5,18,4.5,20,5];return[{id:`${e}_trackcircuit_bad`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":[`case`,[`==`,[`feature-state`,`state`],1],`#ff0000`,[`==`,[`feature-state`,`state`],2],`#ffffff`,[`==`,[`feature-state`,`state`],3],`#808080`,`#000000`],"line-width":t,"line-dasharray":[4,4],"line-opacity":[`case`,[`==`,[`feature-state`,`substate`],0],1,0]}},{id:`${e}_trackcircuit_grey`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":t,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],3],[`!=`,[`feature-state`,`substate`],0]],1,0]}},{id:`${e}_trackcircuit_red`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`red`,"line-width":t,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],1],[`!=`,[`feature-state`,`substate`],0]],1,0]}},{id:`${e}_trackcircuit_white`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":t,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],2],[`!=`,[`feature-state`,`substate`],0]],1,0]}},{id:`${e}_trackcircuit_white_label`,type:`symbol`,source:e,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],2],1,0]}},{id:`${e}_trackcircuit_red_label`,type:`symbol`,source:e,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`red`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],1],1,0]}}]},bumper:e=>({id:`${e}_bumper`,type:`symbol`,source:e,layout:{"icon-image":`icon-bumper`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-rotate":[`get`,`angle`],"icon-allow-overlap":!0,"icon-anchor":`left`}}),switch:e=>[{id:`${e}_switch_hitarea`,type:`circle`,source:e,paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,11],"circle-color":`red`,"circle-opacity":0}},{id:`${e}_switch_text`,type:`symbol`,source:e,layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,11,22,15],"text-font":[`Open Sans Regular`],"text-anchor":`top`,"text-offset":[0,.5],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":[`match`,[`feature-state`,`state`],`2`,`lightgreen`,`3`,`darkorange`,`4`,`red`,`white`]}}],switch_loc:e=>[{id:`${e}_switchloc`,type:`line`,source:e,paint:{"line-width":5,"line-color":`#000000`}},{id:`${e}_switchloc_normal`,type:`line`,source:e,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`green`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e}_switchloc_reverse`,type:`line`,source:e,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`darkorange`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}}],insulation:e=>{let t=[`interpolate`,[`exponential`,2],[`zoom`],12,1,15,1.5,16,2,17,4];return{id:`${e}_insulation`,type:`circle`,source:e,filter:[`!=`,[`get`,`category`],2],paint:{"circle-radius":t,"circle-stroke-width":t,"circle-stroke-color":`#ffbb00`}}},label:e=>({id:`${e}_label`,type:`symbol`,source:e,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":[`case`,[`==`,[`get`,`angle`],90],`bottom-left`,`top-right`],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`yellow`}}),prevention:e=>[{id:`${e}_prevention_jcw`,type:`symbol`,source:e,layout:{"icon-image":[`case`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.CONTACTLINEEND],`icon-jcw`,``],"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-allow-overlap":!0,"icon-anchor":`left`}},{id:`${e}_prevention_circle`,type:`circle`,source:e,filter:[`match`,[`to-number`,[`get`,`ucOobType`]],[T.ONESTOP,T.STATIONBOUND,T.DOOR],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,6,20,18],"circle-stroke-width":2,"circle-stroke-color":`red`}},{id:`${e}_prevention_text`,type:`symbol`,source:e,filter:[`match`,[`to-number`,[`get`,`ucOobType`]],[T.CONTACTLINEEND,T.ONESTOP,T.STATIONBOUND,T.DOOR],!0,!1],layout:{"text-field":[`case`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.ONESTOP],`停`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.STATIONBOUND],`界`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.DOOR],`门`,``],"text-font":[`Open Sans Regular`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,20,18],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`}}]},E={ctc:ae,graph:ge,geom:ve,raster:ye,geojson:(e,t)=>{let n=[];return e.forEach((e,r)=>{let i=t[r],a=be[e];if(!a){console.warn(`GeoJSON 图层 ${e} 尚未实现`);return}let o=a(i);Array.isArray(o)?n.push(...o):n.push(o)}),n}};function xe(){if(!this.mapConfigs)return;let e=this.mapConfigs.id;this.mapConfigs.sourceLayers.forEach(t=>{(t.includes(`switch`)||t.includes(`signal`)||t.includes(`track`))&&this.map.querySourceFeatures(e,{sourceLayer:t}).forEach(e=>{this.initCTCFeatureState(e)})})}function Se(e){if(!e||e.length<11)return``;let t=e.charAt(10),n=e.charAt(9);return t===`1`&&n===`0`?`track`:t===`3`?`signal`:t===`2`&&n===`0`||t===`1`&&n===`1`?`switch`:t===`2`&&n===`1`?`circuit`:``}function Ce(e){if(!e)return;let t=e.properties.code,n=Se(t);if(n===`switch`){let t={state:``,select:!1,visiable:!0,subState1:``,subState2:``,subState3:``};t.state=`2`;let n=e.properties;this.updateFeatureState(n.code,t)}else if(n===`signal`){let t=e.properties,n=t.attach||0,r=t.func_type,i={state:``,select:!1,visiable:!0,subState1:`grey`,subState2:``,subState3:``};r==1&&n==0||(r==2||r==3)&&n==0||(r==2||r==3||r==11)&&n==1?(i.state=`red`,i.subState1=`blue`,this.updateFeatureState(t.code,i)):(r==4||r==5||r==12)&&n==0?(i.state=`blue`,i.subState1=`green`,this.updateFeatureState(t.code,i)):r==6&&n==0||(r==7||r==11)&&n==0?(i.state=`red`,i.subState1=`blue`,this.updateFeatureState(t.code,i)):(i.state=``,i.subState1=`grey`,this.updateFeatureState(t.code,i))}else if(n===`signal`||n===`circuit`){let t={state:``,select:!1,visiable:!0,subState1:``,subState2:``,subState3:``},n=e.properties;this.updateFeatureState(n.code,t)}}function we(e){e.initCTCFeatureState=Ce,e.initState=xe,e.map.once(`idle`,()=>{e&&e.map.moveLayer(`${e.mapConfigs.id}_${e.mapConfigs.sourceLayers[e.mapConfigs.layers.indexOf(`track`)]}_lock`)})}function Te(e,t){let n=this.map;if(n&&!n.getSource(e)){let r=w.graph(t);n.addSource(e,r)}}function Ee(e,t){let n=this.map;if(n&&!n.getSource(e)){let r=w.raster(t);n.addSource(e,r)}}function De(e,t){let n=this.map;if(!n){console.error(`地图实例未初始化`);return}try{if(n.getSource(e))console.warn(`源已存在,跳过添加: ${e}`);else{let r=t?w.geojson(t,promoteId):w.geojson(void 0,promoteId);n.addSource(e,r),console.log(`成功添加 GeoJSON 源: ${e}`)}}catch(t){console.error(` 添加源失败 [${e}]:`,t)}}function Oe(e){let t=this.map;if(t)if(t.getSource(e))try{(t.getStyle().layers||[]).filter(t=>{if(`source`in t)return t.source===e}).forEach(e=>{t.removeLayer(e.id),console.log(`移除关联图层: ${e.id}`)}),t.removeSource(e),console.log(`成功移除源: ${e}`)}catch(t){console.error(`移除源失败 [${e}]:`,t)}else console.warn(`源不存在,无法移除: ${e}`)}function ke(e,t){let n=this.map;if(!n)return;let r=n.getSource(e);r?(r.setData(t),console.log(`更新源数据: ${e}`)):this.addGeoJsonSource(e,t)}function Ae(e,t,n=`fill`,r,i){let a=this.map;if(!a)return;if(!a.getSource(t)){console.error(`无法添加图层: 源 '${t}' 不存在`);return}a.getLayer(e)&&a.removeLayer(e);let o={};n===`fill`&&(o[`fill-color`]=`#3b82f6`),n===`line`&&(o[`line-color`]=`#3b82f6`),n===`circle`&&(o[`circle-color`]=`#3b82f6`);let s={id:e,type:n,source:t,paint:{...o,...r},layout:i||{}};a.addLayer(s)}function je(e,t){let n=this.map;n&&(n.getLayer(e)?(Object.keys(t).forEach(r=>{n.setPaintProperty(e,r,t[r])}),console.log(`样式已更新: ${e}`)):console.warn(` 图层不存在,无法更新样式: ${e}`))}function Me(e){let t=this.map;t&&(t.getLayer(e)?(t.removeLayer(e),console.log(`图层已移除: ${e}`)):console.warn(` 图层不存在,无法删除: ${e}`))}function Ne(e,t){let n=this.map;if(!n)return;let r=Array.isArray(e)?e:[e];n.on(`click`,e=>{let i=n.queryRenderedFeatures(e.point,{layers:r});if(!i.length)return;let a=i[0];t(a,e.lngLat)}),n.on(`mouseenter`,r[r.length-1],()=>{n.getCanvas().style.cursor=`pointer`}),n.on(`mouseleave`,r[r.length-1],()=>{n.getCanvas().style.cursor=``})}function Pe(){this.stashFeatures.clear(),this.map&&(this.map.remove(),console.log(`地图实例已移除`))}function Fe(e){e.addGeoJsonSource=De,e.addVectorTileSource=Te,e.addRasterTileSource=Ee,e.updateGeoJsonSource=ke,e.removeSource=Oe,e.addGeoJsonLayer=Ae,e.updateLayerStyle=je,e.removeLayer=Me,e.onFeatureClick=Ne,e.destroy=Pe}var Ie=class{signalExist=!0;productInfo;stationCode;time;interlockInfo=new Map;getProductInfo(){return this.productInfo}getStCode(){return this.stationCode}getInterlockInfo(){return this.interlockInfo}isSignalExist(){return this.signalExist}setYardSignal(e){let t=e.split(`&`);this.time=t[0];let n=[],r=[],i=[];this.stationCode=t[1];let a=t[1],o=0;t.length===6&&(this.productInfo=t[2],o=1);let s=t[2],c=a+`:`+s;if(t[2+o]!==``){let e=t[2+o].split(`;`);for(let t of e){let e=t.split(`:`);n.push({name:e[0]+`:`+a,state:e[1]})}}if(t[3+o]!==``){let e=t[3+o].split(`;`);for(let t of e){let e=t.split(`:`);r.push({name:e[0]+`:`+a,state:e[1]})}}if(t[4+o]!==``){let e=t[4+o].split(`;`);for(let t of e){let e=t.split(`:`);i.push({name:e[0]+`:`+a,state:e[1]})}}this.interlockInfo.set(c,{signalInterlock:n,switchInterlock:r,circuitInterlock:i})}reset(){}resetInterlockInfo(){this.interlockInfo=new Map}},Le=class{insulationSignalMap=new Map;signalInsulationMap=new Map;setInsulation(e){this.insulationSignalMap.clear(),this.signalInsulationMap.clear(),e.length===0&&console.warn(`没有绝缘节数据!`),e.forEach(e=>{let t=String(e.id??e.properties?.code??``),n=e.properties?.upSignal??null,r=e.properties?.downSignal??null,i=e.properties?.name??``;this.insulationSignalMap.set(t,{upsignal:n,downsignal:r}),n!=null&&this.signalInsulationMap.set(String(n),t+`-`+i),r!=null&&this.signalInsulationMap.set(String(r),t+`-`+i)})}getInsulationBySignalKey(e){return this.signalInsulationMap.get(e)}getSignalByInsulationKey(e){return this.insulationSignalMap.get(e)}},Re=function(e){return e.RedLight=`red`,e.GreenLight=`green`,e.BlueLight=`blue`,e.WhiteLight=`white`,e}({}),ze={1:Re.RedLight,2:Re.GreenLight,3:Re.WhiteLight,4:Re.BlueLight},Be=class{map;layers;firstSwitches;updateFeatureState;signalStore=new Ie;interLockInsulation=new Le;interLockState={signal:new Map,switch:new Map,circuit:new Map};pathCircuits=[];pathCircuitsCodes=[];linkWhiteCircuits=[];constructor(e){if(this.map=e.map,this.firstSwitches=e.firstSwitches??[],this.updateFeatureState=e.updateFeatureState,`mode`in e&&e.mode===`geojson`){let t=e.sourceIds;this.layers={signal:{sourceId:t.signal},switch:{sourceId:t.switch},switch_loc:{sourceId:t.switch_loc},track_circuit:{sourceId:t.track_circuit},track:{sourceId:t.track},insulation:{sourceId:t.insulation}}}else{let t=e.sourceId,n=e.sourceLayers;this.layers={signal:{sourceId:t,sourceLayer:n.signal},switch:{sourceId:t,sourceLayer:n.switch},switch_loc:{sourceId:t,sourceLayer:n.switch_loc},track_circuit:{sourceId:t,sourceLayer:n.track_circuit},track:{sourceId:t,sourceLayer:n.track},insulation:{sourceId:t,sourceLayer:n.insulation}}}}queryFeatures(e){let t=this.layers[e];return this.map.querySourceFeatures(t.sourceId,t.sourceLayer?{sourceLayer:t.sourceLayer}:void 0)}setFeatureState(e,t,n){if(this.updateFeatureState)return this.updateFeatureState(t,n);let r=this.layers[e];this.map.setFeatureState(r.sourceLayer?{source:r.sourceId,sourceLayer:r.sourceLayer,id:t}:{source:r.sourceId,id:t},n)}getFeatureState(e,t){let n=this.layers[e];return this.map.getFeatureState(n.sourceLayer?{source:n.sourceId,sourceLayer:n.sourceLayer,id:t}:{source:n.sourceId,id:t})}initInsulation(){let e=this.queryFeatures(`insulation`);this.interLockInsulation.setInsulation(e)}handleSignalData(e){this.signalStore.resetInterlockInfo(),!e||e.length===0?this.signalStore.signalExist=!1:(this.signalStore.signalExist=!0,this.signalStore.setYardSignal(e)),this.signalStore.isSignalExist()&&this.signalStore.getInterlockInfo().forEach((e,t)=>{let n=t.split(`:`)[0],r=t.split(`:`)[1];this.arrToMap(this.interLockState.signal,e.signalInterlock),this.arrToMap(this.interLockState.switch,e.switchInterlock),this.arrToMap(this.interLockState.circuit,e.circuitInterlock),r===`ZK01`?this.visualizeZK(e,r,n):this.visualizeYD(e,r,n)})}turnOffSignals(){this.interLockState={signal:new Map,switch:new Map,circuit:new Map}}reset(e){this.clearCircuits(e),this.clearSwitchLocs(e)}clearCircuits(e){this.queryFeatures(`track_circuit`).forEach(t=>{t.properties?.stcode===e&&this.setFeatureState(`track_circuit`,t.properties.code,{state:``,visiable:!0})})}clearSwitchLocs(e){this.queryFeatures(`switch_loc`).forEach(t=>{t.properties?.stcode===e&&this.setFeatureState(`switch_loc`,t.properties.code,{state:``,visiable:!0})})}visualizeZK(e,t,n){this.reset(n);for(let t of e.signalInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getSignalFeature(e,n);r&&this.setFeatureState(`signal`,r.properties.code,{state:ze[t.state],visiable:!0})}for(let t of e.switchInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1];this.getSwitchLocFeatures(e,n,t.state).forEach(e=>{this.setFeatureState(`switch_loc`,e.properties.code,{state:t.state})})}for(let t of e.circuitInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getCircuitFeature(e,n);r&&this.setFeatureState(`track_circuit`,r.properties.code,{state:t.state,visiable:!0})}this.applyHandSwitchPaths(n,e.switchInterlock)}visualizeYD(e,t,n){this.reset(n);for(let t of e.signalInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getSignalFeature(e,n);r&&this.setFeatureState(`signal`,r.properties.code,{state:ze[t.state],visiable:!0})}for(let t of e.switchInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1];this.getSwitchLocFeatures(e,n,t.state).forEach(e=>{this.setFeatureState(`switch_loc`,e.properties.code,{state:t.state,visiable:!0})})}this.pathCircuits=[],this.pathCircuitsCodes=[],this.linkWhiteCircuits=[];for(let t of e.circuitInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getCircuitFeature(e,n);r&&(this.pathCircuits.push(r),this.pathCircuitsCodes.push(String(r.properties?.code??``)))}for(let t of e.circuitInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getCircuitFeature(e,n);if(!r){console.warn(`没有找到对应的区段YD`,t.name,t.state);continue}if(t.state===`1`)this.setFeatureState(`track_circuit`,r.properties.code,{state:t.state,controlName:``,visiable:!0});else{let e=String(r.properties?.fromCode??``),n=String(r.properties?.toCode??``);try{let i=this.getCircuitState([e,n],null);i?(this.setFeatureState(`track_circuit`,r.properties.code,{state:i.circuitState,controlName:i.controlName,link:i.controlName===``?void 0:0,visiable:!0}),i.controlName!==``&&this.linkWhiteCircuits.push(r)):this.setFeatureState(`track_circuit`,r.properties.code,{state:t.state,visiable:!0})}catch(e){if(e instanceof Error&&e.message!==`End Loop`)throw e}}}this.queryFeatures(`track_circuit`).forEach(e=>{let t=String(e.properties?.code??``),n=this.linkWhiteCircuits.find(e=>String(e.properties?.code??``)===t);if(n){let t=this.getFeatureState(`track_circuit`,e.id);t.state!==`2`&&t.state!==2&&t.state!==`1`&&t.state!==1&&this.setFeatureState(`track_circuit`,e.properties.code,{state:2,link:1,controlName:n.properties?.controlName??``,visiable:!0})}}),this.applyHandSwitchPaths(n,e.switchInterlock)}applyHandSwitchPaths(e,t){let n=[];for(let r of this.firstSwitches)this.findHandSwitchPath(r,e,t,n,[]);n.forEach(e=>{this.setFeatureState(`track`,e,{state:5,visiable:!0})})}findHandSwitchPath(e,t,n,r,i){let a=this.findSwitchInfo(e,t,n);if(!this.validSwitchInfo(a))return;let o=this.getSwitchLocFeatures(e,t,a.state);for(let a of o){let o=String(a.properties?.t_code??``),s=String(a.properties?.s_code??``),c=this.getTrackByCode(o);if(!c)continue;let l=String(c.properties?.fromCode??``),u=String(c.properties?.toCode??``),d=c.properties?.fromLyr,f=c.properties?.toLyr,p=``,m=null;if(l===s?(p=u,m=f):u===s&&(p=l,m=d),m===2){let a=this.getSwitchByCode(p);if(a){r.push(o);let s=String(a.properties?.name??``),c=this.findSwitchInfo(s,t,n);this.validSwitchInfo(c)&&!i.includes(s)&&this.doseTrackConnectSwitch(o,c)&&(i.push(e),this.findHandSwitchPath(s,t,n,r,i))}}else r.push(o)}}doseTrackConnectSwitch(e,t){let n=t.name.split(`:`)[0],r=t.name.split(`:`)[1];return this.getSwitchLocFeatures(n,r,t.state).some(t=>String(t.properties?.t_code??``)===e)}getCircuitState(e,t){let n=4,r=null;try{e.forEach((i,a)=>{let o=this.interLockInsulation.getSignalByInsulationKey(i),s=this.getInsulationSignalState(o??null);if(t==null&&s!=null&&(r=s),s==null&&t!=null&&(s={name:t.name,dir:t.dir,state:`3`}),s!=null&&s.state===`3`){n=2;let t=e.find(e=>e!==i),r=this.findNextCircuit(t,s);if(r!=null){let e=this.interLockInsulation.getSignalByInsulationKey(t);if(this.getControlSignalState(e??null,s)!=4){let e=String(r.properties?.fromCode??``),t=String(r.properties?.toCode??``),n={...r,properties:{...r.properties,controlName:s.name}};this.linkWhiteCircuits.push(n),this.getCircuitState([e,t],s)}}}})}catch(e){console.error(e)}return{circuitState:n,controlName:r==null?``:r.name}}findNextCircuit(e,t){let n=this.pathCircuits.find(n=>{let r=String(n.properties?.fromCode??``),i=String(n.properties?.toCode??``);return t.dir===`up`&&r===e||t.dir===`down`&&i===e});return n?this.linkWhiteCircuits.find(e=>String(e.properties?.code??``)===String(n.properties?.code??``))?null:n:null}getInsulationSignalState(e){if(!e)return null;if(e.upsignal){let t=this.getSignalById(String(e.upsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``),r=this.interLockState.signal.get(e+`:`+n);if(r===`3`)return{name:e,state:r,dir:`up`}}}if(e.downsignal){let t=this.getSignalById(String(e.downsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``),r=this.interLockState.signal.get(e+`:`+n);if(r===`3`)return{name:e,state:r,dir:`down`}}}return null}getControlSignalState(e,t){if(e){if(t.dir===`up`&&e.upsignal){let t=this.getSignalById(String(e.upsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``);return this.interLockState.signal.get(e+`:`+n)}}if(t.dir===`down`&&e.downsignal){let t=this.getSignalById(String(e.downsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``);return this.interLockState.signal.get(e+`:`+n)}}}}getSignalFeature(e,t){return this.queryFeatures(`signal`).find(n=>n.properties?.name===e&&String(n.properties?.code??``).includes(t))}getSignalById(e){return this.queryFeatures(`signal`).find(t=>String(t.id??t.properties?.code??``)===e)}getSwitchLocFeatures(e,t,n){let r=this.queryFeatures(`switch`).find(n=>n.properties?.name===e&&String(n.properties?.code??``).includes(t));if(!r)return[];let i=String(r.properties?.code??``),a=this.queryFeatures(`switch_loc`);return n===`4`?a.filter(e=>String(e.properties?.s_code??``)===i):a.filter(e=>String(e.properties?.s_code??``)===i&&(String(e.properties?.location??``)===n||String(e.properties?.location??``)===`1`))}getSwitchByCode(e){return this.queryFeatures(`switch`).find(t=>String(t.id??t.properties?.code??``)===e)}getTrackByCode(e){return this.queryFeatures(`track`).find(t=>String(t.id??t.properties?.code??``)===e)}getCircuitFeature(e,t){let n=this.queryFeatures(`track_circuit`).filter(n=>n.properties?.name===e&&String(n.properties?.code??``).includes(t));if(n.length===0)return;let r;if(n.length>=1&&(n[0].properties?.type===`1`||n[0].properties?.type===1))return n[0];for(let e of n){if(r)break;if(e.properties?.type===2||e.properties?.type===`2`){let t=String(e.properties?.switches??``).split(`,`),n=String(e.properties?.positions??``).replace(/\s+/g,``).split(`,`).filter(e=>e!==`1`);for(let i=0;i<t.length;i++){let a=t[i],o=n[i],s=this.getSwitchNameByCode(a);if(!s||o!==this.interLockState.switch.get(s+`:`+a.substring(0,9)))break;if(i==t.length-1){r=e;break}}}}return r}getSwitchNameByCode(e){let t=this.queryFeatures(`switch`).find(t=>String(t.properties?.code??``)===e);return t?String(t.properties?.name??``):void 0}findSwitchInfo(e,t,n){let r=e+`:`+t;return n.find(e=>e.name===r)??null}validSwitchInfo(e){return e?e.state===`2`||e.state===`3`:!1}arrToMap(e,t){t?.forEach(t=>e.set(t.name,t.state))}};function Ve(){if(!this.mapConfigs)return;let e=this.mapConfigs.id;this.mapConfigs.sourceLayers?.forEach(t=>{(t.includes(`switch`)||t.includes(`signal`)||t.includes(`track`))&&this.map.querySourceFeatures(e,{sourceLayer:t}).forEach(e=>{this.initGraphFeatureState(e)})})}function He(e){if(!e||e.length<11)return``;let t=e.charAt(10),n=e.charAt(9);return t===`1`&&n===`0`?`track`:t===`3`?`signal`:t===`2`&&n===`0`||t===`1`&&n===`1`?`switch`:t===`2`&&n===`1`?`circuit`:``}function Ue(e){if(!e)return;let t=e.properties.code,n=He(t);if(n===`switch`){let t={state:``,visiable:!0};t.state=`2`;let n=e.properties;this.updateFeatureState(n.code,t)}else if(n===`signal`){let t=e.properties,n=t.attach||0,r=t.func_type,i={state:``,visiable:!0};r==1&&n==0||(r==2||r==3)&&n==0||(r==2||r==3||r==11)&&n==1?(i.state=`red`,this.updateFeatureState(t.code,i)):(r==4||r==5||r==12)&&n==0?(i.state=`blue`,this.updateFeatureState(t.code,i)):r==6&&n==0||(r==7||r==11)&&n==0?(i.state=`red`,this.updateFeatureState(t.code,i)):(i.state=``,this.updateFeatureState(t.code,i))}else if(n===`signal`||n===`circuit`){let t={state:``,visiable:!0},n=e.properties;this.updateFeatureState(n.code,t)}}function We(e){if(!e.mapConfigs)return;let t=e.mapConfigs.id,n=e.mapConfigs.layers?.reduce((t,n,r)=>(t[n]=e.mapConfigs.sourceLayers[r],t),{});if(n)return new Be({map:e.map,sourceId:t,sourceLayers:n,updateFeatureState:(t,n)=>e.updateFeatureState(t,n)})}function Ge(e){e.initGraphFeatureState=Ue,e.initState=Ve,e.interLockVisualization=We(e),e.map.once(`idle`,()=>{})}function Ke(){this.mapConfigs&&(this.mapConfigs.layers??[]).forEach(e=>{let t=`geojson_${e}`;this.map.getSource(t)&&this.stashFeatures.forEach(n=>{n.sourceLayer!==t||!n.properties||this.initGeoJsonFeatureState({properties:n.properties},e)})})}function qe(e,t){if(!e)return;let n=e.properties,r=n?.code;if(r)if(t===`switch`||t===`switch_loc`)this.updateFeatureState(r,{state:`2`,visiable:!0});else if(t===`signal`){let e=n?.attach||0,t=n?.functionType,i={state:``,visiable:!0};t==1&&e==0||(t==2||t==3)&&e==0||(t==2||t==3||t==11)&&e==1||t==6&&e==0||(t==7||t==11)&&e==0?i.state=`red`:(t==4||t==5||t==12)&&e==0&&(i.state=`blue`),this.updateFeatureState(r,i)}else t===`track_circuit`&&this.updateFeatureState(r,{state:3,substate:1,visiable:!0})}function Je(e){if(!e.mapConfigs)return;let t=[`signal`,`switch`,`switch_loc`,`track_circuit`,`track`,`insulation`].reduce((e,t)=>(e[t]=`geojson_${t}`,e),{});return new Be({mode:`geojson`,map:e.map,sourceIds:t,updateFeatureState:(t,n)=>e.updateFeatureState(t,n)})}function Ye(e){e.initGeoJsonFeatureState=qe,e.initGeoJsonState=Ke,e.interLockVisualization=Je(e),e.map.once(`idle`,()=>{})}function D(){return D=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},D.apply(null,arguments)}var O=`draw`,Xe=`edit`,Ze=`deleteCoordinate`,Qe=`insertMidpoint`,k;(function(e){e.Commit=`commit`,e.Provisional=`provisional`,e.Finish=`finish`})(k||={});var $e=`https://raw.githubusercontent.com/JamesLMilner/terra-draw/refs/heads/main/assets/markers/marker-blue.png`,A={SELECTED:`selected`,MID_POINT:`midPoint`,SELECTION_POINT_FEATURE_ID:`selectionPointFeatureId`,SELECTION_POINT:`selectionPoint`},j={MODE:`mode`,CURRENTLY_DRAWING:`currentlyDrawing`,EDITED:`edited`,CLOSING_POINT:`closingPoint`,SNAPPING_POINT:`snappingPoint`,COORDINATE_POINT:`coordinatePoint`,COORDINATE_POINT_FEATURE_ID:`coordinatePointFeatureId`,COORDINATE_POINT_IDS:`coordinatePointIds`,PROVISIONAL_COORDINATE_COUNT:`provisionalCoordinateCount`,COMMITTED_COORDINATE_COUNT:`committedCoordinateCount`,MARKER:`marker`},M=10;function et(e){return!!(e&&typeof e==`object`&&e&&!Array.isArray(e))}function tt(e){return!!(e&&typeof e==`object`&&`properties`in e&&typeof e.properties==`object`&&e.properties!==null&&`mode`in e.properties)}function nt(e){return!!function(e){return typeof e==`number`&&!isNaN(new Date(e).valueOf())}(e)}var rt=`Feature mode property does not match the mode being added to`,it;(function(e){e.Drawing=`drawing`,e.Select=`select`,e.Static=`static`,e.Render=`render`})(it||={});var at={rightClick:!0,contextMenu:!1,leftClick:!0,onDragStart:!0,onDrag:!0,onDragEnd:!0},N=class{get state(){return this._state}set state(e){throw Error(`Please use the modes lifecycle methods`)}get styles(){return this._styles}set styles(e){if(typeof e!=`object`)throw Error(`Styling must be an object`);this.onStyleChange&&this.onStyleChange([],`styling`),this._styles=e}registerBehaviors(e){}constructor(e,t=!1){this._state=`unregistered`,this._styles={},this.pointerEvents=at,this.behaviors=[],this.validate=void 0,this.pointerDistance=40,this.coordinatePrecision=void 0,this.undoRedoMaxStackSize=void 0,this.onStyleChange=void 0,this.store=void 0,this.projection=`web-mercator`,this.setDoubleClickToZoom=void 0,this.unproject=void 0,this.project=void 0,this.setCursor=void 0,this.isInitialUpdate=!1,this.type=it.Drawing,this.mode=`base`,t?this.isInitialUpdate=!0:this.updateOptions(D({},e))}updateOptions(e){e!=null&&e.styles&&(this.styles=D({},this._styles,e.styles)),e!=null&&e.pointerDistance&&(this.pointerDistance=e.pointerDistance),e!=null&&e.validation&&(this.validate=e&&e.validation),e!=null&&e.projection&&(this.projection=e.projection),e?.pointerEvents!==void 0&&(this.pointerEvents=e.pointerEvents),e!=null&&e.modeName&&!0===this.isInitialUpdate&&(this.mode=e.modeName),this.isInitialUpdate=!1}allowPointerEvent(e,t){return typeof e==`boolean`?e:typeof e!=`function`||e(t)}setDrawing(){if(this._state!==`started`)throw Error(`Mode must be unregistered or stopped to start`);this._state=`drawing`}setStarted(){if(this._state!==`stopped`&&this._state!==`registered`&&this._state!==`drawing`&&this._state!==`selecting`)throw Error(`Mode must be unregistered or stopped to start`);this._state=`started`,this.setDoubleClickToZoom(!1)}setStopped(){if(this._state!==`started`)throw Error(`Mode must be started to be stopped`);this._state=`stopped`,this.setDoubleClickToZoom(!0)}register(e){if(this._state!==`unregistered`)throw Error(`Can not register unless mode is unregistered`);this._state=`registered`,this.store=e.store,this.store.registerOnChange(e.onChange),this.setDoubleClickToZoom=e.setDoubleClickToZoom,this.project=e.project,this.unproject=e.unproject,this.onSelect=e.onSelect,this.onDeselect=e.onDeselect,this.setCursor=e.setCursor,this.onStyleChange=e.onChange,this.onFinish=e.onFinish,this.coordinatePrecision=e.coordinatePrecision,this.undoRedoMaxStackSize=e.undoRedoMaxStackSize,this.registerBehaviors({mode:e.mode,store:this.store,project:this.project,unproject:this.unproject,pointerDistance:this.pointerDistance,coordinatePrecision:e.coordinatePrecision,projection:this.projection,undoRedoMaxStackSize:e.undoRedoMaxStackSize})}validateFeature(e){return this.performFeatureValidation(e)}afterFeatureAdded(e){}afterFeatureUpdated(e){}performFeatureValidation(e){if(this._state===`unregistered`)throw Error(`Mode must be registered`);let t=function(e,t){let n;if(et(e))if(e.id==null)n=`Feature has no id`;else if(typeof e.id!=`string`&&typeof e.id!=`number`)n=`Feature must be string or number as per GeoJSON spec`;else if(t(e.id))if(et(e.geometry))if(et(e.properties))if(typeof e.geometry.type==`string`&&[`Polygon`,`LineString`,`Point`].includes(e.geometry.type))if(Array.isArray(e.geometry.coordinates)){if(!e.properties.mode||typeof e.properties.mode!=`string`)return{valid:!1,reason:`Feature does not have a valid mode property`}}else n=`Feature coordinates is not an array`;else n=`Feature is not Point, LineString or Polygon`;else n=`Feature has no properties`;else n=`Feature has no geometry`;else n=`Feature must match the id strategy (default is UUID4)`;else n=`Feature is not object`;return n?{valid:!1,reason:n}:{valid:!0}}(e,this.store.idStrategy.isValidId);if(!t.valid)return t;if(this.validate){let n=this.validate(e,{project:this.project,unproject:this.unproject,coordinatePrecision:this.coordinatePrecision,updateType:k.Provisional});return{valid:t.valid&&n.valid,reason:n.reason}}return{valid:t.valid,reason:t.reason}}validateModeFeature(e,t){let n=this.performFeatureValidation(e);return n.valid?e.properties.mode===this.mode?t(e):{valid:!1,reason:rt}:{valid:!1,reason:n.reason}}onFinish(e,t){}onDeselect(e){}onSelect(e){}onKeyDown(e){}onKeyUp(e){}undo(){}clearHistory(){}undoSize(){return 0}redoSize(){return 0}redo(){}onMouseMove(e){}onClick(e){}onDragStart(e,t){}onDrag(e,t){}onDragEnd(e,t){}getHexColorStylingValue(e,t,n){return this.getStylingValue(e,t,n)}getNumericStylingValue(e,t,n){return this.getStylingValue(e,t,n)}getUrlStylingValue(e,t,n){return this.getStylingValue(e,t,n)}getStylingValue(e,t,n){return e===void 0?t:typeof e==`function`?(r=e(n))??t:e;var r}},ot=class extends N{constructor(...e){super(...e),this.type=it.Select}};function P(e,t){let n=e=>e*Math.PI/180,r=n(e[1]),i=n(e[0]),a=n(t[1]),o=a-r,s=n(t[0])-i,c=Math.sin(o/2)*Math.sin(o/2)+Math.cos(r)*Math.cos(a)*Math.sin(s/2)*Math.sin(s/2);return 2*Math.atan2(Math.sqrt(c),Math.sqrt(1-c))*6371e3/1e3}var st=6371008.8;function F(e){return e%360*Math.PI/180}function ct(e){return e/6371.0088}function lt(e){return e%(2*Math.PI)*180/Math.PI}function I(e,t=9){let n=10**t;return Math.round(e*n)/n}var ut=57.29577951308232,dt=.017453292519943295,ft=6378137,L=(e,t)=>({x:e===0?0:e*dt*ft,y:t===0?0:Math.log(Math.tan(Math.PI/4+t*dt/2))*ft}),R=(e,t)=>({lng:e===0?0:e/ft*ut,lat:t===0?0:(2*Math.atan(Math.exp(t/ft))-Math.PI/2)*ut});function pt(e,t,n){let r=F(e[0]),i=F(e[1]),a=F(n),o=ct(t),s=Math.asin(Math.sin(i)*Math.cos(o)+Math.cos(i)*Math.sin(o)*Math.cos(a));return[lt(r+Math.atan2(Math.sin(a)*Math.sin(o)*Math.cos(i),Math.cos(o)-Math.sin(i)*Math.sin(s))),lt(s)]}function mt(e){let{center:t,radiusKilometers:n,coordinatePrecision:r}=e,i=e.steps?e.steps:64,a=[];for(let e=0;e<i;e++){let o=pt(t,n,-360*e/i);a.push([I(o[0],r),I(o[1],r)])}return a.push(a[0]),{type:`Feature`,geometry:{type:`Polygon`,coordinates:[a]},properties:{}}}function ht(e){let t;if(e.geometry.type===`Polygon`)t=e.geometry.coordinates;else{if(e.geometry.type!==`LineString`)throw Error(`Self intersects only accepts Polygons and LineStrings`);t=[e.geometry.coordinates]}let n=[];for(let e=0;e<t.length;e++)for(let n=0;n<t[e].length-1;n++)for(let r=0;r<t.length;r++)for(let a=0;a<t[r].length-1;a++)i(e,n,r,a);return n.length>0;function r(e){return e<0||e>1}function i(e,i,a,o){let s=t[e][i],c=t[e][i+1],l=t[a][o],u=t[a][o+1],d=function(e,t,n,r){if(gt(e,n)||gt(e,r)||gt(t,n)||gt(r,n))return null;let i=e[0],a=e[1],o=t[0],s=t[1],c=n[0],l=n[1],u=r[0],d=r[1],f=(i-o)*(l-d)-(a-s)*(c-u);return f===0?null:[((i*s-a*o)*(c-u)-(i-o)*(c*d-l*u))/f,((i*s-a*o)*(l-d)-(a-s)*(c*d-l*u))/f]}(s,c,l,u);if(d===null)return;let f,p;f=c[0]===s[0]?(d[1]-s[1])/(c[1]-s[1]):(d[0]-s[0])/(c[0]-s[0]),p=u[0]===l[0]?(d[1]-l[1])/(u[1]-l[1]):(d[0]-l[0])/(u[0]-l[0]),r(f)||r(p)||(d.toString(),n.push(d))}}function gt(e,t){return e[0]===t[0]&&e[1]===t[1]}function _t(e,t){return yt(e[0])<=t&&yt(e[1])<=t}function vt(e){return e.length===2&&typeof e[0]==`number`&&typeof e[1]==`number`&&e[0]!==1/0&&e[1]!==1/0&&(n=e[0])>=-180&&n<=180&&(t=e[1])>=-90&&t<=90;var t,n}function yt(e){let t=1,n=0;for(;Math.round(e*t)/t!==e;)t*=10,n++;return n}var bt=`Feature has holes`,xt=`Feature has less than 4 coordinates`,St=`Feature has invalid coordinates`,Ct=`Feature coordinates are not closed`;function wt(e,t){if(e.geometry.type!==`Polygon`)return{valid:!1,reason:`Feature is not a Polygon`};if(e.geometry.coordinates.length!==1)return{valid:!1,reason:bt};if(e.geometry.coordinates[0].length<4)return{valid:!1,reason:xt};for(let n=0;n<e.geometry.coordinates[0].length;n++){if(!vt(e.geometry.coordinates[0][n]))return{valid:!1,reason:St};if(!_t(e.geometry.coordinates[0][n],t))return{valid:!1,reason:`Feature has coordinates with excessive precision`}}return(n=e.geometry.coordinates[0][0])[0]!==(r=e.geometry.coordinates[0][e.geometry.coordinates[0].length-1])[0]||n[1]!==r[1]?{valid:!1,reason:Ct}:{valid:!0};var n,r}function Tt(e,t){let n=wt(e,t);return n.valid?ht(e)?{valid:!1,reason:`Feature intersects itself`}:{valid:!0}:n}var z=class{constructor({store:e,mode:t,project:n,unproject:r,pointerDistance:i,coordinatePrecision:a,projection:o,undoRedoMaxStackSize:s}){this.store=void 0,this.mode=void 0,this.project=void 0,this.unproject=void 0,this.pointerDistance=void 0,this.coordinatePrecision=void 0,this.projection=void 0,this.undoRedoMaxStackSize=void 0,this.store=e,this.mode=t,this.project=n,this.unproject=r,this.pointerDistance=i,this.coordinatePrecision=a,this.projection=o,this.undoRedoMaxStackSize=s}};function Et(e){if(!function(e){let t=e.coordinates[0],n=0;for(let e=0;e<t.length-1;e++){let[r,i]=t[e],[a,o]=t[e+1];n+=(a-r)*(o+i)}return n<0}(e))return{type:`Polygon`,coordinates:[e.coordinates[0].reverse()]}}var Dt=`insert-before`,B=`insert-after`,V=`update`,Ot=`delete`,H=`replace`,U=class extends z{constructor(e,t){super(e),this.options=void 0,this.options=t}createPoint({coordinates:e,properties:t,context:n}){if(n?.updateType!==k.Finish||this.validateGeometryWithUpdateType({geometry:{type:`Point`,coordinates:e},properties:t,updateType:k.Finish}))return this.handleCreateFeature({geometry:{type:`Point`,coordinates:e},properties:t})}createLineString({coordinates:e,properties:t}){return this.handleCreateFeature({geometry:{type:`LineString`,coordinates:e},properties:t})}createPolygon({coordinates:e,properties:t}){let n=Et({type:`Polygon`,coordinates:[e]});return this.handleCreateFeature({geometry:{type:`Polygon`,coordinates:n?n.coordinates:[e]},properties:t})}createGuidancePoint({coordinate:e,type:t}){return this.createGuidancePoints({coordinates:[e],type:t})[0]}createGuidancePoints({coordinates:e,type:t,additionalProperties:n}){let r=e.map((e,r)=>({type:`Feature`,geometry:{type:`Point`,coordinates:e},properties:D({mode:this.mode,[t]:!0},n?n(r):{})}));return this.createFeatures(r)}updatePoint({featureId:e,coordinateMutations:t,propertyMutations:n,context:r}){return this.handleMutateFeature({type:`Point`,featureId:e,coordinateMutations:t,propertyMutations:n,context:r})}updatePolygon({featureId:e,coordinateMutations:t,context:n,propertyMutations:r}){return this.handleMutateFeature({type:`Polygon`,featureId:e,coordinateMutations:t,propertyMutations:r,context:n})}updateLineString({featureId:e,coordinateMutations:t,context:n,propertyMutations:r}){return this.handleMutateFeature({type:`LineString`,featureId:e,coordinateMutations:t,propertyMutations:r,context:n})}deleteFeatureIfPresent(e){e&&this.store.has(e)&&this.store.delete([e])}deleteFeaturesIfPresent(e){if(e.length===0)return;let t=e.filter(e=>this.store.has(e));t.length&&this.store.delete(t)}setDeselected(e){let t=e.filter(e=>this.store.has(e)).map(e=>({featureId:e,properties:{[A.SELECTED]:!1}}));this.updateFeatureProperties(t)}setSelected(e){let{type:t}=this.store.getGeometryCopy(e),n={featureId:e,propertyMutations:{[A.SELECTED]:!0},context:{updateType:k.Commit}};t===`Polygon`?this.updatePolygon(n):t===`LineString`?this.updateLineString(n):t===`Point`&&this.updatePoint(n)}updateGuidancePoints(e){this.updateFeatureGeometries(e.map(({featureId:e,coordinate:t})=>({id:e,geometry:{type:`Point`,coordinates:t}})))}handleCreateFeature({geometry:e,properties:t}){return this.createFeatureWithGeometry({geometry:e,properties:t})}handleMutateFeature({type:e,featureId:t,coordinateMutations:n,propertyMutations:r,context:i}){if(!this.mutateFeature({type:e,featureId:t,coordinateMutations:n,propertyMutations:r,context:i.updateType===k.Finish?D({},i,{correctRightHandRule:!0}):D({},i)}))return null;let a=this.buildFeatureWithGeometry(t);return i.updateType!==k.Finish||n||this.validateGeometryWithUpdateType({geometry:a.geometry,properties:a.properties,updateType:i.updateType})?a:null}mutateFeature({type:e,featureId:t,coordinateMutations:n,propertyMutations:r,context:i}){if(!t)return!1;let a=this.store.getGeometryCopy(t),o=this.store.getPropertiesCopy(t);if(a.type!==e)throw Error(`${e} geometries cannot be updated on features with ${a.type} geometries`);if(n){let e=this.applyCoordinateMutations(a,n);if(i.correctRightHandRule&&e.type===`Polygon`){let t=Et(e);t&&(e=t)}if(!this.validateGeometryWithUpdateType({geometry:e,properties:o,updateType:i.updateType}))return!1;this.updateFeatureGeometries([{id:t,geometry:e}])}return r&&this.updateFeatureProperties([{featureId:t,properties:r}]),!0}applyCoordinateMutations(e,t){if(this.isReplaceMutation(t))return D({},e,{coordinates:t.coordinates});if(e.type===`Point`)throw Error(`Coordinate mutations are not supported for Point geometries`);let n=e.type===`Polygon`,r=n?e.coordinates[0].slice():e.coordinates.slice(),i=r.length,a=e=>{let t=e<0?i+e:e;if(t<0||t>=i)throw RangeError(`Index ${e} (normalized to ${t}) is out of bounds`);return t},o=Array(i).fill(void 0),s=Array.from({length:i},()=>[]),c=Array.from({length:i},()=>[]),l=[];for(let e of t){if(e.type===Dt||e.type===B){let t=e.index,n=t<0?i+t:t;if(n<0||n>i)throw RangeError(`Index ${e.index} (normalized to ${n}) is out of bounds`);if(e.type===Dt){if(n>=i)throw RangeError(`INSERT_BEFORE index ${e.index} (normalized to ${n}) is out of bounds for length ${i}`);s[n].push(e)}else n===i?l.push(e):c[n].push(e);continue}let t=a(e.index);o[t]=D({},e,{index:t})}let u=[];for(let e=0;e<i;e++){let t=s[e];for(let e of t)u.push(e.coordinate);let n=o[e];n?n.type===Ot||u.push(n.coordinate):u.push(r[e]);let i=c[e];for(let e of i)u.push(e.coordinate)}for(let e of l)u.push(e.coordinate);return D({},e,n?{coordinates:[u,...e.coordinates.slice(1)]}:{coordinates:u})}isReplaceMutation(e){return e.type===H}createFeatureWithGeometry({geometry:e,properties:t}){let[n]=this.createFeatures([{type:`Feature`,geometry:e,properties:t}]);return{id:n,type:`Feature`,properties:this.store.getPropertiesCopy(n),geometry:this.store.getGeometryCopy(n)}}validateGeometryWithUpdateType({geometry:e,properties:t,updateType:n}){return!this.options.validate||this.options.validate({type:`Feature`,geometry:e,properties:t||{}},{project:this.project,unproject:this.unproject,coordinatePrecision:this.coordinatePrecision,updateType:n}).valid}buildFeatureWithGeometry(e){return{id:e,type:`Feature`,properties:this.store.getPropertiesCopy(e),geometry:this.store.getGeometryCopy(e)}}createFeatures(e){return this.store.create(e)}updateFeatureGeometries(e){this.store.updateGeometry(e)}updateFeatureProperties(e){let t=e.map(({featureId:e,properties:t})=>Object.entries(t).map(([t,n])=>({id:e,property:t,value:n}))).flat();this.store.updateProperty(t)}},kt={cancel:`Escape`,finish:`Enter`},At={start:`crosshair`},jt=class extends N{constructor(e){super(e,!0),this.mode=`circle`,this.center=void 0,this.endPosition=void 0,this.segments=64,this.currentCircleId=void 0,this.keyEvents=kt,this.cursors=At,this.startingRadiusKilometers=1e-5,this.cursorMovedAfterInitialCursorDown=!1,this.drawInteraction=`click-move`,this.drawType=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.startingRadiusKilometers&&(this.startingRadiusKilometers=e.startingRadiusKilometers),e!=null&&e.drawInteraction&&(this.drawInteraction=e.drawInteraction),e!=null&&e.segments&&(this.segments=e.segments<3?3:e.segments)}close(){if(this.currentCircleId===void 0||this.endPosition===void 0||!this.updateCircle(this.endPosition,k.Finish))return;let e=this.currentCircleId;this.cursorMovedAfterInitialCursorDown=!1,this.center=void 0,this.currentCircleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}beginDrawing(e,t=`click`){this.center=[e.lng,e.lat],this.endPosition=[e.lng,e.lat];let n=mt({center:this.center,radiusKilometers:this.startingRadiusKilometers,coordinatePrecision:this.coordinatePrecision}),r=this.mutateFeature.createPolygon({coordinates:n.geometry.coordinates[0],properties:{mode:this.mode,radiusKilometers:this.startingRadiusKilometers,[j.CURRENTLY_DRAWING]:!0}});r&&(this.currentCircleId=r.id,this.cursorMovedAfterInitialCursorDown=!1,this.drawType=t,this.setDrawing())}dragDrawAllowed(){return this.drawInteraction===`click-drag`||this.drawInteraction===`click-move-or-drag`}moveDrawAllowed(){return this.drawInteraction===`click-move`||this.drawInteraction===`click-move-or-drag`}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){this.moveDrawAllowed()&&(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))&&(this.center?this.center&&this.currentCircleId!==void 0&&(this.endPosition=[e.lng,e.lat],this.close()):this.beginDrawing(e))}onMouseMove(e){this.cursorMovedAfterInitialCursorDown=!0,this.endPosition=[e.lng,e.lat],this.updateCircle(this.endPosition,k.Provisional)}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onDragStart(e,t){this.state!==`drawing`&&this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&this.dragDrawAllowed()&&(this.beginDrawing(e,`drag`),t(!1))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.cursorMovedAfterInitialCursorDown=!0,this.endPosition=[e.lng,e.lat],this.updateCircle(this.endPosition,k.Provisional))}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.endPosition=[e.lng,e.lat],this.close(),t(!0))}cleanUp(){let e=this.currentCircleId;this.center=void 0,this.currentCircleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Polygon`&&e.properties.mode===this.mode?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t):t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}updateCircle(e,t){if(this.currentCircleId===void 0||this.center===void 0)return;let n=t===k.Finish,r,i;if(this.cursorMovedAfterInitialCursorDown)if(i=P(this.center,e),this.projection===`web-mercator`){let t=function(e,t){let n=1e3*P(e,t);if(n===0)return 1;let{x:r,y:i}=L(e[0],e[1]),{x:a,y:o}=L(t[0],t[1]);return Math.sqrt((a-r)**2+(o-i)**2)/n}(this.center,e);r=function(e){let{center:t,radiusKilometers:n,coordinatePrecision:r}=e,i=e.steps?e.steps:64,a=1e3*n,[o,s]=t,{x:c,y:l}=L(o,s),u=[];for(let e=0;e<i;e++){let t=360*e/i*Math.PI/180,n=a*Math.cos(t),o=a*Math.sin(t),[s,d]=[c+n,l+o],{lng:f,lat:p}=R(s,d);u.push([I(f,r),I(p,r)])}return u.push(u[0]),{type:`Feature`,geometry:{type:`Polygon`,coordinates:[u]},properties:{}}}({center:this.center,radiusKilometers:i*t,coordinatePrecision:this.coordinatePrecision,steps:this.segments})}else{if(this.projection!==`globe`)throw Error(`Invalid projection`);r=mt({center:this.center,radiusKilometers:i,coordinatePrecision:this.coordinatePrecision,steps:this.segments})}let a={};return r&&i&&(a.radiusKilometers=i),n&&(a[j.CURRENTLY_DRAWING]=void 0),this.mutateFeature.updatePolygon({featureId:this.currentCircleId,coordinateMutations:r?{type:H,coordinates:r.geometry.coordinates}:void 0,propertyMutations:a,context:n?{updateType:t,action:O}:{updateType:t}})}afterFeatureUpdated(e){this.currentCircleId===e.id&&(this.cursorMovedAfterInitialCursorDown=!1,this.center=void 0,this.currentCircleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.mutateFeature=new U(e,{validate:this.validate})}},W=(e,t)=>{let{x:n,y:r}=e,{x:i,y:a}=t,o=i-n,s=a-r;return Math.sqrt(s*s+o*o)};function Mt(e,t){return e[0]===t[0]&&e[1]===t[1]}var G=class extends z{constructor(e){super(e)}getGeometryType(e){return this.store.getGeometryCopy(e).type}coordinateAtIndexIsIdentical({featureId:e,newCoordinate:t,index:n}){let r=this.store.getGeometryCopy(e),i;if(r.type===`Polygon`)i=r.coordinates[0][n];else if(r.type===`LineString`)i=r.coordinates[n];else{if(n!==0)throw Error(`Point geometries only have one coordinate at index 0`);i=r.coordinates}return Mt(t,i)}getGeometry(e){return this.store.getGeometryCopy(e)}getCoordinates(e){let{type:t,coordinates:n}=this.store.getGeometryCopy(e);return t===`Polygon`?n[0]:n}getCoordinate(e,t){let n=this.getCoordinates(e),r=t<0?n.length+t:t;if(r<0||r>=n.length)throw RangeError(`Index ${t} (normalized to ${r}) is out of bounds`);return n[r]}getProperties(e){return this.store.getPropertiesCopy(e)}hasFeature(e){return this.store.has(e)}getAllFeatureIdsWhere(e){return this.store.copyAllWhere(e).map(({id:e})=>e)}},Nt={cancel:`Escape`,finish:`Enter`},Pt={start:`crosshair`,close:`pointer`},Ft=class extends N{constructor(e){super(e,!0),this.mode=`freehand`,this.canClose=!1,this.currentId=void 0,this.closingPointId=void 0,this.minDistance=20,this.keyEvents=Nt,this.cursors=Pt,this.preventPointsNearClose=!0,this.autoClose=!1,this.autoCloseTimeout=500,this.hasLeftStartingPoint=!1,this.preventNewFeature=!1,this.drawInteraction=`click-move`,this.drawType=void 0,this.smoothing=0,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.minDistance&&(this.minDistance=e.minDistance),e?.smoothing!==void 0&&(this.smoothing=Math.min(Math.max(e.smoothing,0),.999)),e?.preventPointsNearClose!==void 0&&(this.preventPointsNearClose=e.preventPointsNearClose),e?.autoClose!==void 0&&(this.autoClose=e.autoClose),e!=null&&e.autoCloseTimeout&&(this.autoCloseTimeout=e.autoCloseTimeout),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.drawInteraction&&(this.drawInteraction=e.drawInteraction)}moveDrawAllowed(){return this.drawInteraction===`click-move`||this.drawInteraction===`click-move-or-drag`}dragDrawAllowed(){return this.drawInteraction===`click-drag`||this.drawInteraction===`click-move-or-drag`}beginDrawing(e,t=`click`){let{id:n}=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.currentId=n,this.drawType=t,this.closingPointId=this.mutateFeature.createGuidancePoint({coordinate:[e.lng,e.lat],type:j.CLOSING_POINT}),this.canClose=!0,this.state!==`drawing`&&this.setDrawing()}addCoordinate(e){if(this.currentId===void 0||!1===this.canClose)return void this.setCursor(this.cursors.start);let[t,n]=this.readFeature.getCoordinate(this.currentId,-2),{x:r,y:i}=this.project(t,n),a=W({x:r,y:i},{x:e.containerX,y:e.containerY}),[o,s]=this.readFeature.getCoordinate(this.currentId,0),{x:c,y:l}=this.project(o,s);if(W({x:c,y:l},{x:e.containerX,y:e.containerY})<this.pointerDistance){if(this.autoClose&&this.hasLeftStartingPoint&&(this.preventNewFeature=!0,setTimeout(()=>{this.preventNewFeature=!1},this.autoCloseTimeout),this.close()),this.setCursor(this.cursors.close),this.preventPointsNearClose)return}else this.hasLeftStartingPoint=!0,this.setCursor(this.cursors.start);if(a<this.minDistance)return;let u=this.getSmoothedCoordinate([t,n],[e.lng,e.lat]);this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:Dt,index:-1,coordinate:u}],context:{updateType:k.Provisional}})}getSmoothedCoordinate(e,t){if(this.smoothing===0)return t;let[n,r]=e,[i,a]=t;return[n*this.smoothing+i*(1-this.smoothing),r*this.smoothing+a*(1-this.smoothing)]}close(){if(this.currentId===void 0||!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.mutateFeature.deleteFeatureIfPresent(this.closingPointId),this.canClose=!1,this.currentId=void 0,this.closingPointId=void 0,this.hasLeftStartingPoint=!1,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){this.moveDrawAllowed()&&this.drawType===`click`&&this.addCoordinate(e)}onClick(e){if(this.moveDrawAllowed()&&(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))){if(this.preventNewFeature)return;if(!1===this.canClose)return void this.beginDrawing(e);this.close()}}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&!0===this.canClose&&this.close()}onDragStart(e,t){this.state!==`drawing`&&(this.preventNewFeature||this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&this.dragDrawAllowed()&&(this.beginDrawing(e,`drag`),t(!1)))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&this.addCoordinate(e)}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.preventNewFeature=!0,setTimeout(()=>{this.preventNewFeature=!1},this.autoCloseTimeout),this.close(),t(!0))}cleanUp(){let e=this.currentId,t=this.closingPointId;this.closingPointId=void 0,this.currentId=void 0,this.canClose=!1,this.hasLeftStartingPoint=!1,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(t)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Polygon`&&e.properties.mode===this.mode?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t):e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode?(t.pointWidth=this.getNumericStylingValue(this.styles.closingPointWidth,t.pointWidth,e),t.pointColor=this.getHexColorStylingValue(this.styles.closingPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.closingPointOpacity,t.pointOpacity===void 0?1:t.pointOpacity,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.closingPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.closingPointOutlineWidth,2,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.closingPointOutlineOpacity,t.pointOutlineOpacity===void 0?1:t.pointOutlineOpacity,e),t.zIndex=50,t):t}validateFeature(e){return this.validateModeFeature(e,e=>wt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.mutateFeature.deleteFeatureIfPresent(this.closingPointId),this.canClose=!1,this.currentId=void 0,this.closingPointId=void 0,this.hasLeftStartingPoint=!1)}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}};function It({unproject:e,point:t,pointerDistance:n}){let r=n/2,{x:i,y:a}=t;return{type:`Feature`,properties:{},geometry:{type:`Polygon`,coordinates:[[e(i-r,a-r),e(i+r,a-r),e(i+r,a+r),e(i-r,a+r),e(i-r,a-r)].map(e=>[e.lng,e.lat])]}}}var Lt=class extends z{constructor(e){super(e)}create(e){let{containerX:t,containerY:n}=e;return It({unproject:this.unproject,point:{x:t,y:n},pointerDistance:this.pointerDistance})}},Rt=class extends z{constructor(e){super(e)}measure(e,t){let{x:n,y:r}=this.project(t[0],t[1]);return W({x:n,y:r},{x:e.containerX,y:e.containerY})}},zt=class extends z{constructor(e,t,n){super(e),this.config=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.getSnappableCoordinateFirstClick=e=>this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode)).coordinate,this.getSnappableCoordinate=(e,t)=>this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode&&e.id!==t)).coordinate,this.config=e,this.pixelDistance=t,this.clickBoundingBox=n}getSnappable(e,t){let n=this.clickBoundingBox.create(e),r=this.store.search(n,t),i={featureId:void 0,featureCoordinateIndex:void 0,coordinate:void 0,minDist:1/0};return r.forEach(t=>{let n;if(t.geometry.type===`Polygon`)n=t.geometry.coordinates[0];else{if(t.geometry.type!==`LineString`)return;n=t.geometry.coordinates}n.forEach((n,r)=>{let a=this.pixelDistance.measure(e,n);a<i.minDist&&a<this.pointerDistance&&(i.coordinate=n,i.minDist=a,i.featureId=t.id,i.featureCoordinateIndex=r)})}),i}};function Bt(e,t,n){let r=F(e[0]),i=F(e[1]),a=F(n),o=ct(t),s=Math.asin(Math.sin(i)*Math.cos(o)+Math.cos(i)*Math.sin(o)*Math.cos(a));return[lt(r+Math.atan2(Math.sin(a)*Math.sin(o)*Math.cos(i),Math.cos(o)-Math.sin(i)*Math.sin(s))),lt(s)]}function Vt({x:e,y:t},n,r){let i=F(r);return{x:e+n*Math.cos(i),y:t+n*Math.sin(i)}}function Ht(e,t){let n=F(e[0]),r=F(t[0]),i=F(e[1]),a=F(t[1]),o=Math.sin(r-n)*Math.cos(a),s=Math.cos(i)*Math.sin(a)-Math.sin(i)*Math.cos(a)*Math.cos(r-n);return lt(Math.atan2(o,s))}function K({x:e,y:t},{x:n,y:r}){let i=n-e,a=r-t;if(i===0&&a===0)return 0;let o=Math.atan2(a,i);return o*=180/Math.PI,o>180?o-=360:o<-180&&(o+=360),o}function Ut(e){return(e+360)%360}function Wt(e,t,n){let r=[],i=e.length,a,o,s,c=0;for(let i=0;i<e.length&&!(t>=c&&i===e.length-1);i++){if(c>t&&r.length===0){if(a=t-c,!a)return r.push(e[i]),r;o=Ht(e[i],e[i-1])-180,s=Bt(e[i],a,o),r.push(s)}if(c>=n)return a=n-c,a?(o=Ht(e[i],e[i-1])-180,s=Bt(e[i],a,o),r.push(s),r):(r.push(e[i]),r);if(c>=t&&r.push(e[i]),i===e.length-1)return r;c+=P(e[i],e[i+1])}if(c<t&&e.length===i)throw Error(`Start position is beyond line`);let l=e[e.length-1];return[l,l]}function Gt(e){return Math.PI/180*e}function Kt(e){return 180/Math.PI*e}var qt=class extends z{constructor(e){super(e),this.config=void 0,this.config=e}generateInsertionCoordinates(e,t,n){let r=[e,t],i=0;for(let e=0;e<r.length-1;e++)i+=P(r[0],r[1]);if(i<=n)return r;let a=i/n-1;Number.isInteger(a)||(a=Math.floor(a)+1);let o=[];for(let e=0;e<a;e++){let t=Wt(r,n*e,n*(e+1));o.push(t)}let s=[];for(let e=0;e<o.length;e++)s.push(o[e][1]);return this.limitCoordinates(s)}generateInsertionGeodesicCoordinates(e,t,n){let r=P(e,t),i=function(e,t,n){let r=[],i=Gt(e[1]),a=Gt(e[0]),o=Gt(t[1]),s=Gt(t[0]);n+=1;let c=2*Math.asin(Math.sqrt(Math.sin((o-i)/2)**2+Math.cos(i)*Math.cos(o)*Math.sin((s-a)/2)**2));if(c===0||isNaN(c))return r;for(let e=0;e<=n;e++){let t=e/n,l=Math.sin((1-t)*c)/Math.sin(c),u=Math.sin(t*c)/Math.sin(c),d=l*Math.cos(i)*Math.cos(a)+u*Math.cos(o)*Math.cos(s),f=l*Math.cos(i)*Math.sin(a)+u*Math.cos(o)*Math.sin(s),p=l*Math.sin(i)+u*Math.sin(o);if(isNaN(d)||isNaN(f)||isNaN(p))continue;let m=Math.atan2(p,Math.sqrt(d**2+f**2)),h=Math.atan2(f,d);isNaN(m)||isNaN(h)||r.push([Kt(h),Kt(m)])}return r.slice(1,-1)}(e,t,Math.floor(r/n));return this.limitCoordinates(i)}limitCoordinates(e){return e.map(e=>[I(e[0],this.config.coordinatePrecision),I(e[1],this.config.coordinatePrecision)])}};function Jt(e,t){if(e.geometry.type!==`LineString`)return{valid:!1,reason:`Feature is not a LineString`};if(e.geometry.coordinates.length<2)return{valid:!1,reason:`Feature has less than 2 coordinates`};for(let n=0;n<e.geometry.coordinates.length;n++){if(!vt(e.geometry.coordinates[n]))return{valid:!1,reason:`Feature has invalid coordinates`};if(!_t(e.geometry.coordinates[n],t))return{valid:!1,reason:`Feature has coordinates with excessive precision`}}return{valid:!0}}function Yt(e){return Math.sqrt(e[0]**2+e[1]**2+e[2]**2)}function Xt(e,t){let n=function(e,t){let[n,r,i]=e,[a,o,s]=t;return n*a+r*o+i*s}(e,t)/(Yt(e)*Yt(t));return Math.acos(Math.min(Math.max(n,-1),1))}function Zt(e){let t=F(e[1]),n=F(e[0]);return[Math.cos(t)*Math.cos(n),Math.cos(t)*Math.sin(n),Math.sin(t)]}function Qt(e){let[t,n,r]=e,i=lt(Math.asin(r));return[lt(Math.atan2(n,t)),i]}function $t(e,t,n){let r=Zt(e),i=Zt(t),[a,o,s]=Zt(n),[c,l,u]=function(e,t){let[n,r,i]=e,[a,o,s]=t;return[r*s-i*o,i*a-n*s,n*o-r*a]}(r,i),d=l*s-u*o,f=u*a-c*s,p=c*o-l*a,m=p*l-f*u,h=d*u-p*c,g=f*c-d*l,_=1/Math.sqrt(m**2+h**2+g**2),v=[m*_,h*_,g*_],y=[-1*m*_,-1*h*_,-1*g*_],ee=Xt(r,i),b=Xt(r,v),x=Xt(i,v),te=Xt(r,y),ne=Xt(i,y),S;return S=b<te&&b<ne||x<te&&x<ne?v:y,Xt(r,S)>ee||Xt(i,S)>ee?P(Qt(S),Qt(r))<=P(Qt(S),Qt(i))?[Qt(r),!0,!1]:[Qt(i),!1,!0]:[Qt(S),!1,!1]}function en(e,t,n){let r=t.x-e.x,i=t.y-e.y,a=Math.max(0,Math.min(1,((n.x-e.x)*r+(n.y-e.y)*i)/(r*r+i*i)));return{x:e.x+a*r,y:e.y+a*i}}var tn=class extends z{constructor(e,t,n){super(e),this.config=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.getSnappableCoordinateFirstClick=e=>{let t=this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode));return t.coordinate?[I(t.coordinate[0],this.config.coordinatePrecision),I(t.coordinate[1],this.config.coordinatePrecision)]:void 0},this.getSnappableCoordinate=(e,t)=>{let n=this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode&&e.id!==t));return n.coordinate?[I(n.coordinate[0],this.config.coordinatePrecision),I(n.coordinate[1],this.config.coordinatePrecision)]:void 0},this.config=e,this.pixelDistance=t,this.clickBoundingBox=n}getSnappable(e,t){let n=this.clickBoundingBox.create(e),r=this.store.search(n,t),i={featureId:void 0,featureCoordinateIndex:void 0,coordinate:void 0,minDistance:1/0};return r.forEach(t=>{let n;if(t.geometry.type===`Polygon`)n=t.geometry.coordinates[0];else{if(t.geometry.type!==`LineString`)return;n=t.geometry.coordinates}let r=[];for(let e=0;e<n.length-1;e++)r.push([n[e],n[e+1]]);let a,o=[e.lng,e.lat];if(this.config.projection===`web-mercator`?a=function(e,t){let n=[1/0,1/0],r=1/0,i=0;for(let a of t){let o=a[0],s=a[1],c,l=1/0,u=L(o[0],o[1]),d=L(s[0],s[1]),f=L(e[0],e[1]);if(o[0]===e[0]&&o[1]===e[1])c=o;else if(s[0]===e[0]&&s[1]===e[1])c=s;else{let{x:e,y:t}=en(u,d,f),{lng:n,lat:r}=R(e,t);c=[n,r]}c&&(l=W(f,L(c[0],c[1])),l<r&&(n=c,r=l,i=t.indexOf(a)))}return r===1/0?void 0:{coordinate:n,lineIndex:i,distance:r}}(o,r):this.config.projection===`globe`&&(a=function(e,t){let n=[1/0,1/0],r=1/0,i=0;for(let a of t){let o=a[0],s=a[1],c,l=1/0;o[0]===e[0]&&o[1]===e[1]?c=o:s[0]===e[0]&&s[1]===e[1]?c=s:[c]=$t(o,s,e),c&&(l=P(e,c),l<r&&(n=c,r=l,i=t.indexOf(a)))}return r===1/0?void 0:{coordinate:n,distance:r,lineIndex:i}}(o,r)),!a)return;let s=this.pixelDistance.measure(e,a.coordinate);s<i.minDistance&&s<this.pointerDistance&&(i.featureId=t.id,i.coordinate=[I(a.coordinate[0],this.config.coordinatePrecision),I(a.coordinate[1],this.config.coordinatePrecision)],i.featureCoordinateIndex=a.lineIndex,i.minDistance=s)}),i}};function nn(e){return Array.isArray(e)&&e.length>0&&Array.isArray(e[0])&&Array.isArray(e[0][0])}var rn=e=>nn(e)?e[0].slice(0,-1):e,an=e=>nn(e)?e[0]:e,on=class extends z{constructor(e,t,n,r){super(e),this.config=void 0,this.pixelDistance=void 0,this.mutateFeatureBehavior=void 0,this.readFeatureBehavior=void 0,this._startEndPoints=[],this.config=e,this.pixelDistance=t,this.mutateFeatureBehavior=n,this.readFeatureBehavior=r}get ids(){return this._startEndPoints.concat()}set ids(e){}create(e){if(this.ids.length)throw Error(`Opening and closing points already created`);let t=nn(e),n=an(e);if(t){if(n.length<=3)throw Error(`Requires at least 4 coordinates`);this._startEndPoints=this.mutateFeatureBehavior.createGuidancePoints({coordinates:[n[0],n[n.length-2]],type:j.CLOSING_POINT})}else this._startEndPoints=[this.mutateFeatureBehavior.createGuidancePoint({coordinate:n[n.length-2],type:j.CLOSING_POINT})]}delete(){this.ids.length&&(this.mutateFeatureBehavior.deleteFeaturesIfPresent(this.ids),this._startEndPoints=[])}updateOne(e,t){this.mutateFeatureBehavior.updateGuidancePoints([{featureId:this.ids[e],coordinate:t}])}update(e){let t=an(e);this.ids.length===1?this.mutateFeatureBehavior.updateGuidancePoints([{featureId:this.ids[0],coordinate:t[t.length-2]}]):this.ids.length===2&&this.mutateFeatureBehavior.updateGuidancePoints([{featureId:this.ids[0],coordinate:t[0]},{featureId:this.ids[1],coordinate:t[t.length-3]}])}isLineStringClosingPoint(e){if(this.ids.length!==1)return{isClosing:!1};let t=this.readFeatureBehavior.getGeometry(this.ids[0]);return{isClosing:this.pixelDistance.measure(e,t.coordinates)<this.pointerDistance}}isPolygonClosingPoints(e){if(this.ids.length!==2)return{isClosing:!1,isPreviousClosing:!1};let t=this.readFeatureBehavior.getGeometry(this.ids[0]),n=this.readFeatureBehavior.getGeometry(this.ids[1]),r=this.pixelDistance.measure(e,t.coordinates),i=this.pixelDistance.measure(e,n.coordinates);return{isClosing:r<this.pointerDistance,isPreviousClosing:i<this.pointerDistance}}},sn=class extends z{constructor(e,t,n){super(e),this.readFeature=void 0,this.mutateFeature=void 0,this.readFeature=t,this.mutateFeature=n}createOrUpdate({featureId:e,featureCoordinates:t}){if(!this.readFeature.hasFeature(e))return void this.deleteOrphanedPoints(e);let n=rn(t),r=this.readFeature.getProperties(e),i=r.coordinatePointIds;if(i)if(i&&i.every(e=>this.readFeature.hasFeature(e))){let t=r.coordinatePointIds,i=t.map(e=>this.readFeature.getGeometry(e).coordinates);if(t.length!==n.length){this.deleteCoordinatePoints(t);let i=this.createPoints(n,r.mode,e);this.setFeatureCoordinatePoints(e,i)}else{let e=[];n.forEach((n,r)=>{n[0]===i[r][0]&&n[1]===i[r][1]||e.push({featureId:t[r],coordinate:n})}),this.mutateFeature.updateGuidancePoints(e)}}else{let t=i.filter(e=>this.readFeature.hasFeature(e));t.length&&this.deleteCoordinatePoints(t);let a=this.createPoints(n,r.mode,e);this.setFeatureCoordinatePoints(e,a)}else{let t=this.createPoints(n,r.mode,e);this.setFeatureCoordinatePoints(e,t)}}deletePointsByFeatureIds(e){for(let t of e)this.deleteIfPresent(t)}updateOneAtIndex(e,t,n){let r=this.readFeature.getProperties(e).coordinatePointIds;r&&r.length!==0&&r[t]!==void 0&&this.mutateFeature.updateGuidancePoints([{featureId:r[t],coordinate:n}])}updateAllInPlace({featureId:e,featureCoordinates:t}){let n=this.readFeature.getProperties(e);if(!n.coordinatePointIds)return;let r=rn(t);r.length===n.coordinatePointIds.length&&this.mutateFeature.updateGuidancePoints(n.coordinatePointIds.map((e,t)=>({featureId:e,coordinate:r[t]})))}createPoints(e,t,n){return this.mutateFeature.createGuidancePoints({coordinates:e,type:j.COORDINATE_POINT,additionalProperties:e=>({mode:t,[j.COORDINATE_POINT]:!0,[j.COORDINATE_POINT_FEATURE_ID]:n,index:e})})}setFeatureCoordinatePoints(e,t,n=k.Commit){let r=this.readFeature.getGeometryType(e),i={featureId:e,propertyMutations:{[j.COORDINATE_POINT_IDS]:t},context:{updateType:n}};if(r===`Polygon`)this.mutateFeature.updatePolygon(i);else{if(r!==`LineString`)throw Error(`Unsupported geometry type for coordinate points`);this.mutateFeature.updateLineString(i)}}deleteCoordinatePoints(e){this.mutateFeature.deleteFeaturesIfPresent(e)}deleteIfPresent(e){if(!this.readFeature.hasFeature(e))return;let t=this.readFeature.getProperties(e).coordinatePointIds;t&&(this.deleteCoordinatePoints(t),this.setFeatureCoordinatePoints(e,null))}deleteOrphanedPoints(e){let t=this.readFeature.getAllFeatureIdsWhere(t=>t[j.COORDINATE_POINT_FEATURE_ID]===e);this.mutateFeature.deleteFeaturesIfPresent(t)}},cn=class{constructor(e){this.undoHistory=[],this.redoHistory=[],this.cloneCoordinatesFunction=void 0,this.maxStackSize=void 0,this.cloneCoordinatesFunction=e=>this.cloneRecursively(e);let t=e?.maxStackSize;this.maxStackSize=t!==void 0&&Number.isFinite(t)?Math.max(0,Math.floor(t)):1/0}setMaxStackSize(e){Number.isFinite(e)?(this.maxStackSize=Math.max(0,Math.floor(e)),this.trimHistoryToMax(this.undoHistory),this.trimHistoryToMax(this.redoHistory)):this.maxStackSize=1/0}trimHistoryToMax(e){if(Number.isFinite(this.maxStackSize))for(;e.length>this.maxStackSize;)e.shift()}pushUndoEntry(e){this.maxStackSize!==0&&(this.undoHistory.push(e),this.trimHistoryToMax(this.undoHistory))}pushRedoEntry(e){this.maxStackSize!==0&&(this.redoHistory.push(e),this.trimHistoryToMax(this.redoHistory))}cloneRecursively(e){return Array.isArray(e)?e.map(e=>this.cloneRecursively(e)):typeof e==`object`&&e?D({},e):e}cloneCoordinates(e){return this.cloneCoordinatesFunction(e)}cloneEntry(e){return{featureCoordinates:this.cloneCoordinates(e.featureCoordinates),currentCoordinate:e.currentCoordinate}}clear(){this.undoHistory=[],this.redoHistory=[]}undoSize(){return this.undoHistory.length}redoSize(){return this.redoHistory.length}recordSnapshot(e){this.pushUndoEntry(this.cloneEntry(e)),this.redoHistory=[]}beginUndo(){let e=this.undoHistory.pop();if(!e)return;let t=this.cloneEntry(e);this.pushRedoEntry(t);let n=this.undoHistory[this.undoHistory.length-1];return{undoneEntry:t,previousEntry:n?this.cloneEntry(n):void 0}}takeRedo(){let e=this.redoHistory.pop();if(e)return this.cloneEntry(e)}commitRedo(e){this.pushUndoEntry(this.cloneEntry(e))}},ln={cancel:`Escape`,finish:`Enter`},un={start:`crosshair`,close:`pointer`,dragStart:`grabbing`,dragEnd:`crosshair`},dn=class extends N{constructor(e){super(e,!0),this.mode=`linestring`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=ln,this.snapping=void 0,this.cursors=un,this.mouseMove=!1,this.insertCoordinates=void 0,this.lastCommittedCoordinates=void 0,this.snappedPointId=void 0,this.lastMouseMoveEvent=void 0,this.showCoordinatePoints=!1,this.finishOnNthCoordinate=void 0,this.editable=!1,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0,this.editedInsertIndex=void 0,this.editedPointId=void 0,this.coordinateSnapping=void 0,this.insertPoint=void 0,this.lineSnapping=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.closingPoints=void 0,this.coordinatePoints=void 0,this.undoRedo=void 0,this.updateOptions(e)}updateOptions(e){if(super.updateOptions(e),e?.finishOnNthCoordinate!==void 0&&Number.isInteger(e.finishOnNthCoordinate)&&e.finishOnNthCoordinate>1&&(this.finishOnNthCoordinate=Math.floor(e.finishOnNthCoordinate)),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.snapping&&(this.snapping=e.snapping),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.insertCoordinates&&(this.insertCoordinates=e.insertCoordinates),e&&e.editable&&(this.editable=e.editable),e?.showCoordinatePoints!==void 0){if(this.showCoordinatePoints=e.showCoordinatePoints,this.coordinatePoints&&!0===e.showCoordinatePoints)this.store.copyAllWhere(e=>e.mode===this.mode).forEach(e=>{this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})});else if(this.coordinatePoints&&!1===this.showCoordinatePoints){let e=this.store.copyAllWhere(e=>e.mode===this.mode&&!!e[j.COORDINATE_POINT_IDS]?.length);this.coordinatePoints.deletePointsByFeatureIds(e.map(e=>e.id))}}}shouldFinishOnCommit(e){return!!this.finishOnNthCoordinate&&Math.max(0,e.coordinates.length-1)>=this.finishOnNthCoordinate}updateSnappedCoordinate(e){let t=this.snapCoordinate(e);return t?(this.snappedPointId?this.mutateFeature.updateGuidancePoints([{featureId:this.snappedPointId,coordinate:t}]):this.snappedPointId=this.mutateFeature.createGuidancePoint({coordinate:t,type:j.SNAPPING_POINT}),e.lng=t[0],e.lat=t[1]):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),t}close(){if(this.currentId===void 0)return;let e=this.mutateFeature.updateLineString({featureId:this.currentId,context:{updateType:k.Finish,action:O},coordinateMutations:[{type:Ot,index:-1}],propertyMutations:{[j.CURRENTLY_DRAWING]:void 0}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates});let t=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.lastCommittedCoordinates=void 0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted(),this.closingPoints.delete(),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0),this.onFinish(t,{mode:this.mode,action:O})}generateInsertCoordinates(e,t){if(!this.insertCoordinates||!this.lastCommittedCoordinates)throw Error(`Not able to insert coordinates`);if(this.insertCoordinates.strategy!==`amount`)throw Error(`Strategy does not exist`);let n=P(e,t)/(this.insertCoordinates.value+1),r=[];return this.projection===`globe`?r=this.insertPoint.generateInsertionGeodesicCoordinates(e,t,n):this.projection===`web-mercator`&&(r=this.insertPoint.generateInsertionCoordinates(e,t,n)),r}createLine(e){let t=this.mutateFeature.createLineString({coordinates:[e,e],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.lastCommittedCoordinates=t.geometry.coordinates,this.currentId=t.id,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.setDrawing(),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates})}firstUpdateToLine(e){if(!this.currentId)return;this.setCursor(this.cursors.close);let t=this.mutateFeature.updateLineString({featureId:this.currentId,context:{updateType:k.Commit},coordinateMutations:[{type:B,index:-1,coordinate:e}]});t&&(this.closingPoints.create(t.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates}),this.lastCommittedCoordinates=t.geometry.coordinates,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.shouldFinishOnCommit(t.geometry)&&this.close())}updateToLine(e,t){if(!this.currentId)return;let{isClosing:n}=this.closingPoints.isLineStringClosingPoint(e);if(n)return void this.close();this.setCursor(this.cursors.close);let r=this.mutateFeature.updateLineString({featureId:this.currentId,context:{updateType:k.Commit},coordinateMutations:[{type:B,index:-1,coordinate:t}]});r&&(this.closingPoints.update(r.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:r.geometry.coordinates}),this.lastCommittedCoordinates=r.geometry.coordinates,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.shouldFinishOnCommit(r.geometry)&&this.close())}undoSize(){return this.undoRedo.undoSize()}clearHistory(){this.undoRedo.clear()}pushHistorySnapshot(e,t){let n=this.readFeature.getGeometry(e);this.undoRedo.recordSnapshot({featureCoordinates:n.coordinates,currentCoordinate:t})}updateSnappedGuidancePointFromLastMouseMove(){this.snapping&&this.lastMouseMoveEvent?this.updateSnappedCoordinate(this.lastMouseMoveEvent):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0)}syncClosingPoints(e){this.currentCoordinate>=2?this.closingPoints.ids.length?this.closingPoints.update(e):this.closingPoints.create(e):this.closingPoints.delete()}undo(){if(this.state!==`drawing`||!this.currentId)return;let e=this.undoRedo.beginUndo();if(!e)return;let{previousEntry:t}=e;if(!t){let e=this.currentId;this.currentId=void 0,this.currentCoordinate=0,this.lastCommittedCoordinates=void 0,this.closingPoints.delete(),this.state===`drawing`&&this.setStarted(),this.showCoordinatePoints&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.updateSnappedGuidancePointFromLastMouseMove();return}let n=this.mutateFeature.updateLineString({featureId:this.currentId,coordinateMutations:{type:H,coordinates:t.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0},context:{updateType:k.Commit}});n&&(this.currentCoordinate=t.currentCoordinate,this.lastCommittedCoordinates=n.geometry.coordinates,this.syncClosingPoints(n.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:n.geometry.coordinates}),this.updateSnappedGuidancePointFromLastMouseMove())}redoSize(){return this.undoRedo.redoSize()}redo(){let e=this.undoRedo.takeRedo();if(e){if(this.currentId){let t=this.mutateFeature.updateLineString({featureId:this.currentId,coordinateMutations:{type:H,coordinates:e.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0},context:{updateType:k.Commit}});if(!t)return;this.currentCoordinate=e.currentCoordinate,this.lastCommittedCoordinates=t.geometry.coordinates,this.syncClosingPoints(t.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates})}else{let{id:t,geometry:n}=this.mutateFeature.createLineString({coordinates:e.featureCoordinates,properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.currentId=t,this.currentCoordinate=e.currentCoordinate,this.lastCommittedCoordinates=n.coordinates,this.state===`started`&&this.setDrawing(),this.syncClosingPoints(n.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:t,featureCoordinates:n.coordinates})}this.undoRedo.commitRedo(e),this.updateSnappedGuidancePointFromLastMouseMove()}}registerBehaviors(e){this.insertPoint=new qt(e),this.clickBoundingBox=new Lt(e),this.pixelDistance=new Rt(e),this.lineSnapping=new tn(e,this.pixelDistance,this.clickBoundingBox),this.coordinateSnapping=new zt(e,this.pixelDistance,this.clickBoundingBox),this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate}),this.closingPoints=new on(e,this.pixelDistance,this.mutateFeature,this.readFeature),this.coordinatePoints=new sn(e,this.readFeature,this.mutateFeature),this.undoRedo=new cn({maxStackSize:e.undoRedoMaxStackSize})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){this.mouseMove=!0,this.setCursor(this.cursors.start),this.lastMouseMoveEvent=e;let t=this.updateSnappedCoordinate(e)||[e.lng,e.lat];if(this.currentId===void 0||this.currentCoordinate===0)return;let{isClosing:n}=this.closingPoints.isLineStringClosingPoint(e);n&&this.setCursor(this.cursors.close);let r=[{type:V,index:-1,coordinate:t}];if(this.insertCoordinates){let e=this.getInsertCoordinates(t);e&&(r={type:H,coordinates:e})}let i=this.mutateFeature.updateLineString({coordinateMutations:r,featureId:this.currentId,context:{updateType:k.Provisional}});i&&this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:i.geometry.coordinates})}getInsertCoordinates(e){if(!this.lastCommittedCoordinates)return;let t=this.lastCommittedCoordinates[this.lastCommittedCoordinates.length-1];if(Mt(t,e))return;let n=this.generateInsertCoordinates(t,e);return[...this.lastCommittedCoordinates.slice(0,-1),...n,e]}onRightClick(e){if(!this.editable||this.state!==`started`)return;let{featureId:t,featureCoordinateIndex:n}=this.coordinateSnapping.getSnappable(e,e=>this.lineStringFilter(e));if(!t||n===void 0)return;let r=this.readFeature.getGeometry(t),i;if(r.type!==`LineString`||(i=r.coordinates,i.length<=2))return;let a=this.mutateFeature.updateLineString({featureId:t,coordinateMutations:[{type:Ot,index:n}],context:{updateType:k.Finish,action:Xe}});a&&this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:t,featureCoordinates:a.geometry.coordinates}),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0),this.closingPoints.delete(),this.onFinish(t,{mode:this.mode,action:Ze})}onLeftClick(e){this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0);let t=this.snapCoordinate(e)||[e.lng,e.lat];this.currentCoordinate===0?this.createLine(t):this.currentCoordinate===1&&this.currentId?this.firstUpdateToLine(t):this.currentId&&this.updateToLine(e,t)}onClick(e){this.currentId===void 0||this.readFeature.hasFeature(this.currentId)||this.cleanUp(),(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))&&(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,e.button===`right`?this.onRightClick(e):e.button===`left`&&this.onLeftClick(e))}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel&&this.cleanUp(),e.key===this.keyEvents.finish&&this.close()}onDragStart(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragStart,e)||!this.editable)return;let n;if(this.state===`started`){let t=this.lineSnapping.getSnappable(e,e=>this.lineStringFilter(e));t.coordinate&&(this.editedSnapType=`line`,this.editedFeatureCoordinateIndex=t.featureCoordinateIndex,this.editedFeatureId=t.featureId,n=t.coordinate);let r=this.coordinateSnapping.getSnappable(e,e=>this.lineStringFilter(e));r.coordinate&&(this.editedSnapType=`coordinate`,this.editedFeatureCoordinateIndex=r.featureCoordinateIndex,this.editedFeatureId=r.featureId,n=r.coordinate)}this.editedFeatureId&&n&&(this.editedPointId||=this.mutateFeature.createGuidancePoint({coordinate:n,type:j.EDITED}),this.setCursor(this.cursors.dragStart),t(!1))}onDrag(e,t){if(this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.editedFeatureId!==void 0&&this.editedFeatureCoordinateIndex!==void 0){if(this.editedSnapType===`coordinate`||this.editedSnapType===`line`&&this.editedInsertIndex!==void 0){let t=this.mutateFeature.updateLineString({featureId:this.editedFeatureId,context:{updateType:k.Provisional},coordinateMutations:[{type:V,index:this.editedFeatureCoordinateIndex,coordinate:[e.lng,e.lat]}]});if(!t)return;this.showCoordinatePoints&&(this.editedInsertIndex===void 0?this.coordinatePoints.updateOneAtIndex(this.editedFeatureId,this.editedFeatureCoordinateIndex,[e.lng,e.lat]):this.coordinatePoints.createOrUpdate({featureId:this.editedFeatureId,featureCoordinates:t.geometry.coordinates}))}else if(this.editedSnapType===`line`&&this.editedInsertIndex===void 0){this.editedInsertIndex=this.editedFeatureCoordinateIndex+1;let e=this.mutateFeature.updateLineString({featureId:this.editedFeatureId,context:{updateType:k.Provisional}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.editedFeatureId,featureCoordinates:e.geometry.coordinates}),this.editedFeatureCoordinateIndex++}this.snapping&&this.snappedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),this.snappedPointId=void 0),this.editedPointId&&this.mutateFeature.updateGuidancePoints([{featureId:this.editedPointId,coordinate:[e.lng,e.lat]}]),this.mutateFeature.updateLineString({featureId:this.editedFeatureId,context:{updateType:k.Provisional},propertyMutations:{[j.EDITED]:!0}})}}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||(this.setCursor(this.cursors.dragEnd),!this.mutateFeature.updateLineString({featureId:this.editedFeatureId,propertyMutations:{[j.EDITED]:!1},context:{updateType:k.Finish,action:Xe}})))return;let n=this.editedFeatureId;t(!0),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0),this.closingPoints.delete(),this.onFinish(n,{mode:this.mode,action:Xe})}cleanUp(){let e=this.currentId,t=this.snappedPointId;this.snappedPointId=void 0,this.currentId=void 0,this.currentCoordinate=0,this.lastCommittedCoordinates=void 0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted(),e&&this.showCoordinatePoints&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(t),this.closingPoints.delete()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.type===`Feature`&&e.geometry.type===`LineString`&&e.properties.mode===this.mode)return t.lineStringColor=this.getHexColorStylingValue(this.styles.lineStringColor,t.lineStringColor,e),t.lineStringOpacity=this.getNumericStylingValue(this.styles.lineStringOpacity,t.lineStringOpacity===void 0?1:t.lineStringOpacity,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.lineStringWidth,t.lineStringWidth,e),t.zIndex=M,t;if(e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode){let n=e.properties[j.COORDINATE_POINT],r=e.properties[j.CLOSING_POINT]?`closingPoint`:e.properties[j.SNAPPING_POINT]?`snappingPoint`:n?`coordinatePoint`:void 0;if(!r)return t;let i={closingPoint:{width:this.styles.closingPointWidth,color:this.styles.closingPointColor,opacity:this.styles.closingPointOpacity,outlineColor:this.styles.closingPointOutlineColor,outlineWidth:this.styles.closingPointOutlineWidth,outlineOpacity:this.styles.closingPointOutlineOpacity},snappingPoint:{width:this.styles.snappingPointWidth,color:this.styles.snappingPointColor,opacity:this.styles.snappingPointOpacity,outlineColor:this.styles.snappingPointOutlineColor,outlineWidth:this.styles.snappingPointOutlineWidth,outlineOpacity:this.styles.snappingPointOutlineOpacity},coordinatePoint:{width:this.styles.coordinatePointWidth,color:this.styles.coordinatePointColor,opacity:this.styles.coordinatePointOpacity,outlineColor:this.styles.coordinatePointOutlineColor,outlineWidth:this.styles.coordinatePointOutlineWidth,outlineOpacity:this.styles.coordinatePointOutlineOpacity}};return t.pointWidth=this.getNumericStylingValue(i[r].width,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(i[r].opacity,1,e),t.pointColor=this.getHexColorStylingValue(i[r].color,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(i[r].outlineColor,`#ffffff`,e),t.pointOutlineWidth=this.getNumericStylingValue(i[r].outlineWidth,2,e),t.pointOutlineOpacity=this.getNumericStylingValue(i[r].outlineOpacity,1,e),t.zIndex=n?20:50,t}return t}validateFeature(e){return this.validateModeFeature(e,e=>Jt(e,this.coordinatePrecision))}lineStringFilter(e){return!!(e.geometry.type===`LineString`&&e.properties&&e.properties.mode===this.mode)}snapCoordinate(e){var t,n,r;let i;if((t=this.snapping)!=null&&t.toLine){let t;t=this.currentId?this.lineSnapping.getSnappableCoordinate(e,this.currentId):this.lineSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((n=this.snapping)!=null&&n.toCoordinate){let t;t=this.currentId?this.coordinateSnapping.getSnappableCoordinate(e,this.currentId):this.coordinateSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((r=this.snapping)!=null&&r.toCustom){let t=this.snapping.toCustom(e,{currentCoordinate:this.currentCoordinate,currentId:this.currentId,getCurrentGeometrySnapshot:this.currentId?()=>this.readFeature.getGeometry(this.currentId):()=>null,project:this.project,unproject:this.unproject});t&&(i=t)}return i}afterFeatureUpdated(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates}),this.editedFeatureId===e.id&&this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0),this.snappedPointId&&this.lastMouseMoveEvent&&this.updateSnappedCoordinate(this.lastMouseMoveEvent),this.currentId===e.id&&(this.closingPoints.delete(),this.currentCoordinate=0,this.currentId=void 0,this.lastCommittedCoordinates=void 0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted())}afterFeatureAdded(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})}},fn=`Feature is not a Point`,pn=`Feature has invalid coordinates`,mn=`Feature has coordinates with excessive precision`;function hn(e,t){return e.geometry.type===`Point`?vt(e.geometry.coordinates)?_t(e.geometry.coordinates,t)?{valid:!0}:{valid:!1,reason:mn}:{valid:!1,reason:pn}:{valid:!1,reason:fn}}var gn=class extends z{constructor(e,t,n){super(e),this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.pixelDistance=t,this.clickBoundingBox=n}getNearestPointFeature(e){let t=this.clickBoundingBox.create(e),n=this.store.search(t),r,i=1/0;for(let t=0;t<n.length;t++){let a=n[t];if(a.geometry.type!==`Point`||a.properties.mode!==this.mode)continue;let o=this.pixelDistance.measure(e,a.geometry.coordinates);o>i||o>this.pointerDistance||(i=o,r=a)}return r}},_n={create:`crosshair`,dragStart:`grabbing`,dragEnd:`crosshair`},vn=class extends N{constructor(e){super(e,!0),this.mode=`point`,this.cursors=_n,this.editable=!1,this.editedFeatureId=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.pointSearch=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.editable&&(this.editable=e.editable)}start(){this.setStarted(),this.setCursor(this.cursors.create)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}onMouseMove(){}onKeyDown(){}onKeyUp(){}cleanUp(){this.editedFeatureId=void 0}onDragStart(e,t){this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&(this.editable&&(this.editedFeatureId=this.pointSearch.getNearestPointFeature(e)?.id),this.editedFeatureId&&(this.setCursor(this.cursors.dragStart),t(!1)))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.editedFeatureId!==void 0&&this.mutateFeature.updatePoint({featureId:this.editedFeatureId,coordinateMutations:{type:H,coordinates:[e.lng,e.lat]},propertyMutations:{[j.EDITED]:!0},context:{updateType:k.Provisional}})}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||!this.mutateFeature.updatePoint({featureId:this.editedFeatureId,propertyMutations:{mode:this.mode,[j.EDITED]:!1},context:{updateType:k.Finish,action:`edit`}}))return;let n=this.editedFeatureId;this.setCursor(this.cursors.dragEnd),this.editedFeatureId=void 0,t(!0),this.onFinish(n,{mode:this.mode,action:O})}registerBehaviors(e){this.pixelDistance=new Rt(e),this.clickBoundingBox=new Lt(e),this.pointSearch=new gn(e,this.pixelDistance,this.clickBoundingBox),this.mutateFeature=new U(e,{validate:this.validate})}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode){let n=!!(e.id&&this.editedFeatureId===e.id);t.pointWidth=this.getNumericStylingValue(n?this.styles.editedPointWidth:this.styles.pointWidth,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(this.styles.pointOpacity,t.pointOpacity===void 0?1:t.pointOpacity,e),t.pointColor=this.getHexColorStylingValue(n?this.styles.editedPointColor:this.styles.pointColor,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(n?this.styles.editedPointOutlineColor:this.styles.pointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.pointOutlineOpacity,t.pointOutlineOpacity===void 0?1:t.pointOutlineOpacity,e),t.pointOutlineWidth=this.getNumericStylingValue(n?this.styles.editedPointOutlineWidth:this.styles.pointOutlineWidth,2,e),t.zIndex=30}return t}validateFeature(e){return this.validateModeFeature(e,e=>hn(e,this.coordinatePrecision))}onLeftClick(e){let t=this.mutateFeature.createPoint({coordinates:[e.lng,e.lat],properties:{mode:this.mode},context:{updateType:k.Finish,action:O}});t&&this.onFinish(t.id,{mode:this.mode,action:O})}onRightClick(e){if(!this.editable)return;let t=this.pointSearch.getNearestPointFeature(e);t&&this.mutateFeature.deleteFeatureIfPresent(t.id)}afterFeatureUpdated(e){this.editedFeatureId===e.id&&(this.editedFeatureId=void 0,this.setCursor(this.cursors.create))}},yn={cancel:`Escape`,finish:`Enter`},bn={start:`crosshair`,close:`pointer`,dragStart:`grabbing`,dragEnd:`crosshair`},xn=class extends N{constructor(e){super(e,!0),this.mode=`polygon`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=yn,this.cursors=bn,this.mouseMove=!1,this.showCoordinatePoints=!1,this.lastMouseMoveEvent=void 0,this.snapping=void 0,this.snappedPointId=void 0,this.editable=!1,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0,this.editedInsertIndex=void 0,this.editedPointId=void 0,this.coordinatePoints=void 0,this.lineSnapping=void 0,this.coordinateSnapping=void 0,this.pixelDistance=void 0,this.closingPoints=void 0,this.clickBoundingBox=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.undoRedo=void 0,this.updateOptions(e)}updateOptions(e){if(super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.snapping&&(this.snapping=e.snapping),e?.editable!==void 0&&(this.editable=e.editable),e?.pointerEvents!==void 0&&(this.pointerEvents=e.pointerEvents),e?.showCoordinatePoints!==void 0){if(this.showCoordinatePoints=e.showCoordinatePoints,this.coordinatePoints&&!0===e.showCoordinatePoints)this.store.copyAllWhere(e=>e.mode===this.mode).filter(e=>e.geometry.type===`Polygon`).forEach(e=>{this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})});else if(this.coordinatePoints&&!1===this.showCoordinatePoints){let e=this.store.copyAllWhere(e=>e.mode===this.mode&&!!e[j.COORDINATE_POINT_IDS]).filter(e=>e.geometry.type===`Polygon`);this.coordinatePoints.deletePointsByFeatureIds(e.map(e=>e.id))}}}close(){if(this.currentId===void 0||this.readFeature.getCoordinates(this.currentId).length<5)return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:Ot,index:-2}],propertyMutations:{[j.CURRENTLY_DRAWING]:void 0,[j.COMMITTED_COORDINATE_COUNT]:void 0,[j.PROVISIONAL_COORDINATE_COUNT]:void 0},context:{updateType:k.Finish,action:O}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.state===`drawing`&&this.setStarted(),this.editedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),void 0),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.closingPoints.delete();let t=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.undoRedo.clear(),this.onFinish(t,{mode:this.mode,action:O})}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate}),this.clickBoundingBox=new Lt(e),this.pixelDistance=new Rt(e),this.lineSnapping=new tn(e,this.pixelDistance,this.clickBoundingBox),this.coordinateSnapping=new zt(e,this.pixelDistance,this.clickBoundingBox),this.closingPoints=new on(e,this.pixelDistance,this.mutateFeature,this.readFeature),this.coordinatePoints=new sn(e,this.readFeature,this.mutateFeature),this.undoRedo=new cn({maxStackSize:e.undoRedoMaxStackSize})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}updateSnappedCoordinate(e){let t=this.snapCoordinate(e);t?(this.snappedPointId?this.mutateFeature.updateGuidancePoints([{featureId:this.snappedPointId,coordinate:t}]):this.snappedPointId=this.mutateFeature.createGuidancePoint({coordinate:t,type:j.SNAPPING_POINT}),e.lng=t[0],e.lat=t[1]):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0)}undoSize(){return this.undoRedo.undoSize()}clearHistory(){this.undoRedo.clear()}pushHistorySnapshot(e,t){let n=this.readFeature.getGeometry(e);this.undoRedo.recordSnapshot({featureCoordinates:n.coordinates,currentCoordinate:t})}updateSnappedGuidancePointFromLastMouseMove(){this.snapping&&this.lastMouseMoveEvent?this.updateSnappedCoordinate(this.lastMouseMoveEvent):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0)}syncClosingPoints(e){this.currentCoordinate>=3?this.closingPoints.ids.length?this.closingPoints.update(e):this.closingPoints.create(e):this.closingPoints.delete()}undo(){if(this.state!==`drawing`||!this.currentId)return;let e=this.undoRedo.beginUndo();if(!e)return;let{previousEntry:t}=e;if(!t){let e=this.currentId;this.currentId=void 0,this.currentCoordinate=0,this.closingPoints.delete(),this.state===`drawing`&&this.setStarted(),this.showCoordinatePoints&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.updateSnappedGuidancePointFromLastMouseMove();return}let n=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:{type:H,coordinates:t.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:t.currentCoordinate,[j.PROVISIONAL_COORDINATE_COUNT]:t.currentCoordinate},context:{updateType:k.Commit}});n&&(this.currentCoordinate=t.currentCoordinate,this.syncClosingPoints(n.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:n.geometry.coordinates}),this.updateSnappedGuidancePointFromLastMouseMove())}redoSize(){return this.undoRedo.redoSize()}redo(){let e=this.undoRedo.takeRedo();if(e){if(this.currentId){let t=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:{type:H,coordinates:e.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:e.currentCoordinate,[j.PROVISIONAL_COORDINATE_COUNT]:e.currentCoordinate},context:{updateType:k.Commit}});if(!t)return;this.currentCoordinate=e.currentCoordinate,this.syncClosingPoints(t.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates})}else{let t=this.undoRedo.cloneCoordinates(e.featureCoordinates)[0],{id:n,geometry:r}=this.mutateFeature.createPolygon({coordinates:t,properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:e.currentCoordinate,[j.PROVISIONAL_COORDINATE_COUNT]:e.currentCoordinate}});this.currentId=n,this.currentCoordinate=e.currentCoordinate,this.state===`started`&&this.setDrawing(),this.syncClosingPoints(r.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:n,featureCoordinates:r.coordinates})}this.undoRedo.commitRedo(e),this.updateSnappedGuidancePointFromLastMouseMove()}}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.lastMouseMoveEvent=e,this.updateSnappedCoordinate(e),this.currentId===void 0||this.currentCoordinate===0)return;let t=this.readFeature.getCoordinate(this.currentId,0),n=[e.lng,e.lat],r;if(this.currentCoordinate===1)r=[{type:V,index:1,coordinate:n},{type:V,index:2,coordinate:[e.lng,e.lat]}];else if(this.currentCoordinate===2)r=[{type:V,index:2,coordinate:n}];else{let{isClosing:i,isPreviousClosing:a}=this.closingPoints.isPolygonClosingPoints(e);a||i?(this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.setCursor(this.cursors.close),r=[{type:V,index:-1,coordinate:t},{type:V,index:-2,coordinate:t}]):r=[{type:V,index:-2,coordinate:n},{type:V,index:-1,coordinate:t}]}let i=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:r,propertyMutations:{[j.PROVISIONAL_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Provisional}});i&&this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:i.geometry.coordinates})}snapCoordinate(e){var t,n,r;let i;if((t=this.snapping)!=null&&t.toLine){let t;t=this.currentId?this.lineSnapping.getSnappableCoordinate(e,this.currentId):this.lineSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((n=this.snapping)!=null&&n.toCoordinate){let t;t=this.currentId?this.coordinateSnapping.getSnappableCoordinate(e,this.currentId):this.coordinateSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((r=this.snapping)!=null&&r.toCustom){let t=this.snapping.toCustom(e,{currentCoordinate:this.currentCoordinate,currentId:this.currentId,getCurrentGeometrySnapshot:this.currentId?()=>this.readFeature.getGeometry(this.currentId):()=>null,project:this.project,unproject:this.unproject});t&&(i=t)}return i}polygonFilter(e){return!!(e.geometry.type===`Polygon`&&e.properties&&e.properties.mode===this.mode)}onRightClick(e){if(!this.editable||this.state!==`started`)return;let{featureId:t,featureCoordinateIndex:n}=this.coordinateSnapping.getSnappable(e,e=>this.polygonFilter(e));if(!t||n===void 0)return;let r=this.readFeature.getGeometry(t);if(r.type!==`Polygon`)return;let i=r.coordinates[0];if(i.length<=4)return;let a;a=n===0||n===i.length-1?[{type:Ot,index:0},{type:Ot,index:-1},{type:B,index:-1,coordinate:i[1]}]:[{type:Ot,index:n}];let o=this.mutateFeature.updatePolygon({featureId:t,coordinateMutations:a,context:{updateType:k.Finish,action:Xe}});if(o){if(this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:t,featureCoordinates:o.geometry.coordinates}),this.snappedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),this.snappedPointId=void 0,this.snapping)){let t=this.snapCoordinate(e);if(t){let[e]=this.mutateFeature.createGuidancePoints({type:j.SNAPPING_POINT,coordinates:[t]});this.snappedPointId=e}}this.onFinish(t,{mode:this.mode,action:Xe})}}onLeftClick(e){this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0);let t=this.snapCoordinate(e)||[e.lng,e.lat];if(this.currentCoordinate===0){let{id:e,geometry:n}=this.mutateFeature.createPolygon({coordinates:[t,t,t,t],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1,[j.PROVISIONAL_COORDINATE_COUNT]:this.currentCoordinate+1}});this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e,featureCoordinates:n.coordinates}),this.currentId=e,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.setDrawing()}else if(this.currentCoordinate===1&&this.currentId){if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,newCoordinate:t,index:0}))return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:1,coordinate:t},{type:V,index:2,coordinate:t}],propertyMutations:{[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Commit}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate)}else if(this.currentCoordinate===2&&this.currentId){if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,newCoordinate:t,index:1}))return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:2,coordinate:t},{type:B,index:2,coordinate:t}],propertyMutations:{[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Commit}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.currentCoordinate===2&&this.closingPoints.create(e.geometry.coordinates),this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate)}else if(this.currentId){let{isClosing:n,isPreviousClosing:r}=this.closingPoints.isPolygonClosingPoints(e);if(r||n)this.close();else{if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,newCoordinate:t,index:this.currentCoordinate-1}))return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:Dt,index:-1,coordinate:t}],propertyMutations:{[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Commit}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.closingPoints.ids.length&&this.closingPoints.update(e.geometry.coordinates)}}}onClick(e){this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onKeyDown(){}onDragStart(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragStart,e)||!this.editable)return;let n;if(this.state===`started`){let t=this.lineSnapping.getSnappable(e,e=>this.polygonFilter(e));t.coordinate&&(this.editedSnapType=`line`,this.editedFeatureCoordinateIndex=t.featureCoordinateIndex,this.editedFeatureId=t.featureId,n=t.coordinate);let r=this.coordinateSnapping.getSnappable(e,e=>this.polygonFilter(e));r.coordinate&&(this.editedSnapType=`coordinate`,this.editedFeatureCoordinateIndex=r.featureCoordinateIndex,this.editedFeatureId=r.featureId,n=r.coordinate)}this.editedFeatureId&&n&&(this.editedPointId||=this.mutateFeature.createGuidancePoint({coordinate:n,type:j.EDITED}),this.setCursor(this.cursors.dragStart),t(!1))}onDrag(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDrag,e)||this.editedFeatureId===void 0||this.editedFeatureCoordinateIndex===void 0)return;let n=this.readFeature.getGeometry(this.editedFeatureId),r=[e.lng,e.lat],i=[];if(this.editedSnapType===`coordinate`||this.editedSnapType===`line`&&this.editedInsertIndex!==void 0?i=this.editedFeatureCoordinateIndex===0||this.editedFeatureCoordinateIndex===n.coordinates[0].length-1?[{type:V,index:0,coordinate:r},{type:V,index:-1,coordinate:r}]:[{type:V,index:this.editedFeatureCoordinateIndex,coordinate:r}]:this.editedSnapType===`line`&&this.editedInsertIndex===void 0&&(this.editedInsertIndex=this.editedFeatureCoordinateIndex+1,i=[{type:Dt,index:this.editedInsertIndex,coordinate:r}],this.editedFeatureCoordinateIndex++),i.length===0)return;let a=this.mutateFeature.updatePolygon({featureId:this.editedFeatureId,coordinateMutations:i,propertyMutations:{[j.EDITED]:!0},context:{updateType:k.Provisional}});a&&(this.showCoordinatePoints&&(this.editedInsertIndex?this.coordinatePoints.createOrUpdate({featureId:this.editedFeatureId,featureCoordinates:a.geometry.coordinates}):this.coordinatePoints.updateOneAtIndex(this.editedFeatureId,this.editedFeatureCoordinateIndex,a.geometry.coordinates[0][this.editedFeatureCoordinateIndex])),this.snapping&&this.snappedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),this.snappedPointId=void 0),this.editedPointId&&this.mutateFeature.updateGuidancePoints([{featureId:this.editedPointId,coordinate:r}]))}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||(this.setCursor(this.cursors.dragEnd),!this.mutateFeature.updatePolygon({featureId:this.editedFeatureId,propertyMutations:{[j.EDITED]:!1},context:{updateType:k.Finish,action:Xe}})))return;let n=this.editedFeatureId;this.editedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),void 0),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0,t(!0),this.onFinish(n,{mode:this.mode,action:Xe})}cleanUp(){let e=this.currentId,t=this.snappedPointId,n=this.editedPointId;this.currentId=void 0,this.snappedPointId=void 0,this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0,this.currentCoordinate=0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted(),e&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(n),this.mutateFeature.deleteFeatureIfPresent(t),this.closingPoints.ids.length&&this.closingPoints.delete()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.properties.mode===this.mode){if(e.geometry.type===`Polygon`)return t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.zIndex=M,t;if(e.geometry.type===`Point`){let n=e.properties[j.EDITED],r=e.properties[j.COORDINATE_POINT],i=n?`editedPoint`:e.properties[j.CLOSING_POINT]?`closingPoint`:e.properties[j.SNAPPING_POINT]?`snappingPoint`:r?`coordinatePoint`:void 0;if(!i)return t;let a={editedPoint:{width:this.styles.editedPointOutlineWidth,color:this.styles.editedPointColor,opacity:this.styles.editedPointOpacity,outlineColor:this.styles.editedPointOutlineColor,outlineWidth:this.styles.editedPointOutlineWidth,outlineOpacity:this.styles.editedPointOutlineOpacity},closingPoint:{width:this.styles.closingPointWidth,color:this.styles.closingPointColor,opacity:this.styles.closingPointOpacity,outlineColor:this.styles.closingPointOutlineColor,outlineWidth:this.styles.closingPointOutlineWidth,outlineOpacity:this.styles.closingPointOutlineOpacity},snappingPoint:{width:this.styles.snappingPointWidth,color:this.styles.snappingPointColor,opacity:this.styles.snappingPointOpacity,outlineColor:this.styles.snappingPointOutlineColor,outlineWidth:this.styles.snappingPointOutlineWidth,outlineOpacity:this.styles.snappingPointOutlineOpacity},coordinatePoint:{width:this.styles.coordinatePointWidth,color:this.styles.coordinatePointColor,opacity:this.styles.coordinatePointOpacity,outlineColor:this.styles.coordinatePointOutlineColor,outlineWidth:this.styles.coordinatePointOutlineWidth,outlineOpacity:this.styles.coordinatePointOutlineOpacity}};return t.pointWidth=this.getNumericStylingValue(a[i].width,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(a[i].opacity,1,e),t.pointColor=this.getHexColorStylingValue(a[i].color,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(a[i].outlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(a[i].outlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(a[i].outlineWidth,2,e),t.zIndex=n?40:r?20:30,t}}return t}afterFeatureAdded(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})}afterFeatureUpdated(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates}),this.editedFeatureId===e.id&&this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0),this.snappedPointId&&this.lastMouseMoveEvent&&this.updateSnappedCoordinate(this.lastMouseMoveEvent),this.currentId===e.id&&(this.currentCoordinate=0,this.currentId=void 0,this.undoRedo.clear(),this.closingPoints.delete(),this.state===`drawing`&&this.setStarted())}validateFeature(e){return this.validateModeFeature(e,e=>wt(e,this.coordinatePrecision))}},Sn={cancel:`Escape`,finish:`Enter`},Cn={start:`crosshair`},wn=class extends N{constructor(e){super(e,!0),this.mode=`rectangle`,this.startPosition=void 0,this.endPosition=void 0,this.currentRectangleId=void 0,this.keyEvents=Sn,this.cursors=Cn,this.drawInteraction=`click-move`,this.drawType=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.drawInteraction&&(this.drawInteraction=e.drawInteraction)}updateRectangle(e,t){if(!this.startPosition||!this.currentRectangleId)return;let n=t===k.Finish;return this.mutateFeature.updatePolygon({featureId:this.currentRectangleId,coordinateMutations:[{type:V,index:1,coordinate:[e[0],this.startPosition[1]]},{type:V,index:2,coordinate:e},{type:V,index:3,coordinate:[this.startPosition[0],e[1]]}],propertyMutations:n?{[j.CURRENTLY_DRAWING]:void 0}:{},context:n?{updateType:t,action:O}:{updateType:t}})}close(){if(!this.currentRectangleId||!this.endPosition||!this.updateRectangle(this.endPosition,k.Finish))return;let e=this.currentRectangleId;this.startPosition=void 0,this.currentRectangleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}beginDrawing(e,t=`click`){this.startPosition=[e.lng,e.lat],this.endPosition=[e.lng,e.lat],this.currentRectangleId=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}}).id,this.drawType=t,this.setDrawing()}moveDrawAllowed(){return this.drawInteraction===`click-move`||this.drawInteraction===`click-move-or-drag`}dragDrawAllowed(){return this.drawInteraction===`click-drag`||this.drawInteraction===`click-move-or-drag`}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){this.moveDrawAllowed()&&(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))&&(this.startPosition?(this.endPosition=[e.lng,e.lat],this.close()):this.beginDrawing(e))}onMouseMove(e){this.endPosition=[e.lng,e.lat],this.updateRectangle(this.endPosition,k.Provisional)}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onDragStart(e,t){this.state!==`drawing`&&this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&this.dragDrawAllowed()&&(this.beginDrawing(e,`drag`),t(!1))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.endPosition=[e.lng,e.lat],this.updateRectangle(this.endPosition,k.Provisional))}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.endPosition=[e.lng,e.lat],this.close(),t(!0))}cleanUp(){let e=this.currentRectangleId;this.startPosition=void 0,this.currentRectangleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Polygon`&&e.properties.mode===this.mode?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t):t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentRectangleId===e.id&&(this.startPosition=void 0,this.currentRectangleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}},q=class extends N{constructor(e){if(!e.modeName)throw Error(`Mode name is required for TerraDrawRenderMode`);super(e,!0),this.type=it.Render,this.mode=`render`,this.updateOptions(e)}updateOptions(e){super.updateOptions(e)}registerBehaviors(e){this.mode=e.mode}start(){this.setStarted()}stop(){this.setStopped()}onKeyUp(){}onKeyDown(){}onClick(){}onDragStart(){}onDrag(){}onDragEnd(){}onMouseMove(){}cleanUp(){}styleFeature(e){return{pointColor:this.getHexColorStylingValue(this.styles.pointColor,`#3f97e0`,e),pointWidth:this.getNumericStylingValue(this.styles.pointWidth,6,e),pointOpacity:this.getNumericStylingValue(this.styles.pointOpacity,1,e),pointOutlineColor:this.getHexColorStylingValue(this.styles.pointOutlineColor,`#ffffff`,e),pointOutlineWidth:this.getNumericStylingValue(this.styles.pointOutlineWidth,0,e),pointOutlineOpacity:this.getNumericStylingValue(this.styles.pointOutlineOpacity,1,e),polygonFillColor:this.getHexColorStylingValue(this.styles.polygonFillColor,`#3f97e0`,e),polygonFillOpacity:this.getNumericStylingValue(this.styles.polygonFillOpacity,.3,e),polygonOutlineColor:this.getHexColorStylingValue(this.styles.polygonOutlineColor,`#3f97e0`,e),polygonOutlineWidth:this.getNumericStylingValue(this.styles.polygonOutlineWidth,4,e),lineStringWidth:this.getNumericStylingValue(this.styles.lineStringWidth,4,e),lineStringColor:this.getHexColorStylingValue(this.styles.lineStringColor,`#3f97e0`,e),lineStringOpacity:this.getNumericStylingValue(this.styles.lineStringOpacity,1,e),zIndex:this.getNumericStylingValue(this.styles.zIndex,0,e)}}validateFeature(e){let t=super.validateFeature(e);if(t.valid){let t=e,n=hn(t,this.coordinatePrecision).valid||wt(t,this.coordinatePrecision).valid||Jt(t,this.coordinatePrecision).valid;return n?{valid:!0}:{valid:n,reason:`Feature is not a valid Point, Polygon or LineString feature`}}return t}};function Tn(e,t){let n=e,r=t,i=F(n[1]),a=F(r[1]),o=F(r[0]-n[0]);o>Math.PI&&(o-=2*Math.PI),o<-Math.PI&&(o+=2*Math.PI);let s=Math.log(Math.tan(a/2+Math.PI/4)/Math.tan(i/2+Math.PI/4)),c=(lt(Math.atan2(o,s))+360)%360;return c>180?-(360-c):c}function En(e,t,n){let r=t;t<0&&(r=-Math.abs(r));let i=r/st,a=e[0]*Math.PI/180,o=F(e[1]),s=F(n),c=i*Math.cos(s),l=o+c;Math.abs(l)>Math.PI/2&&(l=l>0?Math.PI-l:-Math.PI-l);let u=Math.log(Math.tan(l/2+Math.PI/4)/Math.tan(o/2+Math.PI/4)),d=Math.abs(u)>1e-11?c/u:Math.cos(o),f=[(180*(a+i*Math.sin(s)/d)/Math.PI+540)%360-180,180*l/Math.PI];return f[0]+=f[0]-e[0]>180?-360:e[0]-f[0]>180?360:0,f}function Dn(e,t,n,r,i){let a=r(e[0],e[1]),o=r(t[0],t[1]),{lng:s,lat:c}=i((a.x+o.x)/2,(a.y+o.y)/2);return[I(s,n),I(c,n)]}function On(e,t,n){let r=En(e,1e3*P(e,t)/2,Tn(e,t));return[I(r[0],n),I(r[1],n)]}function kn({featureCoords:e,precision:t,unproject:n,project:r,projection:i}){let a=[];for(let o=0;o<e.length-1;o++){let s;if(i===`web-mercator`)s=Dn(e[o],e[o+1],t,r,n);else{if(i!==`globe`)throw Error(`Invalid projection`);s=On(e[o],e[o+1],t)}a.push(s)}return a}var An=class extends z{constructor(e,t,n,r,i,a){super(e),this.config=void 0,this.selectionPointBehavior=void 0,this.coordinatePointBehavior=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.pixelDistance=void 0,this._midPoints=[],this.config=e,this.selectionPointBehavior=t,this.coordinatePointBehavior=n,this.mutateFeature=r,this.readFeature=i,this.pixelDistance=a}getMidpointConfig(e){return{featureCoords:e,precision:this.coordinatePrecision,project:this.config.project,unproject:this.config.unproject,projection:this.config.projection}}get ids(){return this._midPoints.concat()}set ids(e){}getNearestMidPoint(e){let t,n=1/0;return this.ids.forEach(r=>{let i=this.readFeature.getGeometry(r),a=this.pixelDistance.measure(e,i.coordinates);a<this.pointerDistance&&a<n&&(n=a,t=r)}),t}insert({featureId:e,midPointId:t}){let n=this.readFeature.getGeometry(t),{midPointFeatureId:r,midPointSegment:i}=this.readFeature.getProperties(t),a=this.readFeature.getGeometry(r),o={featureId:r,coordinateMutations:[{type:B,index:i,coordinate:n.coordinates}],context:{updateType:k.Commit}},s=null;if(a.type===`Polygon`)s=this.mutateFeature.updatePolygon(o);else{if(a.type!==`LineString`)throw Error(`Midpoints can only be added to polygons or linestrings`);s=this.mutateFeature.updateLineString(o)}if(!s)throw Error(`Failed to insert midpoint coordinate`);let c=s.geometry.coordinates;this.readFeature.getProperties(e)[j.COORDINATE_POINT_IDS]&&this.coordinatePointBehavior.createOrUpdate({featureId:e,featureCoordinates:c}),this.mutateFeature.deleteFeaturesIfPresent([...this.selectionPointBehavior.ids,...this._midPoints]),this.create({featureCoordinates:c,featureId:r}),this.selectionPointBehavior.create({featureCoordinates:c,featureId:e})}create({featureCoordinates:e,featureId:t}){if(!this.readFeature.hasFeature(t))throw Error(`Store does not have feature with this id`);let n=an(e),r=kn(this.getMidpointConfig(n));this._midPoints=this.mutateFeature.createGuidancePoints({additionalProperties:e=>({mode:this.mode,midPointSegment:e,midPointFeatureId:t,[A.MID_POINT]:!0}),coordinates:r,type:A.MID_POINT})}delete(){this._midPoints.length&&(this.mutateFeature.deleteFeaturesIfPresent(this._midPoints),this._midPoints=[])}updateAllInPlace({featureCoordinates:e}){if(this._midPoints.length===0)return;let t=an(e),n=kn(this.getMidpointConfig(t));this.mutateFeature.updateGuidancePoints(this._midPoints.map((e,t)=>({featureId:e,coordinate:n[t]})))}updateOneAtIndex(e,t){if(e<0&&(e=this._midPoints.length+e),this._midPoints[e]===void 0)return;let n=an(t),r=kn(this.getMidpointConfig(n));this.mutateFeature.updateGuidancePoints([{featureId:this._midPoints[e],coordinate:r[e]}])}},jn=class extends z{constructor(e,t){super(e),this.mutateFeature=void 0,this._selectionPoints=[],this.mutateFeature=t}get ids(){return this._selectionPoints.concat()}set ids(e){}create({featureId:e,featureCoordinates:t}){let n=rn(t);this._selectionPoints=this.mutateFeature.createGuidancePoints({coordinates:n,type:A.SELECTION_POINT,additionalProperties:t=>({[A.SELECTION_POINT_FEATURE_ID]:e,index:t})})}delete(){this.ids.length&&(this.mutateFeature.deleteFeaturesIfPresent(this.ids),this._selectionPoints=[])}updateAllInPlace({featureCoordinates:e}){if(this._selectionPoints.length===0)return;let t=rn(e);t.length===this._selectionPoints.length&&this.mutateFeature.updateGuidancePoints(this._selectionPoints.map((e,n)=>({featureId:e,coordinate:t[n]})))}updateOneAtIndex(e,t){this._selectionPoints[e]!==void 0&&this.mutateFeature.updateGuidancePoints([{featureId:this._selectionPoints[e],coordinate:t}])}};function Mn(e,t){let n=!1;for(let o=0,s=t.length;o<s;o++){let s=t[o];for(let t=0,o=s.length,c=o-1;t<o;c=t++)(i=s[t])[1]>(r=e)[1]!=(a=s[c])[1]>r[1]&&r[0]<(a[0]-i[0])*(r[1]-i[1])/(a[1]-i[1])+i[0]&&(n=!n)}var r,i,a;return n}var Nn=(e,t,n)=>{let r=e=>e*e,i=(e,t)=>r(e.x-t.x)+r(e.y-t.y);return Math.sqrt(((e,t,n)=>{let r=i(t,n);if(r===0)return i(e,t);let a=((e.x-t.x)*(n.x-t.x)+(e.y-t.y)*(n.y-t.y))/r;return a=Math.max(0,Math.min(1,a)),i(e,{x:t.x+a*(n.x-t.x),y:t.y+a*(n.y-t.y)})})(e,t,n))},Pn=class extends z{constructor(e,t,n){super(e),this.config=void 0,this.createClickBoundingBox=void 0,this.pixelDistance=void 0,this.config=e,this.createClickBoundingBox=t,this.pixelDistance=n}find(e,t){let n,r,i,a=1/0,o=1/0,s=this.createClickBoundingBox.create(e),c=this.store.search(s);for(let s=0;s<c.length;s++){let l=c[s],u=l.geometry;if(u.type===`Point`){if(l.properties.selectionPoint||l.properties.coordinatePoint||!t&&l.properties[A.MID_POINT])continue;let r=this.pixelDistance.measure(e,u.coordinates);!l.properties[A.MID_POINT]&&r<this.pointerDistance&&r<a&&(a=r,n=l)}else if(u.type===`LineString`){if(n)continue;for(let t=0;t<u.coordinates.length-1;t++){let n=u.coordinates[t],i=u.coordinates[t+1],a=Nn({x:e.containerX,y:e.containerY},this.project(n[0],n[1]),this.project(i[0],i[1]));a<this.pointerDistance&&a<o&&(o=a,r=l)}}else if(u.type===`Polygon`){if(n||r)continue;Mn([e.lng,e.lat],u.coordinates)&&(i=l)}}return{clickedFeature:n||r||i}}},Fn=class extends z{constructor(e,t,n,r,i,a,o){super(e),this.config=void 0,this.featuresAtCursorEvent=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.draggedFeatureId=null,this.dragPosition=void 0,this.config=e,this.featuresAtCursorEvent=t,this.selectionPoints=n,this.midPoints=r,this.coordinatePoints=i,this.readFeature=a,this.mutateFeature=o}startDragging(e,t){this.draggedFeatureId=t,this.dragPosition=[e.lng,e.lat]}stopDragging(){this.draggedFeatureId=null,this.dragPosition=void 0}isDragging(){return this.draggedFeatureId!==null}canDrag(e,t){let{clickedFeature:n}=this.featuresAtCursorEvent.find(e,!0);return!(!n||n.id!==t)}drag(e){if(!this.draggedFeatureId)return;let t=this.readFeature.getGeometry(this.draggedFeatureId),n=[e.lng,e.lat];if(t.type===`Polygon`||t.type===`LineString`){let r,i;if(t.type===`Polygon`?(r=t.coordinates[0],i=r.length-1):(r=t.coordinates,i=r.length),!this.dragPosition)return!1;for(let e=0;e<i;e++){let t=r[e],i,a;if(this.config.projection===`web-mercator`){let e=L(this.dragPosition[0],this.dragPosition[1]),r=L(n[0],n[1]),o=L(t[0],t[1]),s={x:e.x-r.x,y:e.y-r.y},{lng:c,lat:l}=R(o.x-s.x,o.y-s.y);i=c,a=l}else{let e=[this.dragPosition[0]-n[0],this.dragPosition[1]-n[1]];i=t[0]-e[0],a=t[1]-e[1]}if(i=I(i,this.config.coordinatePrecision),a=I(a,this.config.coordinatePrecision),i>180||i<-180||a>90||a<-90)return!1;r[e]=[i,a]}t.type===`Polygon`&&(r[r.length-1]=[r[0][0],r[0][1]]);let a=this.draggedFeatureId,o=null;if(t.type===`Polygon`)o=this.mutateFeature.updatePolygon({featureId:a,coordinateMutations:{type:H,coordinates:[r]},context:{updateType:k.Provisional}});else{if(t.type!==`LineString`)return;o=this.mutateFeature.updateLineString({featureId:a,coordinateMutations:{type:H,coordinates:r},context:{updateType:k.Provisional}})}if(!o)return!1;let s=o.geometry.coordinates;this.midPoints.updateAllInPlace({featureCoordinates:s}),this.selectionPoints.updateAllInPlace({featureCoordinates:s}),this.coordinatePoints.updateAllInPlace({featureId:a,featureCoordinates:s}),this.dragPosition=[e.lng,e.lat]}else t.type===`Point`&&(this.mutateFeature.updatePoint({featureId:this.draggedFeatureId,coordinateMutations:{type:H,coordinates:n},context:{updateType:k.Provisional}}),this.dragPosition=[e.lng,e.lat])}},In=class extends z{constructor(e,t,n,r,i,a,o,s,c){super(e),this.config=void 0,this.pixelDistance=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.coordinateSnapping=void 0,this.lineSnapping=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.draggedCoordinate={id:null,index:-1},this.config=e,this.pixelDistance=t,this.selectionPoints=n,this.midPoints=r,this.coordinatePoints=i,this.coordinateSnapping=a,this.lineSnapping=o,this.readFeature=s,this.mutateFeature=c}getClosestCoordinate(e,t){let n={dist:1/0,index:-1,isFirstOrLastPolygonCoord:!1},r;if(t.type===`LineString`)r=t.coordinates;else{if(t.type!==`Polygon`)return n;r=t.coordinates[0]}for(let i=0;i<r.length;i++){let a=this.pixelDistance.measure(e,r[i]);if(a<this.pointerDistance&&a<n.dist){let e=t.type===`Polygon`&&(i===r.length-1||i===0);n.dist=a,n.index=e?0:i,n.isFirstOrLastPolygonCoord=e}}return n}getDraggable(e,t){let n=this.readFeature.getGeometry(t);return this.getClosestCoordinate(e,n)}getDraggableIndex(e,t){let n=this.readFeature.getGeometry(t),r=this.getClosestCoordinate(e,n);return r.index===-1?-1:r.index}snapCoordinate(e,t,n){let r=[e.lng,e.lat],i=e=>!!(e.properties&&e.properties.mode===n.properties.mode&&e.id!==this.draggedCoordinate.id);if(t!=null&&t.toLine){let t;t=this.lineSnapping.getSnappable(e,i).coordinate,t&&(r=t)}if(t.toCoordinate){let t;t=this.coordinateSnapping.getSnappable(e,i).coordinate,t&&(r=t)}if(t!=null&&t.toCustom){let i;i=t.toCustom(e,{currentCoordinate:this.draggedCoordinate.index,currentId:n.id,getCurrentGeometrySnapshot:n.id?()=>this.readFeature.getGeometry(n.id):()=>null,project:this.project,unproject:this.unproject}),i&&(r=i)}return r}drag(e,t,n){let r=this.draggedCoordinate.id;if(r===null)return!1;let i=this.draggedCoordinate.index,a=this.readFeature.getGeometry(r),o=this.readFeature.getProperties(r),s=a.type===`LineString`?a.coordinates:a.coordinates[0],c=a.type===`Polygon`&&(i===s.length-1||i===0),l=this.snapCoordinate(e,n,{type:`Feature`,id:r,geometry:a,properties:o});if(e.lng>180||e.lng<-180||e.lat>90||e.lat<-90)return!1;if(c){let e=s.length-1;s[0]=l,s[e]=l}else s[i]=l;if(a.type!==`Point`&&!t&&ht({type:`Feature`,geometry:a,properties:{}}))return!1;let u=r,d=null;return a.type===`Polygon`?d=this.mutateFeature.updatePolygon({featureId:u,coordinateMutations:{type:H,coordinates:[s]},context:{updateType:k.Provisional}}):a.type===`LineString`&&(d=this.mutateFeature.updateLineString({featureId:u,coordinateMutations:{type:H,coordinates:s},context:{updateType:k.Provisional}})),!!d&&(this.midPoints.updateOneAtIndex(i>0?i-1:-1,s),this.midPoints.updateOneAtIndex(i,s),this.selectionPoints.updateOneAtIndex(i,l),this.coordinatePoints.updateOneAtIndex(u,i,l),!0)}isDragging(){return this.draggedCoordinate.id!==null}startDragging(e,t){this.draggedCoordinate={id:e,index:t}}stopDragging(){this.draggedCoordinate={id:null,index:-1}}};function Ln(e){let t=0,n=0,r=0;return(e.geometry.type===`Polygon`?e.geometry.coordinates[0].slice(0,-1):e.geometry.coordinates).forEach(e=>{t+=e[0],n+=e[1],r++},!0),[t/r,n/r]}var Rn=(e,t)=>{if(t===0||t===360||t===-360)return e;let n=.017453292519943295*t,r=(e.geometry.type===`Polygon`?e.geometry.coordinates[0]:e.geometry.coordinates).map(([e,t])=>L(e,t)),i=r.reduce((e,t)=>({x:e.x+t.x,y:e.y+t.y}),{x:0,y:0});i.x/=r.length,i.y/=r.length;let a=r.map(e=>({x:i.x+(e.x-i.x)*Math.cos(n)-(e.y-i.y)*Math.sin(n),y:i.y+(e.x-i.x)*Math.sin(n)+(e.y-i.y)*Math.cos(n)})).map(({x:e,y:t})=>[R(e,t).lng,R(e,t).lat]);return e.geometry.type===`Polygon`?e.geometry.coordinates[0]=a:e.geometry.coordinates=a,e};function zn(e){let t=(e.geometry.type===`Polygon`?e.geometry.coordinates[0]:e.geometry.coordinates).map(e=>{let{x:t,y:n}=L(e[0],e[1]);return[t,n]});return e.geometry.type===`Polygon`?function(e){let t=0,n=0,r=0,i=e.length;for(let a=0;a<i-1;a++){let[i,o]=e[a],[s,c]=e[a+1],l=i*c-s*o;t+=l,n+=(i+s)*l,r+=(o+c)*l}return t/=2,n/=6*t,r/=6*t,{x:n,y:r}}(t):function(e){let t=e.length,n=0,r=0;for(let i=0;i<t;i++){let[t,a]=e[i];n+=t,r+=a}return{x:n/t,y:r/t}}(t)}var Bn=class extends z{constructor(e,t,n,r,i,a){super(e),this.config=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.lastBearing=void 0,this.selectedGeometry=void 0,this.selectedGeometryCentroid=void 0,this.selectedGeometryWebMercatorCentroid=void 0,this.config=e,this.selectionPoints=t,this.midPoints=n,this.coordinatePoints=r,this.readFeature=i,this.mutateFeature=a}reset(){this.lastBearing=void 0,this.selectedGeometry=void 0,this.selectedGeometryWebMercatorCentroid=void 0,this.selectedGeometryCentroid=void 0}rotate(e,t){this.selectedGeometry||=this.readFeature.getGeometry(t);let n=this.selectedGeometry;if(n.type!==`Polygon`&&n.type!==`LineString`)return;let r=[e.lng,e.lat],i,a={type:`Feature`,geometry:n,properties:{}};if(this.config.projection===`web-mercator`){this.selectedGeometryWebMercatorCentroid||=zn(a);let t=L(e.lng,e.lat);if(i=K(this.selectedGeometryWebMercatorCentroid,t),i===0)return;if(!this.lastBearing)return void(this.lastBearing=i);Rn(a,-(this.lastBearing-i))}else{if(this.config.projection!==`globe`)throw Error(`Unsupported projection`);if(this.selectedGeometryCentroid||=Ln({type:`Feature`,geometry:n,properties:{}}),i=Tn(this.selectedGeometryCentroid,r),!this.lastBearing)return void(this.lastBearing=i+180);(function(e,t){if(t===0||t===360||t===-360)return e;let n=Ln(e);(e.geometry.type===`Polygon`?e.geometry.coordinates[0]:e.geometry.coordinates).forEach(e=>{let r=Tn(n,e)+t,i=En(n,function(e,t){e[0]+=e[0]-t[0]>180?-360:t[0]-e[0]>180?360:0;let n=st,r=t[1]*Math.PI/180,i=e[1]*Math.PI/180,a=i-r,o=Math.abs(e[0]-t[0])*Math.PI/180;o>Math.PI&&(o-=2*Math.PI);let s=Math.log(Math.tan(i/2+Math.PI/4)/Math.tan(r/2+Math.PI/4)),c=Math.abs(s)>1e-11?a/s:Math.cos(r);return Math.sqrt(a*a+c*c*o*o)*n}(n,e),r);e[0]=i[0],e[1]=i[1]})})(a,-(this.lastBearing-(i+180)))}let o=n.type===`Polygon`?n.coordinates[0]:n.coordinates;o.forEach(e=>{e[0]=I(e[0],this.coordinatePrecision),e[1]=I(e[1],this.coordinatePrecision)});let s={featureId:t,coordinateMutations:{type:H,coordinates:n.type===`Polygon`?[o]:o},context:{updateType:k.Provisional}},c=null;if(a.geometry.type===`Polygon`)c=this.mutateFeature.updatePolygon(s);else{if(a.geometry.type!==`LineString`)return;c=this.mutateFeature.updateLineString(s)}if(!c)return!1;let l=c.geometry.coordinates;this.midPoints.updateAllInPlace({featureCoordinates:l}),this.selectionPoints.updateAllInPlace({featureCoordinates:l}),this.coordinatePoints.updateAllInPlace({featureId:t,featureCoordinates:l}),this.projection===`web-mercator`?this.lastBearing=i:this.projection===`globe`&&(this.lastBearing=i+180)}},Vn=class extends z{constructor(e,t){super(e),this.config=void 0,this.dragCoordinateResizeBehavior=void 0,this.config=e,this.dragCoordinateResizeBehavior=t}scale(e,t){if(!this.dragCoordinateResizeBehavior.isDragging()){let n=this.dragCoordinateResizeBehavior.getDraggableIndex(e,t);this.dragCoordinateResizeBehavior.startDragging(t,n)}this.dragCoordinateResizeBehavior.drag(e,`center-fixed`)}reset(){this.dragCoordinateResizeBehavior.stopDragging()}};function Hn({coordinates:e,originX:t,originY:n,xScale:r,yScale:i}){r===1&&i===1||e.forEach(e=>{let{x:a,y:o}=L(e[0],e[1]),{lng:s,lat:c}=R(t+(a-t)*r,n+(o-n)*i);e[0]=s,e[1]=c})}var Un=class extends z{constructor(e,t,n,r,i,a,o){super(e),this.config=void 0,this.pixelDistance=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.minimumScale=1e-4,this.draggedCoordinate={id:null,index:-1},this.boundingBoxMaps={opposite:{0:4,1:5,2:6,3:7,4:0,5:1,6:2,7:3}},this.config=e,this.pixelDistance=t,this.selectionPoints=n,this.midPoints=r,this.coordinatePoints=i,this.readFeature=a,this.mutateFeature=o}getClosestCoordinate(e,t){let n={dist:1/0,index:-1,isFirstOrLastPolygonCoord:!1},r;if(t.type===`LineString`)r=t.coordinates;else{if(t.type!==`Polygon`)return n;r=t.coordinates[0]}for(let i=0;i<r.length;i++){let a=this.pixelDistance.measure(e,r[i]);if(a<this.pointerDistance&&a<n.dist){let e=t.type===`Polygon`&&(i===r.length-1||i===0);n.dist=a,n.index=e?0:i,n.isFirstOrLastPolygonCoord=e}}return n}isValidDragWebMercator(e,t,n){switch(e){case 0:if(t<=0||n>=0)return!1;break;case 1:if(n>=0)return!1;break;case 2:if(t>=0||n>=0)return!1;break;case 3:if(t>=0)return!1;break;case 4:if(t>=0||n<=0)return!1;break;case 5:if(n<=0)return!1;break;case 6:if(t<=0||n<=0)return!1;break;case 7:if(t<=0)return!1}return!0}getSelectedFeatureDataWebMercator(){if(!this.draggedCoordinate.id||this.draggedCoordinate.index===-1)return null;let e=this.getFeature(this.draggedCoordinate.id);if(!e)return null;let t=this.getNormalisedCoordinates(e.geometry);return{boundingBox:this.getBBoxWebMercator(t),feature:e,updatedCoords:t,selectedCoordinate:t[this.draggedCoordinate.index]}}centerWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{feature:n,boundingBox:r,updatedCoords:i,selectedCoordinate:a}=t,o=zn(n);if(!o)return null;let s=L(a[0],a[1]),{closestBBoxIndex:c}=this.getIndexesWebMercator(r,s),l=L(e.lng,e.lat);return this.scaleWebMercator({closestBBoxIndex:c,updatedCoords:i,webMercatorCursor:l,webMercatorSelected:s,webMercatorOrigin:o}),i}centerFixedWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{feature:n,boundingBox:r,updatedCoords:i,selectedCoordinate:a}=t,o=zn(n);if(!o)return null;let s=L(a[0],a[1]),{closestBBoxIndex:c}=this.getIndexesWebMercator(r,s),l=L(e.lng,e.lat);return this.scaleFixedWebMercator({closestBBoxIndex:c,updatedCoords:i,webMercatorCursor:l,webMercatorSelected:s,webMercatorOrigin:o}),i}scaleFixedWebMercator({closestBBoxIndex:e,webMercatorOrigin:t,webMercatorSelected:n,webMercatorCursor:r,updatedCoords:i}){if(!this.isValidDragWebMercator(e,t.x-r.x,t.y-r.y))return null;let a=W(t,r)/W(t,n);return a<0&&(a=this.minimumScale),Hn({coordinates:i,originX:t.x,originY:t.y,xScale:a,yScale:a}),i}oppositeFixedWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{boundingBox:n,updatedCoords:r,selectedCoordinate:i}=t,a=L(i[0],i[1]),{oppositeBboxIndex:o,closestBBoxIndex:s}=this.getIndexesWebMercator(n,a),c={x:n[o][0],y:n[o][1]},l=L(e.lng,e.lat);return this.scaleFixedWebMercator({closestBBoxIndex:s,updatedCoords:r,webMercatorCursor:l,webMercatorSelected:a,webMercatorOrigin:c}),r}oppositeWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{boundingBox:n,updatedCoords:r,selectedCoordinate:i}=t,a=L(i[0],i[1]),{oppositeBboxIndex:o,closestBBoxIndex:s}=this.getIndexesWebMercator(n,a),c={x:n[o][0],y:n[o][1]},l=L(e.lng,e.lat);return this.scaleWebMercator({closestBBoxIndex:s,updatedCoords:r,webMercatorCursor:l,webMercatorSelected:a,webMercatorOrigin:c}),r}scaleWebMercator({closestBBoxIndex:e,webMercatorOrigin:t,webMercatorSelected:n,webMercatorCursor:r,updatedCoords:i}){let a=t.x-r.x,o=t.y-r.y;if(!this.isValidDragWebMercator(e,a,o))return null;let s=1;a!==0&&e!==1&&e!==5&&(s=1-(t.x-n.x-a)/a);let c=1;return o!==0&&e!==3&&e!==7&&(c=1-(t.y-n.y-o)/o),this.validateScale(s,c)?(s<0&&(s=this.minimumScale),c<0&&(c=this.minimumScale),this.performWebMercatorScale(i,t.x,t.y,s,c),i):null}getFeature(e){if(this.draggedCoordinate.id===null)return null;let t=this.readFeature.getGeometry(e);return t.type!==`Polygon`&&t.type!==`LineString`?null:{id:e,type:`Feature`,geometry:t,properties:{}}}getNormalisedCoordinates(e){return e.type===`Polygon`?e.coordinates[0]:e.coordinates}validateScale(e,t){return!isNaN(e)&&t<2**53-1&&!isNaN(t)&&t<2**53-1}performWebMercatorScale(e,t,n,r,i){e.forEach(e=>{let{x:a,y:o}=L(e[0],e[1]),{lng:s,lat:c}=R(t+(a-t)*r,n+(o-n)*i);e[0]=s,e[1]=c})}getBBoxWebMercator(e){let t=[1/0,1/0,-1/0,-1/0];(e=e.map(e=>{let{x:t,y:n}=L(e[0],e[1]);return[t,n]})).forEach(([e,n])=>{e<t[0]&&(t[0]=e),n<t[1]&&(t[1]=n),e>t[2]&&(t[2]=e),n>t[3]&&(t[3]=n)});let[n,r,i,a]=t;return[[n,a],[(n+i)/2,a],[i,a],[i,a+(r-a)/2],[i,r],[(n+i)/2,r],[n,r],[n,a+(r-a)/2]]}getIndexesWebMercator(e,t){let n,r=1/0;for(let i=0;i<e.length;i++){let a=W({x:t.x,y:t.y},{x:e[i][0],y:e[i][1]});a<r&&(n=i,r=a)}if(n===void 0)throw Error(`No closest coordinate found`);return{oppositeBboxIndex:this.boundingBoxMaps.opposite[n],closestBBoxIndex:n}}isDragging(){return this.draggedCoordinate.id!==null}startDragging(e,t){this.draggedCoordinate={id:e,index:t}}stopDragging(){this.draggedCoordinate={id:null,index:-1}}getDraggableIndex(e,t){let n=this.readFeature.getGeometry(t),r=this.getClosestCoordinate(e,n);return r.index===-1?-1:r.index}drag(e,t){if(!this.draggedCoordinate.id)return!1;let n=this.getFeature(this.draggedCoordinate.id);if(!n)return!1;let r=null;if(t===`center`?r=this.centerWebMercatorDrag(e):t===`opposite`?r=this.oppositeWebMercatorDrag(e):t===`center-fixed`?r=this.centerFixedWebMercatorDrag(e):t===`opposite-fixed`&&(r=this.oppositeFixedWebMercatorDrag(e)),!r)return!1;for(let e=0;e<r.length;e++){let t=r[e];if(t[0]=I(t[0],this.coordinatePrecision),t[1]=I(t[1],this.coordinatePrecision),!_t(t,this.coordinatePrecision))return!1}let i=n.id,a=null;if(n.geometry.type===`Polygon`?a=this.mutateFeature.updatePolygon({featureId:i,coordinateMutations:{type:H,coordinates:[r]},context:{updateType:k.Provisional}}):n.geometry.type===`LineString`&&(a=this.mutateFeature.updateLineString({featureId:i,coordinateMutations:{type:H,coordinates:r},context:{updateType:k.Provisional}})),!a)return!1;let o=a.geometry.coordinates;return this.midPoints.updateAllInPlace({featureCoordinates:o}),this.selectionPoints.updateAllInPlace({featureCoordinates:o}),this.coordinatePoints.updateAllInPlace({featureId:i,featureCoordinates:o}),!0}},Wn={deselect:`Escape`,delete:`Delete`,rotate:[`Control`,`r`],scale:[`Control`,`s`]},Gn={pointerOver:`move`,dragStart:`move`,dragEnd:`move`,insertMidpoint:`crosshair`},Kn=class extends ot{constructor(e){super(e,!0),this.mode=`select`,this.allowManualDeselection=!0,this.allowManualSelection=!0,this.dragEventThrottle=5,this.dragEventCount=0,this.selected=[],this.flags={},this.keyEvents=Wn,this.cursors=Gn,this.validations={},this.dragTarget={type:`none`},this.selectionPoints=void 0,this.midPoints=void 0,this.coordinateSnap=void 0,this.featuresAtMouseEvent=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.dragFeature=void 0,this.dragCoordinate=void 0,this.rotateFeature=void 0,this.scaleFeature=void 0,this.dragCoordinateResizeFeature=void 0,this.coordinatePoints=void 0,this.lineSnap=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){if(super.updateOptions(e),this.cursors=e&&e.cursors?D({},this.cursors,e.cursors):Gn,e?.keyEvents===null?this.keyEvents={deselect:null,delete:null,rotate:null,scale:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e?.dragEventThrottle!==void 0&&(this.dragEventThrottle=e.dragEventThrottle),e?.allowManualDeselection!==void 0&&(this.allowManualDeselection=e.allowManualDeselection),e?.allowManualSelection!==void 0&&(this.allowManualSelection=e.allowManualSelection),e!=null&&e.flags){this.flags=D({},this.flags,e.flags),this.validations={};for(let e in this.flags){let t=this.flags[e].feature;t&&t.validation&&(this.validations[e]=t.validation)}}}selectFeature(e){this.select(e,!1)}setSelecting(){if(this._state!==`started`)throw Error(`Mode must be started to move to selecting state`);this._state=`selecting`}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:(e,t)=>{let n=e.properties.mode;return this.validations&&this.validations[n]?this.validations[n](e,t):{valid:!0}}}),this.pixelDistance=new Rt(e),this.clickBoundingBox=new Lt(e),this.featuresAtMouseEvent=new Pn(e,this.clickBoundingBox,this.pixelDistance),this.selectionPoints=new jn(e,this.mutateFeature),this.coordinatePoints=new sn(e,this.readFeature,this.mutateFeature),this.midPoints=new An(e,this.selectionPoints,this.coordinatePoints,this.mutateFeature,this.readFeature,this.pixelDistance),this.coordinateSnap=new zt(e,this.pixelDistance,this.clickBoundingBox),this.lineSnap=new tn(e,this.pixelDistance,this.clickBoundingBox),this.rotateFeature=new Bn(e,this.selectionPoints,this.midPoints,this.coordinatePoints,this.readFeature,this.mutateFeature),this.dragFeature=new Fn(e,this.featuresAtMouseEvent,this.selectionPoints,this.midPoints,this.coordinatePoints,this.readFeature,this.mutateFeature),this.dragCoordinate=new In(e,this.pixelDistance,this.selectionPoints,this.midPoints,this.coordinatePoints,this.coordinateSnap,this.lineSnap,this.readFeature,this.mutateFeature),this.dragCoordinateResizeFeature=new Un(e,this.pixelDistance,this.selectionPoints,this.midPoints,this.coordinatePoints,this.readFeature,this.mutateFeature),this.scaleFeature=new Vn(e,this.dragCoordinateResizeFeature)}deselectFeature(e){this.deselect(e)}deselect(e){this.selected.includes(e)&&(this.mutateFeature.setDeselected(this.selected),this.onDeselect(this.selected[0]),this.selected=[],this.selectionPoints.delete(),this.midPoints.delete(),this.dragTarget={type:`none`})}deleteSelected(){this.selected.length&&this.mutateFeature.deleteFeaturesIfPresent(this.selected),this.selected=[],this.dragTarget={type:`none`}}clearDragTargetAndCursor(){this.dragTarget={type:`none`},this.setCursor(`unset`)}getSelectedFlags(e){let t=this.readFeature.getProperties(e),n=this.flags[t.mode]?.feature,r=n?.coordinates;return{featureFlags:n,coordinatesFlags:r,hasDraggableFlags:n&&(n.draggable||r?.draggable||r?.resizable||typeof r?.midpoints==`object`&&r.midpoints.draggable)}}onRightClick(e){if(!this.selectionPoints.ids.length)return;let t,n=1/0;if(this.selectionPoints.ids.forEach(r=>{let i=this.readFeature.getGeometry(r),a=this.pixelDistance.measure(e,i.coordinates);a<this.pointerDistance&&a<n&&(n=a,t=this.readFeature.getProperties(r))}),!t)return;let r=t.selectionPointFeatureId,i=t.index,a=this.readFeature.getProperties(r),o=this.flags[a.mode];if(!(o&&o.feature&&o.feature.coordinates&&o.feature.coordinates.deletable))return;let s=this.readFeature.getGeometry(r),c;if(s.type===`Polygon`){if(c=s.coordinates[0],c.length<=4)return}else if(s.type!==`LineString`||(c=s.coordinates,c.length<=2))return;s.type!==`Polygon`||i!==0&&i!==c.length-1?c.splice(i,1):(c.shift(),c.pop(),c.push([c[0][0],c[0][1]]));let l=null;if(s.type===`Polygon`?l=this.mutateFeature.updatePolygon({featureId:r,coordinateMutations:{type:H,coordinates:[c]},context:{updateType:k.Commit}}):s.type===`LineString`&&(l=this.mutateFeature.updateLineString({featureId:r,coordinateMutations:{type:H,coordinates:c},context:{updateType:k.Commit}})),!l)return;let u=l.geometry.coordinates;this.mutateFeature.deleteFeaturesIfPresent([...this.midPoints.ids,...this.selectionPoints.ids]),a.coordinatePointIds&&this.coordinatePoints.createOrUpdate({featureId:r,featureCoordinates:u}),this.selectionPoints.create({featureCoordinates:u,featureId:r}),o&&o.feature&&o.feature.coordinates&&o.feature.coordinates.midpoints&&this.midPoints.create({featureCoordinates:u,featureId:r}),this.onFinish(r,{action:Ze,mode:this.mode})}select(e,t=!0){if(this.selected[0]===e)return;let{mode:n}=this.readFeature.getProperties(e),r=this.flags[n];if(!r||!r.feature)return;let i=this.selected[0];if(i){if(i===e)return;this.deselect(i)}t&&this.setCursor(this.cursors.pointerOver),this.selected=[e],this.mutateFeature.setSelected(e),this.onSelect(e);let{type:a,coordinates:o}=this.readFeature.getGeometry(e);a!==`LineString`&&a!==`Polygon`||o&&r&&r.feature.coordinates&&(this.selectionPoints.create({featureCoordinates:o,featureId:e}),r.feature.coordinates.midpoints&&this.midPoints.create({featureCoordinates:o,featureId:e}))}onLeftClick(e){let{clickedFeature:t}=this.featuresAtMouseEvent.find(e,this.selected.length>0),n=this.midPoints.getNearestMidPoint(e),r=this.selected[0];if(r){var i;let{featureFlags:t}=this.getSelectedFlags(r);if(t!=null&&(i=t.coordinates)!=null&&i.midpoints&&n){if(t.coordinates.draggable){let t=this.pixelDistance.measure(e,this.readFeature.getGeometry(n).coordinates),{dist:i}=this.dragCoordinate.getDraggable(e,r);if(i!==void 0&&t>i)return}this.midPoints.insert({featureId:r,midPointId:n}),this.onFinish(this.selected[0],{action:Qe,mode:this.mode});return}}if(t!=null&&t.id)this.allowManualSelection&&this.select(t.id,!0);else if(this.selected.length&&this.allowManualDeselection)return void this.deselect(this.selected[0])}start(){this.setStarted(),this.setSelecting()}stop(){this.cleanUp(),this.setStarted(),this.setStopped()}onClick(e){e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}canScale(e){return this.keyEvents.scale&&this.keyEvents.scale.every(t=>e.heldKeys.includes(t))}canRotate(e){return this.keyEvents.rotate&&this.keyEvents.rotate.every(t=>e.heldKeys.includes(t))}preventDefaultKeyEvent(e){let t=this.canRotate(e),n=this.canScale(e);(t||n)&&e.preventDefault()}onKeyDown(e){this.preventDefaultKeyEvent(e)}onKeyUp(e){if(this.preventDefaultKeyEvent(e),this.keyEvents.delete&&e.key===this.keyEvents.delete){if(!this.selected.length)return;let e=this.selected[0];this.onDeselect(this.selected[0]),this.coordinatePoints.deletePointsByFeatureIds([e]),this.deleteSelected(),this.selectionPoints.delete(),this.midPoints.delete()}else this.keyEvents.deselect&&e.key===this.keyEvents.deselect&&this.cleanUp()}cleanUp(){this.selected.length&&this.deselect(this.selected[0])}onDragStart(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragStart,e))return;let n=this.selected[0];if(!n)return;let{featureFlags:r,coordinatesFlags:i,hasDraggableFlags:a}=this.getSelectedFlags(n);if(!a)return;this.dragEventCount=0;let o=this.dragTarget.type!==`none`&&this.dragTarget.featureId===n?this.dragTarget:{type:`none`},s=o.type===`coordinate`?o.coordinateIndex:this.dragCoordinate.getDraggableIndex(e,n),c=o.type===`resize`?o.coordinateIndex:this.dragCoordinateResizeFeature.getDraggableIndex(e,n),l=i?.resizable&&c!==-1,u=i?.draggable&&s!==-1,d=i&&typeof i.midpoints==`object`&&i.midpoints.draggable,f=r?.draggable&&(o.type===`feature`||this.dragFeature.canDrag(e,n));if(l)return this.setCursor(this.cursors.dragStart),this.dragCoordinateResizeFeature.startDragging(n,c),void t(!1);if(u)return this.setCursor(this.cursors.dragStart),this.dragCoordinate.startDragging(n,s),void t(!1);if(d){let r=o.type===`midpoint`?o.midPointId:this.midPoints.getNearestMidPoint(e);if(this.selected.length&&r){this.midPoints.insert({featureId:n,midPointId:r}),this.onFinish(this.selected[0],{action:Qe,mode:this.mode});let i=this.dragCoordinate.getDraggableIndex(e,n);this.dragCoordinate.startDragging(n,i),t(!1);return}}if(f)return this.setCursor(this.cursors.dragStart),this.dragFeature.startDragging(e,n),void t(!1);this.setCursor(`unset`)}onDrag(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDrag,e))return;let n=this.selected[0];if(!n)return;let r=this.readFeature.getProperties(n),i=this.flags[r.mode],a=!0===(i&&i.feature&&i.feature.selfIntersectable);if(this.dragEventCount++,this.dragEventCount%this.dragEventThrottle!=0){if(i&&i.feature&&i.feature.rotateable&&this.canRotate(e))return t(!1),void this.rotateFeature.rotate(e,n);if(i&&i.feature&&i.feature.scaleable&&this.canScale(e))return t(!1),void this.scaleFeature.scale(e,n);if(this.dragCoordinateResizeFeature.isDragging()&&i.feature&&i.feature.coordinates&&i.feature.coordinates.resizable){if(this.projection===`globe`)throw Error(`Globe is currently unsupported projection for resizable`);t(!1),this.dragCoordinateResizeFeature.drag(e,i.feature.coordinates.resizable);return}if(this.dragCoordinate.isDragging()){var o;let t=(o=i.feature)==null||(o=o.coordinates)==null?void 0:o.snappable,n={toCoordinate:!1};!0===t?n={toCoordinate:!0}:typeof t==`object`&&(n=t),this.dragCoordinate.drag(e,a,n);return}this.dragFeature.isDragging()?this.dragFeature.drag(e):t(!0)}}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&(this.setCursor(this.cursors.dragEnd),this.dragCoordinate.isDragging()?this.onFinish(this.selected[0],{mode:this.mode,action:`dragCoordinate`}):this.dragFeature.isDragging()?this.onFinish(this.selected[0],{mode:this.mode,action:`dragFeature`}):this.dragCoordinateResizeFeature.isDragging()&&this.onFinish(this.selected[0],{mode:this.mode,action:`dragCoordinateResize`}),this.dragCoordinate.stopDragging(),this.dragFeature.stopDragging(),this.dragCoordinateResizeFeature.stopDragging(),this.rotateFeature.reset(),this.scaleFeature.reset(),t(!0))}onMouseMove(e){let t=this.selected[0];if(!t)return void this.clearDragTargetAndCursor();if(this.dragFeature.isDragging()||this.dragCoordinate.isDragging()||this.dragCoordinateResizeFeature.isDragging())return;let{featureFlags:n}=this.getSelectedFlags(t);if(!n)return void this.clearDragTargetAndCursor();let r,i=n.coordinates;if(i!=null&&i.midpoints&&(r=this.midPoints.getNearestMidPoint(e),r&&(this.dragTarget={type:`midpoint`,featureId:t,midPointId:r},this.setCursor(this.cursors.insertMidpoint))),i&&i.draggable){let{index:n,dist:i}=this.dragCoordinate.getDraggable(e,t);if(n>-1){if(r&&this.pixelDistance.measure(e,this.readFeature.getGeometry(r).coordinates)<i)return;this.dragTarget={type:`coordinate`,featureId:t,coordinateIndex:n},this.setCursor(this.cursors.pointerOver);return}}if(i&&i.resizable){let n=this.dragCoordinateResizeFeature.getDraggableIndex(e,t);if(n>-1)return this.dragTarget={type:`resize`,featureId:t,coordinateIndex:n},void this.setCursor(this.cursors.pointerOver)}if(n.draggable&&this.dragFeature.canDrag(e,t)){if(r)return;this.dragTarget={type:`feature`,featureId:t},this.setCursor(this.cursors.pointerOver);return}r||this.clearDragTargetAndCursor()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.properties.mode===this.mode&&e.geometry.type===`Point`){if(e.properties[A.SELECTION_POINT])return t.pointColor=this.getHexColorStylingValue(this.styles.selectionPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.selectionPointOpacity,1,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.selectionPointOutlineColor,t.pointOutlineColor,e),t.pointWidth=this.getNumericStylingValue(this.styles.selectionPointWidth,t.pointWidth,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.selectionPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.selectionPointOutlineWidth,2,e),t.zIndex=30,t;if(e.properties[A.MID_POINT])return t.pointColor=this.getHexColorStylingValue(this.styles.midPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.midPointOpacity,1,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.midPointOutlineColor,t.pointOutlineColor,e),t.pointWidth=this.getNumericStylingValue(this.styles.midPointWidth,4,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.midPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.midPointOutlineWidth,2,e),t.zIndex=50,t}else if(e.properties[A.SELECTED]){if(e.geometry.type===`Point`&&e.properties[j.MARKER])return t.markerUrl=this.getUrlStylingValue(this.styles.selectedMarkerUrl,$e,e),t.markerHeight=this.getNumericStylingValue(this.styles.selectedMarkerHeight,40,e),t.markerWidth=this.getNumericStylingValue(this.styles.selectedMarkerWidth,32,e),t;if(e.geometry.type===`Polygon`)return t.polygonFillColor=this.getHexColorStylingValue(this.styles.selectedPolygonColor,t.polygonFillColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.selectedPolygonOutlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.selectedPolygonOutlineColor,t.polygonOutlineColor,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.selectedPolygonOutlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.selectedPolygonFillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t;if(e.geometry.type===`LineString`)return t.lineStringColor=this.getHexColorStylingValue(this.styles.selectedLineStringColor,t.lineStringColor,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.selectedLineStringWidth,t.lineStringWidth,e),t.zIndex=M,t;if(e.geometry.type===`Point`)return t.pointWidth=this.getNumericStylingValue(this.styles.selectedPointWidth,t.pointWidth,e),t.pointColor=this.getHexColorStylingValue(this.styles.selectedPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.selectedPointOpacity,1,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.selectedPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.selectedPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.selectedPointOutlineWidth,t.pointOutlineWidth,e),t.zIndex=M,t}return t}afterFeatureUpdated(e){if(this.selected.length&&e.id===this.selected[0]){var t,n;let r=this.flags[e.properties.mode];if(r==null||(t=r.feature)==null||!t.coordinates)return;let i=e.geometry.type,a=e.id;if(this.selectionPoints.delete(),this.midPoints.delete(),i!==`LineString`&&i!==`Polygon`)return;let o=e.geometry.coordinates;this.selectionPoints.create({featureCoordinates:o,featureId:a}),r!=null&&(n=r.feature)!=null&&(n=n.coordinates)!=null&&n.midpoints&&this.midPoints.create({featureCoordinates:o,featureId:a})}}},qn=class extends N{constructor(...e){super(...e),this.type=it.Static,this.mode=`static`}start(){}stop(){}onKeyUp(){}onKeyDown(){}onClick(){}onDragStart(){}onDrag(){}onDragEnd(){}onMouseMove(){}cleanUp(){}styleFeature(){return D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0})}};function Jn(e,t,n,r,i){for(;r>n;){if(r-n>600){let a=r-n+1,o=t-n+1,s=Math.log(a),c=.5*Math.exp(2*s/3),l=.5*Math.sqrt(s*c*(a-c)/a)*(o-a/2<0?-1:1);Jn(e,t,Math.max(n,Math.floor(t-o*c/a+l)),Math.min(r,Math.floor(t+(a-o)*c/a+l)),i)}let a=e[t],o=n,s=r;for(Yn(e,n,t),i(e[r],a)>0&&Yn(e,n,r);o<s;){for(Yn(e,o,s),o++,s--;i(e[o],a)<0;)o++;for(;i(e[s],a)>0;)s--}i(e[n],a)===0?Yn(e,n,s):(s++,Yn(e,s,r)),s<=t&&(n=s+1),t<=s&&(r=s-1)}}function Yn(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function Xn(e,t){Zn(e,0,e.children.length,t,e)}function Zn(e,t,n,r,i){i||=or([]),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(let a=t;a<n;a++){let t=e.children[a];Qn(i,e.leaf?r(t):t)}return i}function Qn(e,t){return e.minX=Math.min(e.minX,t.minX),e.minY=Math.min(e.minY,t.minY),e.maxX=Math.max(e.maxX,t.maxX),e.maxY=Math.max(e.maxY,t.maxY),e}function $n(e,t){return e.minX-t.minX}function er(e,t){return e.minY-t.minY}function tr(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function nr(e){return e.maxX-e.minX+(e.maxY-e.minY)}function rr(e,t){let n=Math.max(e.minX,t.minX),r=Math.max(e.minY,t.minY),i=Math.min(e.maxX,t.maxX),a=Math.min(e.maxY,t.maxY);return Math.max(0,i-n)*Math.max(0,a-r)}function ir(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function ar(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function or(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function sr(e,t,n,r,i){let a=[t,n];for(;a.length;){if((n=a.pop())-(t=a.pop())<=r)continue;let o=t+Math.ceil((n-t)/r/2)*r;Jn(e,o,t,n,i),a.push(t,o,o,n)}}var cr=class{constructor(e){this._maxEntries=void 0,this._minEntries=void 0,this.data=void 0,this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()}search(e){let t=this.data,n=[];if(!ar(e,t))return n;let r=this.toBBox,i=[];for(;t;){for(let a=0;a<t.children.length;a++){let o=t.children[a],s=t.leaf?r(o):o;ar(e,s)&&(t.leaf?n.push(o):ir(e,s)?this._all(o,n):i.push(o))}t=i.pop()}return n}collides(e){let t=this.data;if(ar(e,t)){let n=[];for(;t;){for(let r=0;r<t.children.length;r++){let i=t.children[r],a=t.leaf?this.toBBox(i):i;if(ar(e,a)){if(t.leaf||ir(e,a))return!0;n.push(i)}}t=n.pop()}}return!1}load(e){if(e.length<this._minEntries){for(let t=0;t<e.length;t++)this.insert(e[t]);return}let t=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===t.height)this._splitRoot(this.data,t);else{if(this.data.height<t.height){let e=this.data;this.data=t,t=e}this._insert(t,this.data.height-t.height-1,!0)}else this.data=t}insert(e){this._insert(e,this.data.height-1)}clear(){this.data=or([])}remove(e){let t=this.data,n=this.toBBox(e),r=[],i=[],a,o,s=!1;for(;t||r.length;){if(t||(t=r.pop(),o=r[r.length-1],a=i.pop(),s=!0),t.leaf){let n=t.children.indexOf(e);n!==-1&&(t.children.splice(n,1),r.push(t),this._condense(r))}s||t.leaf||!ir(t,n)?o?(a++,t=o.children[a],s=!1):t=null:(r.push(t),i.push(a),a=0,o=t,t=t.children[0])}}toBBox(e){return e}compareMinX(e,t){return e.minX-t.minX}compareMinY(e,t){return e.minY-t.minY}_all(e,t){let n=[];for(;e;)e.leaf?t.push(...e.children):n.push(...e.children),e=n.pop();return t}_build(e,t,n,r){let i=n-t+1,a,o=this._maxEntries;if(i<=o)return a=or(e.slice(t,n+1)),Xn(a,this.toBBox),a;r||(r=Math.ceil(Math.log(i)/Math.log(o)),o=Math.ceil(i/o**(r-1))),a=or([]),a.leaf=!1,a.height=r;let s=Math.ceil(i/o),c=s*Math.ceil(Math.sqrt(o));sr(e,t,n,c,this.compareMinX);for(let i=t;i<=n;i+=c){let t=Math.min(i+c-1,n);sr(e,i,t,s,this.compareMinY);for(let n=i;n<=t;n+=s){let i=Math.min(n+s-1,t);a.children.push(this._build(e,n,i,r-1))}}return Xn(a,this.toBBox),a}_chooseSubtree(e,t,n,r){for(;r.push(t),!t.leaf&&r.length-1!==n;){let n,r=1/0,o=1/0;for(let s=0;s<t.children.length;s++){let c=t.children[s],l=tr(c),u=(i=e,a=c,(Math.max(a.maxX,i.maxX)-Math.min(a.minX,i.minX))*(Math.max(a.maxY,i.maxY)-Math.min(a.minY,i.minY))-l);u<o?(o=u,r=l<r?l:r,n=c):u===o&&l<r&&(r=l,n=c)}t=n||t.children[0]}var i,a;return t}_insert(e,t,n){let r=n?e:this.toBBox(e),i=[],a=this._chooseSubtree(r,this.data,t,i);for(a.children.push(e),Qn(a,r);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(r,i,t)}_split(e,t){let n=e[t],r=n.children.length,i=this._minEntries;this._chooseSplitAxis(n,i,r);let a=this._chooseSplitIndex(n,i,r),o=or(n.children.splice(a,n.children.length-a));o.height=n.height,o.leaf=n.leaf,Xn(n,this.toBBox),Xn(o,this.toBBox),t?e[t-1].children.push(o):this._splitRoot(n,o)}_splitRoot(e,t){this.data=or([e,t]),this.data.height=e.height+1,this.data.leaf=!1,Xn(this.data,this.toBBox)}_chooseSplitIndex(e,t,n){let r,i=1/0,a=1/0;for(let o=t;o<=n-t;o++){let t=Zn(e,0,o,this.toBBox),s=Zn(e,o,n,this.toBBox),c=rr(t,s),l=tr(t)+tr(s);c<i?(i=c,r=o,a=l<a?l:a):c===i&&l<a&&(a=l,r=o)}return r||n-t}_chooseSplitAxis(e,t,n){let r=e.leaf?this.compareMinX:$n,i=e.leaf?this.compareMinY:er;this._allDistMargin(e,t,n,r)<this._allDistMargin(e,t,n,i)&&e.children.sort(r)}_allDistMargin(e,t,n,r){e.children.sort(r);let i=this.toBBox,a=Zn(e,0,t,i),o=Zn(e,n-t,n,i),s=nr(a)+nr(o);for(let r=t;r<n-t;r++){let t=e.children[r];Qn(a,e.leaf?i(t):t),s+=nr(a)}for(let r=n-t-1;r>=t;r--){let t=e.children[r];Qn(o,e.leaf?i(t):t),s+=nr(o)}return s}_adjustParentBBoxes(e,t,n){for(let r=n;r>=0;r--)Qn(t[r],e)}_condense(e){for(let t,n=e.length-1;n>=0;n--)e[n].children.length===0?n>0?(t=e[n-1].children,t.splice(t.indexOf(e[n]),1)):this.clear():Xn(e[n],this.toBBox)}},lr=class{constructor(e){this.tree=void 0,this.idToNode=void 0,this.nodeToId=void 0,this.tree=new cr(e&&e.maxEntries?e.maxEntries:9),this.idToNode=new Map,this.nodeToId=new Map}setMaps(e,t){this.idToNode.set(e.id,t),this.nodeToId.set(t,e.id)}toBBox(e){let t=[],n=[],r;if(e.geometry.type===`Polygon`)r=e.geometry.coordinates[0];else if(e.geometry.type===`LineString`)r=e.geometry.coordinates;else{if(e.geometry.type!==`Point`)throw Error(`Not a valid feature to turn into a bounding box`);r=[e.geometry.coordinates]}for(let e=0;e<r.length;e++)n.push(r[e][1]),t.push(r[e][0]);let i=Math.min(...n),a=Math.max(...n);return{minX:Math.min(...t),minY:i,maxX:Math.max(...t),maxY:a}}insert(e){if(this.idToNode.get(String(e.id)))throw Error(`Feature already exists`);let t=this.toBBox(e);this.setMaps(e,t),this.tree.insert(t)}load(e){let t=[],n=new Set;e.forEach(e=>{let r=this.toBBox(e);if(this.setMaps(e,r),n.has(String(e.id)))throw Error(`Duplicate feature ID found ${e.id}`);n.add(String(e.id)),t.push(r)}),this.tree.load(t)}update(e){this.remove(e.id);let t=this.toBBox(e);this.setMaps(e,t),this.tree.insert(t)}remove(e){let t=this.idToNode.get(e);if(!t)throw Error(`${e} not inserted into the spatial index`);this.tree.remove(t)}clear(){this.tree.clear()}search(e){return this.tree.search(this.toBBox(e)).map(e=>this.nodeToId.get(e))}collides(e){return this.tree.collides(this.toBBox(e))}},ur={getId:()=>`xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx`.replace(/[xy]/g,function(e){let t=16*Math.random()|0;return(e==`x`?t:3&t|8).toString(16)}),isValidId:e=>typeof e==`string`&&e.length===36},dr={target:`geometry`},fr={target:`properties`},pr=class{constructor(e){this.idStrategy=void 0,this.tracked=void 0,this.spatialIndex=void 0,this.store=void 0,this._onChange=()=>{},this.store={},this.spatialIndex=new lr,this.tracked=!e||!1!==e.tracked,this.idStrategy=e&&e.idStrategy?e.idStrategy:ur}clone(e){return JSON.parse(JSON.stringify(e))}getId(){return this.idStrategy.getId()}has(e){return!!this.store[e]}load(e,t,n,r){if(e.length===0)return[];let i=this.clone(e),a=[],o=[];i=i.filter(e=>{e.id??=this.idStrategy.getId();let n=e.id;if(t){let r=t(e);if(!r.valid)return a.push({id:n,valid:!1,reason:r.reason}),!1}if(this.tracked){if(e.properties.createdAt){if(!nt(e.properties.createdAt))return a.push({id:e.id,valid:!1,reason:`createdAt is not a valid numeric timestamp`}),!1}else e.properties.createdAt=+new Date;if(e.properties.updatedAt){if(!nt(e.properties.updatedAt))return a.push({id:e.id,valid:!1,reason:`updatedAt is not a valid numeric timestamp`}),!1}else e.properties.updatedAt=+new Date}return this.has(n)?(a.push({id:n,valid:!1,reason:`Feature already exists with this id: ${n}`}),!1):(this.store[n]=e,o.push(e),a.push({id:n,valid:!0}),!0)}),this.spatialIndex.load(i);let s=o.map(({id:e})=>e);return s.length>0&&(this._onChange(s,`create`,r),n&&o.forEach(e=>{n(e)})),a}search(e,t){let n=this.spatialIndex.search(e).map(e=>this.store[e]);return this.clone(t?n.filter(t):n)}registerOnChange(e){this._onChange=(t,n,r)=>{e(t,n,r)}}getGeometryCopy(e){let t=this.store[e];if(!t)throw Error(`No feature with this id (${e}), can not get geometry copy`);return this.clone(t.geometry)}getPropertiesCopy(e){let t=this.store[e];if(!t)throw Error(`No feature with this id (${e}), can not get properties copy`);return this.clone(t.properties)}updateProperty(e,t){let n=new Set;e.forEach(({id:e,property:t,value:r})=>{let i=this.store[e];if(!i)throw Error(`No feature with this (${e}), can not update geometry`);i.properties[t]!==r&&(n.add(e),r===void 0?delete i.properties[t]:i.properties[t]=r,this.tracked&&(i.properties.updatedAt=+new Date))}),this._onChange&&n.size>0&&this._onChange(Array.from(n),`update`,t?D({},t,fr):fr)}updateGeometry(e,t){let n=new Set;e.forEach(({id:e,geometry:t})=>{n.add(e);let r=this.store[e];if(!r)throw Error(`No feature with this (${e}), can not update geometry`);r.geometry=this.clone(t),this.spatialIndex.update(r),this.tracked&&(r.properties.updatedAt=+new Date)}),this._onChange&&n.size>0&&this._onChange(Array.from(n),`update`,t?D({},t,dr):dr)}create(e,t){let n=[];return e.forEach(({geometry:e,properties:t})=>{let r,i=D({},t);this.tracked&&(r=+new Date,t?(i.createdAt=typeof t.createdAt==`number`?t.createdAt:r,i.updatedAt=typeof t.updatedAt==`number`?t.updatedAt:r):i={createdAt:r,updatedAt:r});let a=this.getId(),o={id:a,type:`Feature`,geometry:e,properties:i};this.store[a]=o,this.spatialIndex.insert(o),n.push(a)}),this._onChange&&this._onChange([...n],`create`,t),n}delete(e,t){e.forEach(e=>{if(!this.store[e])throw Error(`No feature with id ${e}, can not delete`);delete this.store[e],this.spatialIndex.remove(e)}),this._onChange&&this._onChange([...e],`delete`,t)}copy(e){return this.clone(this.store[e])}copyAll(){return this.clone(Object.keys(this.store).map(e=>this.store[e]))}copyAllWhere(e){return this.clone(Object.keys(this.store).map(e=>this.store[e]).filter(t=>t.properties&&e(t.properties)))}clear(e){let t=Object.keys(this.store);this.store={},this.spatialIndex.clear(),this._onChange(t,`delete`,e)}size(){return Object.keys(this.store).length}};Math.PI/180;var mr=`Feature is not a Polygon or LineString`,hr=`Feature intersects itself`,gr=e=>e.geometry.type!==`Polygon`&&e.geometry.type!==`LineString`?{valid:!1,reason:mr}:ht(e)?{valid:!1,reason:hr}:{valid:!0};function _r(e,t,n){let r=K(e,t),i=K(t,n)-r;return i<0&&(i+=360),180-Math.abs(i-90-90)}var vr={cancel:`Escape`,finish:`Enter`},yr={start:`crosshair`,close:`pointer`},br=class extends N{constructor(e){super(e,!0),this.mode=`angled-rectangle`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=vr,this.cursors=yr,this.mouseMove=!1,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents))}close(){if(this.currentId===void 0||!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.currentId===void 0||this.currentCoordinate===0)return;let t=[];if(this.currentCoordinate===1)t=this.getUpdateForSecondCoordinate(e);else{if(this.currentCoordinate!==2)return;t=this.getNewSecondAndThirdCoordinates(e)}this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:t,context:{updateType:k.Provisional}})}getUpdateForSecondCoordinate(e){return[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:V,index:2,coordinate:[e.lng,e.lat]}]}getNewSecondAndThirdCoordinates(e){if(!this.currentId)throw Error(`No current feature being drawn`);let t=this.readFeature.getCoordinate(this.currentId,0),n=this.readFeature.getCoordinate(this.currentId,1),r=Dn(t,n,this.coordinatePrecision,this.project,this.unproject),i=L(t[0],t[1]),a=L(r[0],r[1]),o=L(n[0],n[1]),s=L(e.lng,e.lat),c=W(s,i)<W(s,o),l=_r(i,a,s),u=c?90-l:_r(i,a,s)-90,d=W(a,s),f=Math.cos(F(u))*d,p=K(i,o)+(function(e,t,n){let r=(n.x-t.x)*(e.y-t.y)-(n.y-t.y)*(e.x-t.x);return r>1e-10?`left`:r<-1e-10?`right`:`left`}(i,o,s)===`right`?-90:90),m=Vt(i,f,p),h=Vt(o,f,p),g=R(m.x,m.y),_=R(h.x,h.y);return[{type:V,index:2,coordinate:[I(_.lng,this.coordinatePrecision),I(_.lat,this.coordinatePrecision)]},{type:V,index:3,coordinate:[I(g.lng,this.coordinatePrecision),I(g.lat,this.coordinatePrecision)]}]}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))if(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,this.currentCoordinate===0){let{id:t}=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.currentId=t,this.currentCoordinate++,this.setDrawing()}else if(this.currentCoordinate===1&&this.currentId){let t=this.readFeature.getCoordinate(this.currentId,0);if(Mt([e.lng,e.lat],t)||!this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:B,index:1,coordinate:[e.lng,e.lat]}],context:{updateType:k.Commit}}))return;this.currentCoordinate++}else this.currentCoordinate===2&&this.currentId&&this.close()}onKeyUp(e){if(e.key===this.keyEvents.cancel)this.cleanUp();else if(e.key===this.keyEvents.finish){if(this.currentCoordinate<2)return void this.cleanUp();this.close()}}onKeyDown(){}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){let e=this.currentId;this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.properties.mode===this.mode&&e.geometry.type===`Polygon`&&(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M),t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}};function xr(e,t,n){return(t.x-e.x)*(n.y-e.y)-(t.y-e.y)*(n.x-e.x)<=0}var Sr={cancel:`Escape`,finish:`Enter`},Cr={start:`crosshair`,close:`pointer`},wr=class extends N{constructor(e){super(e,!0),this.mode=`sector`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=Sr,this.direction=void 0,this.arcPoints=64,this.cursors=Cr,this.mouseMove=!1,this.readFeature=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.arcPoints&&(this.arcPoints=e.arcPoints)}close(){if(this.currentId===void 0||!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},coordinateMutations:{coordinates:this.readFeature.getGeometry(this.currentId).coordinates,type:H},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.direction=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}getSectorCoordinates(e){let t=this.readFeature.getCoordinates(this.currentId),n=t[0],r=t[1],i=[e.lng,e.lat],a=L(n[0],n[1]),o=L(r[0],r[1]),s=L(i[0],i[1]);this.direction===void 0&&(this.direction=xr(a,o,s)?`clockwise`:`anticlockwise`);let c=W(a,o),l=K(a,o),u=K(a,s),d=this.arcPoints,f=[n],p=Ut(l),m=Ut(u),h;this.direction===`anticlockwise`?(h=m-p,h<0&&(h+=360)):(h=p-m,h<0&&(h+=360));let g=(this.direction===`anticlockwise`?1:-1)*h/d;f.push(r);for(let e=0;e<=d;e++){let t=Vt(a,c,p+e*g),{lng:n,lat:r}=R(t.x,t.y),i=[I(n,this.coordinatePrecision),I(r,this.coordinatePrecision)];i[0]!==f[f.length-1][0]&&i[1]!==f[f.length-1][1]&&f.push(i)}return f.push(n),f}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.currentId===void 0||this.currentCoordinate===0)return;let t;if(this.currentCoordinate===1)t=[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:V,index:2,coordinate:[e.lng,e.lat]}];else{if(this.currentCoordinate!==2)return;{let n=this.getSectorCoordinates(e);if(!n)return;t={type:H,coordinates:[n]}}}this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:t,context:{updateType:k.Provisional}})}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))if(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,this.currentCoordinate===0)this.currentId=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}})?.id,this.currentCoordinate++,this.setDrawing();else if(this.currentCoordinate===1&&this.currentId){if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,index:0,newCoordinate:[e.lng,e.lat]})||!this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:V,index:2,coordinate:[e.lng,e.lat]}],context:{updateType:k.Provisional}}))return;this.currentCoordinate++}else this.currentCoordinate===2&&this.currentId&&this.close()}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onKeyDown(){}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){let e=this.currentId;this.currentId=void 0,this.direction=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.properties.mode===this.mode&&e.geometry.type===`Polygon`&&(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M),t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.currentId=void 0,this.direction=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}},Tr={cancel:`Escape`,finish:`Enter`},Er={start:`crosshair`,close:`pointer`},Dr=class extends N{constructor(e){super(e,!0),this.mode=`sensor`,this.currentCoordinate=0,this.currentId=void 0,this.currentInitialArcId=void 0,this.currentStartingPointId=void 0,this.keyEvents=Tr,this.direction=void 0,this.arcPoints=64,this.cursors=Er,this.mouseMove=!1,this.readFeature=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.arcPoints&&(this.arcPoints=e.arcPoints)}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.currentInitialArcId!==void 0&&this.currentStartingPointId!==void 0&&this.currentCoordinate!==0){if(this.currentCoordinate===2){let t=this.getUpdatedLineStringCoordinates(e);if(!t)return;this.mutateFeature.updateLineString({featureId:this.currentInitialArcId,coordinateMutations:{type:H,coordinates:t},context:{updateType:k.Provisional}})}else if(this.currentCoordinate===3){let t=this.getUpdatedPolygonCoordinates(e);if(!t)return;if(this.currentId)this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:{type:H,coordinates:[t]},context:{updateType:k.Provisional}});else{let e=this.mutateFeature.createPolygon({coordinates:t,properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});if(!e)return;this.currentId=e.id}}}}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))if(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,this.currentCoordinate===0){let t=this.mutateFeature.createPoint({coordinates:[e.lng,e.lat],properties:{mode:this.mode}});if(!t)return;this.currentStartingPointId=t.id,this.currentCoordinate++,this.setDrawing()}else if(this.currentCoordinate===1&&this.currentStartingPointId){let t=this.mutateFeature.createLineString({coordinates:[[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode}});if(!t)return;this.currentInitialArcId=t.id,this.currentCoordinate++}else this.currentCoordinate===2&&this.currentStartingPointId?this.currentCoordinate++:this.currentCoordinate===3&&this.currentStartingPointId&&this.close()}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onKeyDown(){}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){this.mutateFeature.deleteFeatureIfPresent(this.currentStartingPointId),this.mutateFeature.deleteFeatureIfPresent(this.currentInitialArcId),this.mutateFeature.deleteFeatureIfPresent(this.currentId),this.currentStartingPointId=void 0,this.direction=void 0,this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.properties.mode===this.mode&&(e.geometry.type===`Polygon`?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M):e.geometry.type===`LineString`?(t.lineStringColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.zIndex=M):e.geometry.type===`Point`&&(t.pointColor=this.getHexColorStylingValue(this.styles.centerPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.centerPointOpacity,1,e),t.pointWidth=this.getNumericStylingValue(this.styles.centerPointWidth,t.pointWidth,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.centerPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.centerPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.centerPointOutlineWidth,t.pointOutlineWidth,e),t.zIndex=20)),t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.mutateFeature.deleteFeatureIfPresent(this.currentStartingPointId),this.mutateFeature.deleteFeatureIfPresent(this.currentInitialArcId),this.currentStartingPointId=void 0,this.direction=void 0,this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}close(){if(this.currentStartingPointId===void 0)return;let e=this.currentStartingPointId,t=this.currentInitialArcId;if(this.currentId&&!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},coordinateMutations:{coordinates:this.readFeature.getGeometry(this.currentId).coordinates,type:H},context:{updateType:k.Finish,action:O}}))return;let n=this.currentId;this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(t),this.currentCoordinate=0,this.currentStartingPointId=void 0,this.currentInitialArcId=void 0,this.currentId=void 0,this.direction=void 0,this.state===`drawing`&&this.setStarted(),n&&this.onFinish(n,{mode:this.mode,action:O})}getUpdatedPolygonCoordinates(e){if(this.currentInitialArcId===void 0||this.currentStartingPointId===void 0||this.currentCoordinate<3)return;let t=this.readFeature.getCoordinates(this.currentInitialArcId);if(t.length<2||!this.direction)return;let n=this.readFeature.getGeometry(this.currentStartingPointId).coordinates,r=t[0],i=t[t.length-1],a=L(e.lng,e.lat),o=L(r[0],r[1]),s=L(i[0],i[1]),c=L(n[0],n[1]),l=W(c,o),u=W(c,a)<l?o:a,d=K(c,a),f=K(c,o),p=K(c,s),m=Ut(f),h=Ut(p),g=Ut(d);if(this.notInSector({normalizedCursor:g,normalizedStart:m,normalizedEnd:h,direction:this.direction}))return;let _=this.getDeltaBearing(this.direction,m,h),v=this.arcPoints,y=(this.direction===`anticlockwise`?1:-1)*_/v,ee=W(c,u),b=[];for(let e=0;e<=v;e++){let n=Vt(c,ee,m+e*y),{lng:r,lat:i}=R(n.x,n.y),a=[I(r,this.coordinatePrecision),I(i,this.coordinatePrecision)];a[0]!==t[t.length-1][0]&&a[1]!==t[t.length-1][1]&&b.unshift(a)}return t.push(...b),t.push(t[0]),t}getUpdatedLineStringCoordinates(e){if(this.currentInitialArcId===void 0||this.currentStartingPointId===void 0||this.currentCoordinate<2)return;let t=this.readFeature.getGeometry(this.currentInitialArcId).coordinates,n=this.readFeature.getGeometry(this.currentStartingPointId).coordinates,r=t[0],i=[e.lng,e.lat],a=L(r[0],r[1]),o=L(i[0],i[1]),s=L(n[0],n[1]),c=W(s,a);this.direction===void 0&&(this.direction=xr(s,a,o)?`clockwise`:`anticlockwise`);let l=K(s,a),u=K(s,o),d=this.arcPoints,f=[r],p=Ut(l),m=Ut(u),h;this.direction===`anticlockwise`?(h=m-p,h<0&&(h+=360)):(h=p-m,h<0&&(h+=360));let g=(this.direction===`anticlockwise`?1:-1)*h/d;for(let e=0;e<=d;e++){let t=Vt(s,c,p+e*g),{lng:n,lat:r}=R(t.x,t.y),i=[I(n,this.coordinatePrecision),I(r,this.coordinatePrecision)];i[0]!==f[f.length-1][0]&&i[1]!==f[f.length-1][1]&&f.push(i)}return f}getDeltaBearing(e,t,n){let r;return e===`anticlockwise`?(r=n-t,r<0&&(r+=360)):(r=t-n,r<0&&(r+=360)),r}notInSector({normalizedCursor:e,normalizedStart:t,normalizedEnd:n,direction:r}){return r===`clockwise`?t<=n?e>=t&&e<=n:e>=t||e<=n:t>=n?e<=t&&e>=n:e<=t||e>=n}},Or=class{constructor({name:e,callback:t,unregister:n,register:r}){this.name=void 0,this.callback=void 0,this.registered=!1,this.register=void 0,this.unregister=void 0,this.name=e,this.register=()=>{this.registered||(this.registered=!0,r(t))},this.unregister=()=>{this.register&&(this.registered=!1,n(t))},this.callback=t}},kr={__proto__:null,GeoJSONStore:pr,TerraDrawBaseDrawMode:N,TerraDrawBaseSelectMode:ot,TerraDrawBaseAdapter:class{constructor(e){this._nextKeyUpIsContextMenu=!1,this._lastPointerDownEventTarget=void 0,this._ignoreMismatchedPointerEvents=!1,this._minPixelDragDistance=void 0,this._minPixelDragDistanceDrawing=void 0,this._minPixelDragDistanceSelecting=void 0,this._lastDrawEvent=void 0,this._coordinatePrecision=void 0,this._heldKeys=new Set,this._listeners=[],this._dragState=`not-dragging`,this._currentModeCallbacks=void 0,this._ignoreMismatchedPointerEvents=typeof e.ignoreMismatchedPointerEvents==`boolean`&&e.ignoreMismatchedPointerEvents,this._minPixelDragDistance=typeof e.minPixelDragDistance==`number`?e.minPixelDragDistance:1,this._minPixelDragDistanceSelecting=typeof e.minPixelDragDistanceSelecting==`number`?e.minPixelDragDistanceSelecting:1,this._minPixelDragDistanceDrawing=typeof e.minPixelDragDistanceDrawing==`number`?e.minPixelDragDistanceDrawing:8,this._coordinatePrecision=typeof e.coordinatePrecision==`number`?e.coordinatePrecision:9}getButton(e){return e.button===-1?`neither`:e.button===0?`left`:e.button===1?`middle`:e.button===2?`right`:`neither`}getMapElementXYPosition(e){let{left:t,top:n}=this.getMapEventElement(e.type).getBoundingClientRect();return{containerX:e.clientX-t,containerY:e.clientY-n}}getDrawEventFromEvent(e,t=!1){let n=this.getLngLatFromEvent(e);if(!n)return null;let{lng:r,lat:i}=n,{containerX:a,containerY:o}=this.getMapElementXYPosition(e),s=this.getButton(e),c=Array.from(this._heldKeys);return{lng:I(r,this._coordinatePrecision),lat:I(i,this._coordinatePrecision),containerX:a,containerY:o,button:s,heldKeys:c,isContextMenu:t}}register(e){this._currentModeCallbacks=e,this._listeners=this.getAdapterListeners(),this._listeners.forEach(e=>{e.register()})}getCoordinatePrecision(){return this._coordinatePrecision}getAdapterListeners(){return[new Or({name:`pointerdown`,callback:e=>{if(!this._currentModeCallbacks||!e.isPrimary)return;let t=this.getDrawEventFromEvent(e);t&&(this._dragState=`pre-dragging`,this._lastDrawEvent=t,this._lastPointerDownEventTarget=e.target?e.target:void 0)},register:e=>{this.getMapEventElement(`pointerdown`).addEventListener(`pointerdown`,e)},unregister:e=>{this.getMapEventElement(`pointerdown`).removeEventListener(`pointerdown`,e)}}),new Or({name:`pointermove`,callback:e=>{if(!this._currentModeCallbacks||!e.isPrimary)return;e.preventDefault();let t=this.getDrawEventFromEvent(e);if(t)if(this._dragState===`not-dragging`)this._currentModeCallbacks.onMouseMove(t),this._lastDrawEvent=t;else if(this._dragState===`pre-dragging`){if(!this._lastDrawEvent)return;let e={x:this._lastDrawEvent.containerX,y:this._lastDrawEvent.containerY},n={x:t.containerX,y:t.containerY},r=this._currentModeCallbacks.getState(),i=W(e,n),a=!1;if(a=r===`drawing`?i<this._minPixelDragDistanceDrawing:r===`selecting`?i<this._minPixelDragDistanceSelecting:i<this._minPixelDragDistance,a)return;this._nextKeyUpIsContextMenu=!1,this._dragState=`dragging`,this._currentModeCallbacks.onDragStart(t,e=>{this.setDraggability.bind(this)(e)})}else this._dragState===`dragging`&&this._currentModeCallbacks.onDrag(t,e=>{this.setDraggability.bind(this)(e)})},register:e=>{this.getMapEventElement(`pointermove`).addEventListener(`pointermove`,e)},unregister:e=>{this.getMapEventElement(`pointermove`).removeEventListener(`pointermove`,e)}}),new Or({name:`contextmenu`,callback:e=>{this._currentModeCallbacks&&(e.preventDefault(),this._nextKeyUpIsContextMenu=!0)},register:e=>{this.getMapEventElement(`contextmenu`).addEventListener(`contextmenu`,e)},unregister:e=>{this.getMapEventElement(`contextmenu`).removeEventListener(`contextmenu`,e)}}),new Or({name:`pointerup`,callback:e=>{if(!this._currentModeCallbacks||e.target!==this.getMapEventElement(`pointerup`)||this._ignoreMismatchedPointerEvents&&this._lastPointerDownEventTarget!==e.target||(this._lastPointerDownEventTarget=void 0,!e.isPrimary))return;let t=this.getDrawEventFromEvent(e);t&&(this._dragState===`dragging`?this._currentModeCallbacks.onDragEnd(t,e=>{this.setDraggability.bind(this)(e)}):this._dragState!==`not-dragging`&&this._dragState!==`pre-dragging`||(this._nextKeyUpIsContextMenu&&=(t.isContextMenu=!0,!1),this._currentModeCallbacks.onClick(t)),this._dragState=`not-dragging`,this.setDraggability(!0))},register:e=>{this.getMapEventElement(`pointerup`).addEventListener(`pointerup`,e)},unregister:e=>{this.getMapEventElement(`pointerup`).removeEventListener(`pointerup`,e)}}),new Or({name:`keyup`,callback:e=>{this._currentModeCallbacks&&(this._heldKeys.delete(e.key),this._currentModeCallbacks.onKeyUp({key:e.key,heldKeys:Array.from(this._heldKeys),preventDefault:()=>e.preventDefault()}))},register:e=>{this.getMapEventElement(`keyup`).addEventListener(`keyup`,e)},unregister:e=>{this.getMapEventElement(`keyup`).removeEventListener(`keyup`,e)}}),new Or({name:`keydown`,callback:e=>{this._currentModeCallbacks&&(this._heldKeys.add(e.key),this._currentModeCallbacks.onKeyDown({key:e.key,heldKeys:Array.from(this._heldKeys),preventDefault:()=>e.preventDefault()}))},register:e=>{this.getMapEventElement(`keydown`).addEventListener(`keydown`,e)},unregister:e=>{this.getMapEventElement(`keydown`).removeEventListener(`keydown`,e)}})]}unregister(){this._listeners.forEach(e=>{e.unregister()}),this.clear(),this._currentModeCallbacks=void 0,this._lastDrawEvent=void 0,this._lastPointerDownEventTarget=void 0,this._nextKeyUpIsContextMenu=!1}},getDefaultStyling:()=>({polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0}),SELECT_PROPERTIES:A},Ar={cancel:`Escape`,finish:`Enter`},jr={start:`crosshair`,close:`pointer`},Mr=class extends N{constructor(e){super(e,!0),this.mode=`freehand-linestring`,this.canClose=!1,this.currentId=void 0,this.minDistance=20,this.keyEvents=Ar,this.cursors=jr,this.preventNewFeature=!1,this.mutateFeature=void 0,this.readFeature=void 0,this.pixelDistance=void 0,this.closingPoints=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.minDistance&&(this.minDistance=e.minDistance),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors))}close(){if(this.currentId===void 0||!this.mutateFeature.updateLineString({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.closingPoints.delete(),this.canClose=!1,this.currentId=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.currentId===void 0||!1===this.canClose)return void this.setCursor(this.cursors.start);let[t,n]=this.readFeature.getCoordinate(this.currentId,-2),{x:r,y:i}=this.project(t,n),a=W({x:r,y:i},{x:e.containerX,y:e.containerY}),[o,s]=this.readFeature.getCoordinate(this.currentId,-1),{x:c,y:l}=this.project(o,s),u=W({x:c,y:l},{x:e.containerX,y:e.containerY});if(this.setCursor(u<this.pointerDistance?this.cursors.close:this.cursors.start),a<this.minDistance)return;let d=this.mutateFeature.updateLineString({featureId:this.currentId,coordinateMutations:[{type:B,index:-1,coordinate:[e.lng,e.lat]}],context:{updateType:k.Provisional}});d&&this.closingPoints.update(d.geometry.coordinates)}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)){if(this.preventNewFeature)return;if(!1===this.canClose){let{id:t,geometry:n}=this.mutateFeature.createLineString({coordinates:[[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.closingPoints.create(n.coordinates),this.currentId=t,this.canClose=!0,this.state!==`drawing`&&this.setDrawing();return}this.close()}}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&!0===this.canClose&&this.close()}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){let e=this.currentId;this.currentId=void 0,this.canClose=!1,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e),this.closingPoints.delete()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`LineString`&&e.properties.mode===this.mode?(t.lineStringColor=this.getHexColorStylingValue(this.styles.lineStringColor,t.lineStringColor,e),t.lineStringOpacity=this.getNumericStylingValue(this.styles.lineStringOpacity,t.lineStringOpacity===void 0?1:t.lineStringOpacity,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.lineStringWidth,t.lineStringWidth,e),t.zIndex=M,t):e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode?(t.pointWidth=this.getNumericStylingValue(this.styles.closingPointWidth,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(this.styles.closingPointOpacity,1,e),t.pointColor=this.getHexColorStylingValue(this.styles.closingPointColor,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.closingPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.closingPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.closingPointOutlineWidth,2,e),t.zIndex=50,t):t}validateFeature(e){return this.validateModeFeature(e,e=>Jt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.closingPoints.delete(),this.canClose=!1,this.currentId=void 0)}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate}),this.pixelDistance=new Rt(e),this.closingPoints=new on(e,this.pixelDistance,this.mutateFeature,this.readFeature)}};function Nr(e){if(e===null||typeof e==`boolean`||typeof e==`string`)return!0;if(e===void 0)return!1;if(typeof e==`number`)return Number.isFinite(e);if(typeof e==`bigint`||typeof e==`symbol`||typeof e==`function`||e instanceof RegExp||e instanceof Map||e instanceof Set||e instanceof Date)return!1;if(typeof e==`object`&&e&&!Array.isArray(e)){let t=Object.getPrototypeOf(e);if(t!==Object.prototype&&t!==null)return!1}if(ArrayBuffer.isView(e)&&!(e instanceof DataView))return!1;if(Array.isArray(e)){for(let t of e)if(!Nr(t))return!1}return typeof e==`object`&&Object.keys(e).every(t=>typeof t==`string`&&Nr(e[t]))}var Pr={create:`crosshair`,dragStart:`grabbing`,dragEnd:`crosshair`},Fr=class extends N{constructor(e){super(e,!0),this.mode=`marker`,this.cursors=Pr,this.editable=!1,this.editedFeatureId=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.pointSearch=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.editable&&(this.editable=e.editable)}start(){this.setStarted(),this.setCursor(this.cursors.create)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}onMouseMove(){}onKeyDown(){}onKeyUp(){}cleanUp(){this.editedFeatureId=void 0}onDragStart(e,t){this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&(this.editable&&(this.editedFeatureId=this.pointSearch.getNearestPointFeature(e)?.id),this.editedFeatureId&&(this.setCursor(this.cursors.dragStart),t(!1)))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.editedFeatureId!==void 0&&this.mutateFeature.updatePoint({featureId:this.editedFeatureId,coordinateMutations:{type:H,coordinates:[e.lng,e.lat]},propertyMutations:{[j.EDITED]:!0},context:{updateType:k.Provisional}})}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||!this.mutateFeature.updatePoint({featureId:this.editedFeatureId,propertyMutations:{mode:this.mode,[j.EDITED]:!1},context:{updateType:k.Finish,action:`edit`}}))return;let n=this.editedFeatureId;this.setCursor(this.cursors.dragEnd),this.editedFeatureId=void 0,t(!0),this.onFinish(n,{mode:this.mode,action:O})}registerBehaviors(e){this.pixelDistance=new Rt(e),this.clickBoundingBox=new Lt(e),this.pointSearch=new gn(e,this.pixelDistance,this.clickBoundingBox),this.mutateFeature=new U(e,{validate:this.validate})}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode&&(t.zIndex=30,t.markerHeight=this.getNumericStylingValue(this.styles?.markerHeight,40,e),t.markerWidth=this.getNumericStylingValue(this.styles?.markerWidth,32,e),t.markerUrl=this.getUrlStylingValue(this.styles?.markerUrl,$e,e)),t}validateFeature(e){return this.validateModeFeature(e,e=>hn(e,this.coordinatePrecision))}onLeftClick(e){let t=this.mutateFeature.createPoint({coordinates:[e.lng,e.lat],properties:{mode:this.mode,[j.MARKER]:!0},context:{updateType:k.Finish,action:O}});t&&this.onFinish(t.id,{mode:this.mode,action:O})}onRightClick(e){if(!this.editable)return;let t=this.pointSearch.getNearestPointFeature(e);t&&this.mutateFeature.deleteFeatureIfPresent(t.id)}afterFeatureUpdated(e){this.editedFeatureId===e.id&&(this.editedFeatureId=void 0,this.setCursor(this.cursors.create))}},Ir=[{key:`z`,heldKeys:[`meta`]},{key:`z`,heldKeys:[`control`]}],Lr=[{key:`z`,heldKeys:[`meta`,`shift`]},{key:`z`,heldKeys:[`control`,`shift`]},{key:`y`,heldKeys:[`control`]}],Rr=(e,t)=>{let n=e.key.toLowerCase(),r=new Set(e.heldKeys.map(e=>e.toLowerCase()).filter(e=>e!==n));if(t.key.toLowerCase()!==n)return!1;let i=new Set(t.heldKeys.map(e=>e.toLowerCase()));if(r.size!==i.size)return!1;for(let e of i)if(!r.has(e))return!1;return!0},zr=class{constructor(e){this.undoKeyboardShortcuts=void 0,this.redoKeyboardShortcuts=void 0,this.undoKeyboardShortcuts=e?.undo??Ir,this.redoKeyboardShortcuts=e?.redo??Lr}isUndoKeyboardShortcut(e){return this.undoKeyboardShortcuts.some(t=>Rr(e,t))}isRedoKeyboardShortcut(e){return this.redoKeyboardShortcuts.some(t=>Rr(e,t))}};function Br(e){return e!==void 0&&Number.isFinite(e)?Math.max(0,Math.floor(e)):1/0}var J=`undo`,Y=`redo`,Vr=`push`,X=`mode`,Hr=`session`,Ur=class{constructor(e){this.getModeState=void 0,this.getModeHistorySizes=void 0,this.undoMode=void 0,this.redoMode=void 0,this.clearModeHistory=void 0,this.onHistoryChange=void 0,this.maxStackSize=void 0,this.lastHistorySizes={undoSize:0,redoSize:0},this.maxStackSize=Br(e?.maxStackSize)}getMaxStackSize(){return this.maxStackSize}register(e){this.getModeState=e.getModeState,this.getModeHistorySizes=e.getModeHistorySizes,this.undoMode=e.undoMode,this.redoMode=e.redoMode,this.clearModeHistory=e.clearModeHistory,this.onHistoryChange=e.onHistoryChange}inDrawingState(){return!!this.getModeState&&this.getModeState()===`drawing`}canUndo(){if(!this.inDrawingState())return!1;let{undoSize:e}=this.getHistorySizes();return e>0}canRedo(){if(!this.inDrawingState())return!1;let{redoSize:e}=this.getHistorySizes();return e>0}undo(){return!(!this.canUndo()||!this.undoMode||(this.undoMode(),this.emitHistoryChange(J),0))}redo(){return!(!this.canRedo()||!this.redoMode||(this.redoMode(),this.emitHistoryChange(Y),0))}clearHistory(){this.clearModeHistory&&this.clearModeHistory(),this.lastHistorySizes={undoSize:0,redoSize:0}}getHistorySizes(){return this.getModeHistorySizes?this.getModeHistorySizes():{undoSize:0,redoSize:0}}undoSize(){return this.getHistorySizes().undoSize}redoSize(){return this.getHistorySizes().redoSize}emitPushIfHistoryChangedFromLastSnapshot(){if(!this.inDrawingState())return;let e=this.getHistorySizes();e.undoSize===this.lastHistorySizes.undoSize&&e.redoSize===this.lastHistorySizes.redoSize||this.emitHistoryChange(Vr)}emitPushIfHistoryChanged(e){if(!this.inDrawingState())return;let t=this.getHistorySizes();t.undoSize===e.undoSize&&t.redoSize===e.redoSize||this.emitHistoryChange(Vr)}emitHistoryChange(e){if(!this.onHistoryChange)return;let{undoSize:t,redoSize:n}=this.getHistorySizes();this.lastHistorySizes={undoSize:t,redoSize:n},this.onHistoryChange({cause:e,stack:X,undoStackSize:t,redoStackSize:n})}},Wr=class{constructor(e){this.draw=void 0,this.onHistoryChange=void 0,this.maxStackSize=void 0,this.historyById={},this.undoStack=[],this.ignoreProgrammaticCreate={},this.ignoreProgrammaticDelete={},this.deletedFeatureIds={},this.redoStack=[],this.emitStackChange=e=>{this.onHistoryChange&&this.onHistoryChange({cause:e,stack:Hr,undoStackSize:this.undoStack.length,redoStackSize:this.redoStack.length})},this.handleChange=(e,t,n)=>{if(!this.draw||this.isDrawing()||this.maxStackSize===0||t!==`delete`&&t!==`create`)return;if(t===`create`){if(n===void 0||!(`origin`in n)||n.origin!==`api`)return;let t=!1,r=Array.isArray(e)?e:[e],i=[];for(let e of r){if(this.ignoreProgrammaticCreate[e]){delete this.ignoreProgrammaticCreate[e],delete this.deletedFeatureIds[e];continue}let n=String(e),r=this.draw.getSnapshotFeature(e);r&&(this.deletedFeatureIds[e]&&(this.historyById[n]=[],delete this.deletedFeatureIds[e]),this.historyById[n]||(this.historyById[n]=[]),this.historyById[n].push(r),i.push({id:e,toIndex:this.historyById[n].length-1,snapshot:r}),t=!0)}if(i.length>1)this.pushUndoStackEntry({id:i[0].id,toIndex:i[0].toIndex,action:`batch-create`,metadata:{entries:i}});else if(i.length===1){let e=i[0];this.pushUndoStackEntry({id:e.id,toIndex:e.toIndex,action:`single`})}t&&(this.redoStack.length=0,this.emitStackChange(Vr));return}let r=!1,i=Array.isArray(e)?e:[e],a=[];for(let e of i){let t=String(e);if(this.ignoreProgrammaticDelete[e]){delete this.ignoreProgrammaticDelete[e];continue}if(!this.historyById[t])continue;let n=this.historyById[t].length-1;if(n>=0){let i=this.historyById[t][n];if(!i)continue;a.push({id:e,toIndex:n,snapshot:i}),this.deletedFeatureIds[e]=!0,r=!0}}if(a.length>1)this.pushUndoStackEntry({id:a[0].id,toIndex:a[0].toIndex,action:`batch-delete`,metadata:{entries:a}});else if(a.length===1){let e=a[0];this.pushUndoStackEntry({id:e.id,toIndex:e.toIndex,action:`single`})}r&&(this.redoStack.length=0,this.emitStackChange(Vr))},this.handleFinish=e=>{if(!this.draw||this.maxStackSize===0)return;let t=Array.isArray(e)?e:[e],n=!1;for(let e of t){if(e==null)continue;let t=String(e),r=this.draw.getSnapshotFeature(e);r&&(this.historyById[t]||(this.historyById[t]=[]),this.historyById[t].push(r),n||=(this.redoStack.length=0,!0),this.pushUndoStackEntry({id:e,toIndex:this.historyById[t].length-1,action:`single`}),this.emitStackChange(Vr))}},this.maxStackSize=Br(e?.maxStackSize)}register(e){this.draw===e.draw?this.onHistoryChange=e.onHistoryChange:(this.draw&&(this.draw.off(`change`,this.handleChange),this.draw.off(`finish`,this.handleFinish)),this.draw=e.draw,this.draw.on(`change`,this.handleChange),this.draw.on(`finish`,this.handleFinish),this.onHistoryChange=e.onHistoryChange)}pushUndoStackEntry(e){this.maxStackSize!==0&&(this.undoStack.push(e),this.undoStack.length>this.maxStackSize&&this.undoStack.shift())}pushRedoStackEntry(e){this.maxStackSize!==0&&(this.redoStack.push(e),this.redoStack.length>this.maxStackSize&&this.redoStack.shift())}isDrawing(){return!!this.draw&&this.draw.getModeState()===`drawing`}canUndo(){return!(!this.draw||this.isDrawing())&&this.undoStack.length>0}canRedo(){return!(!this.draw||this.isDrawing())&&this.redoStack.length>0}undo(){if(!this.canUndo()||!this.draw)return!1;let e=this.undoStack.pop();if(!e)return this.emitStackChange(J),!1;if(e.action===`batch-create`){let t=e.metadata?.entries||[];if(t.length===0)return this.emitStackChange(J),!1;let n=t.map(e=>e.id);return n.forEach(e=>{this.ignoreProgrammaticDelete[e]=!0,this.deletedFeatureIds[e]=!0}),this.draw.removeFeatures(n),this.pushRedoStackEntry({id:t[0].id,toIndex:t[0].toIndex,action:`batch-create`,metadata:{entries:t}}),this.emitStackChange(J),!0}if(e.action===`batch-delete`){let t=e.metadata?.entries||[];if(t.length===0)return this.emitStackChange(J),!1;let n=t.map(e=>e.snapshot).filter(e=>e!==void 0);return n.length>0&&(t.forEach(e=>{this.ignoreProgrammaticCreate[e.id]=!0,delete this.deletedFeatureIds[e.id]}),this.draw.addFeatures(n)),this.pushRedoStackEntry({id:t[0].id,toIndex:t[0].toIndex,action:`batch-delete`,metadata:{entries:t}}),this.emitStackChange(J),!0}let t=e.id,n=e.toIndex,r=String(t),i=this.historyById[r];if(!i||i.length===0)return this.emitStackChange(J),!1;let a=Math.min(n,i.length-1);if(!this.draw.hasFeature(t)){let e=i[a];return e?(this.ignoreProgrammaticCreate[t]=!0,delete this.deletedFeatureIds[t],this.draw.addFeatures([e]),this.pushRedoStackEntry({id:t,toIndex:a,action:`delete`,snapshot:e}),this.emitStackChange(J),!0):(this.emitStackChange(J),!1)}if(a<=0)return this.pushRedoStackEntry({id:t,toIndex:0,action:`create`}),this.ignoreProgrammaticDelete[t]=!0,this.deletedFeatureIds[t]=!0,this.draw.removeFeatures([t]),this.undoStack=this.undoStack.filter(e=>e.id!==t),this.emitStackChange(J),!0;let o=i[a],s=i[a-1];return o&&this.pushRedoStackEntry({id:t,toIndex:a,snapshot:o,action:`update`}),this.draw.updateFeatureGeometry(t,s.geometry),i.length=a,this.emitStackChange(J),!0}redo(){if(!this.canRedo()||!this.draw)return!1;let{id:e,toIndex:t,snapshot:n,action:r,metadata:i}=this.redoStack.pop();if(r===`batch-create`){let e=i?.entries||[];if(e.length===0)return this.emitStackChange(Y),!1;let t=e.map(e=>e.snapshot).filter(e=>e!==void 0);return t.length>0&&(e.forEach(e=>{this.ignoreProgrammaticCreate[e.id]=!0}),this.draw.addFeatures(t)),this.pushUndoStackEntry({id:e[0].id,toIndex:e[0].toIndex,action:`batch-create`,metadata:{entries:e}}),this.emitStackChange(Y),!0}if(r===`batch-delete`){let e=i?.entries||[];if(e.length===0)return this.emitStackChange(Y),!1;let t=e.map(e=>e.id);return t.forEach(e=>{this.ignoreProgrammaticDelete[e]=!0,this.deletedFeatureIds[e]=!0}),this.draw.removeFeatures(t),this.pushUndoStackEntry({id:e[0].id,toIndex:e[0].toIndex,action:`batch-delete`,metadata:{entries:e}}),this.emitStackChange(Y),!0}let a=String(e),o=this.historyById[a]||(this.historyById[a]=[]);if(r===`delete`)return this.ignoreProgrammaticDelete[e]=!0,this.deletedFeatureIds[e]=!0,this.draw.removeFeatures([e]),this.pushUndoStackEntry({id:e,toIndex:t,action:`single`}),this.emitStackChange(Y),!0;if(t<=0){let t=o[0];return!!t&&(this.ignoreProgrammaticCreate[e]=!0,this.draw.addFeatures([t]),this.pushUndoStackEntry({id:e,toIndex:0,action:`single`}),this.emitStackChange(Y),!0)}let s=n||o[t];return!!s&&(o.length===t?o.push(s):(o[t]=s,o.length=t+1),this.draw.updateFeatureGeometry(e,s.geometry),this.pushUndoStackEntry({id:e,toIndex:t,action:`single`}),this.emitStackChange(Y),!0)}clearHistory(){let e={};if(this.draw&&!this.isDrawing()){let t=this.draw.getSnapshot();for(let n of t)e[String(n.id)]=[n]}this.historyById=e,this.undoStack=[],this.ignoreProgrammaticCreate={},this.ignoreProgrammaticDelete={},this.deletedFeatureIds={},this.redoStack=[]}undoSize(){return this.undoStack.length}redoSize(){return this.redoStack.length}},Gr=class{constructor(e){this.modeLevel=void 0,this.sessionLevel=void 0,this.shouldPreferMode=void 0,this.onHistoryChange=void 0,this.shouldEmitHistoryChange=void 0,this.modeLevel=e.modeLevel,this.sessionLevel=e.sessionLevel,this.shouldPreferMode=e.shouldPreferMode,this.onHistoryChange=e.onHistoryChange,this.shouldEmitHistoryChange=e.shouldEmitHistoryChange??(()=>!0)}emitStackHistoryChange(e){this.shouldEmitHistoryChange()&&this.onHistoryChange&&this.onHistoryChange({cause:e.cause,stack:e.stack,undoSize:e.undoStackSize,redoSize:e.redoStackSize})}hasSessionUndo(){return!!(this.sessionLevel&&this.sessionLevel.canUndo())}hasSessionRedo(){return!!(this.sessionLevel&&this.sessionLevel.canRedo())}activeStackForUndo(){var e,t;return this.shouldPreferMode()&&(e=this.modeLevel)!=null&&e.canUndo()?X:this.hasSessionUndo()?Hr:(t=this.modeLevel)!=null&&t.canUndo()?X:void 0}activeStackForRedo(){var e,t;return this.shouldPreferMode()&&(e=this.modeLevel)!=null&&e.canRedo()?X:this.hasSessionRedo()?Hr:(t=this.modeLevel)!=null&&t.canRedo()?X:void 0}canUndo(){return this.activeStackForUndo()!==void 0}canRedo(){return this.activeStackForRedo()!==void 0}undo(){let e=this.activeStackForUndo();return!!e&&(e===X?!!this.modeLevel&&this.modeLevel.undo():!(!this.sessionLevel||!this.sessionLevel.canUndo())&&this.sessionLevel.undo())}redo(){let e=this.activeStackForRedo();return!!e&&(e===X?!!this.modeLevel&&this.modeLevel.redo():!(!this.sessionLevel||!this.sessionLevel.canRedo())&&this.sessionLevel.redo())}clearHistory(){this.modeLevel&&this.modeLevel.clearHistory(),this.sessionLevel&&this.sessionLevel.clearHistory()}emitPushAfterFinish(){this.sessionLevel?this.emitStackHistoryChange({cause:Vr,undoStackSize:this.sessionLevel.undoSize(),redoStackSize:this.sessionLevel.redoSize(),stack:Hr}):this.modeLevel&&this.emitStackHistoryChange({cause:Vr,undoStackSize:this.modeLevel.undoSize(),redoStackSize:this.modeLevel.redoSize(),stack:X})}},Kr=class{constructor(e){var t,n,r,i;this._modes=void 0,this._mode=void 0,this._adapter=void 0,this._enabled=!1,this._store=void 0,this._eventListeners=void 0,this._instanceSelectModes=void 0,this.sessionUndoRedoEnabled=!1,this.keyboardShortcutsMatcher=void 0,this.drawingUndoRedo=void 0,this.sessionUndoRedo=void 0,this.undoRedoCoordinator=void 0,this._adapter=e.adapter,this._instanceSelectModes=[];let a=e==null||(t=e.undoRedo)==null?void 0:t.modeLevel;a&&(this.drawingUndoRedo=a);let o=e==null||(n=e.undoRedo)==null?void 0:n.keyboardShortcuts;o&&(this.keyboardShortcutsMatcher=o),this.sessionUndoRedoEnabled=!!(!(e==null||(r=e.undoRedo)==null)&&r.sessionLevel);let s=e==null||(i=e.undoRedo)==null?void 0:i.sessionLevel;this._mode=new qn;let c=new Set,l=e.modes.reduce((e,t)=>{if(c.has(t.mode))throw Error(`There is already a ${t.mode} mode provided`);return c.add(t.mode),e[t.mode]=t,e},{}),u=Object.keys(l);if(u.length===0)throw Error(`No modes provided`);u.forEach(e=>{l[e].type===it.Select&&this._instanceSelectModes.push(e)}),this._modes=D({},l,{static:this._mode}),this._eventListeners={change:[],select:[],deselect:[],finish:[],ready:[],history:[]},this._store=new pr({tracked:!!e.tracked,idStrategy:e.idStrategy?e.idStrategy:void 0});let d=e=>{let t=[];return{changed:t,unchanged:this._store.copyAll().filter(n=>!e.includes(n.id)||(t.push(n),!1))}},f=(e,t)=>{this._enabled&&(this._eventListeners.finish.forEach(n=>{n(e,t)}),this.emitHistoryChangeAfterFinish())},p=(e,t,n)=>{if(!this._enabled)return;this._eventListeners.change.forEach(r=>{r(e,t,n)}),this.emitDrawingPushIfHistoryChangedFromLastSnapshot();let{changed:r,unchanged:i}=d(e);t===`create`?this._adapter.render({created:r,deletedIds:[],unchanged:i,updated:[]},this.getModeStyles()):t===`update`?this._adapter.render({created:[],deletedIds:[],unchanged:i,updated:r},this.getModeStyles()):t===`delete`?this._adapter.render({created:[],deletedIds:e,unchanged:i,updated:[]},this.getModeStyles()):t===`styling`&&this._adapter.render({created:[],deletedIds:[],unchanged:i,updated:[]},this.getModeStyles())},m=e=>{if(!this._enabled)return;this._eventListeners.select.forEach(t=>{t(e)});let{changed:t,unchanged:n}=d([e]);this._adapter.render({created:[],deletedIds:[],unchanged:n,updated:t},this.getModeStyles())},h=e=>{if(!this._enabled)return;this._eventListeners.deselect.forEach(t=>{t(e)});let{changed:t,unchanged:n}=d([e]);t&&this._adapter.render({created:[],deletedIds:[],unchanged:n,updated:t},this.getModeStyles())};Object.keys(this._modes).forEach(e=>{var t;this._modes[e].register({mode:e,store:this._store,setCursor:this._adapter.setCursor.bind(this._adapter),project:this._adapter.project.bind(this._adapter),unproject:this._adapter.unproject.bind(this._adapter),setDoubleClickToZoom:this._adapter.setDoubleClickToZoom.bind(this._adapter),onChange:p,onSelect:m,onDeselect:h,onFinish:f,coordinatePrecision:this._adapter.getCoordinatePrecision(),undoRedoMaxStackSize:(t=this.drawingUndoRedo)==null||t.getMaxStackSize==null?void 0:t.getMaxStackSize()})}),this.sessionUndoRedoEnabled&&s&&(this.sessionUndoRedo=s,s.register({draw:this,onHistoryChange:e=>{var t;(t=this.undoRedoCoordinator)==null||t.emitStackHistoryChange(e)}})),this.drawingUndoRedo&&this.drawingUndoRedo.register({getModeState:()=>this.getModeState(),getModeHistorySizes:()=>this.getDrawingHistorySizes(),undoMode:()=>{this._mode.undo&&this._mode.undo()},redoMode:()=>{this._mode.redo&&this._mode.redo()},clearModeHistory:()=>{let e=this._mode;e.clearHistory&&e.clearHistory()},onHistoryChange:e=>{var t;(t=this.undoRedoCoordinator)==null||t.emitStackHistoryChange(e)}}),this.undoRedoCoordinator=new Gr({modeLevel:this.drawingUndoRedo,sessionLevel:this.sessionUndoRedo,shouldPreferMode:()=>this.getModeState()===`drawing`,onHistoryChange:e=>{this._eventListeners.history.forEach(t=>{t(e)})},shouldEmitHistoryChange:()=>this._enabled})}checkEnabled(){if(!this._enabled)throw Error(`Terra Draw is not enabled`)}handleUndoRedoKeyboardShortcut(e){if(!this.drawingUndoRedo&&!this.sessionUndoRedoEnabled||!this.keyboardShortcutsMatcher)return!1;let t=this.keyboardShortcutsMatcher.isUndoKeyboardShortcut(e),n=this.keyboardShortcutsMatcher.isRedoKeyboardShortcut(e);if(t){if(!this.canUndo())return!1;let t=this.undo();return t&&e.preventDefault(),t}if(n){if(!this.canRedo())return!1;let t=this.redo();return t&&e.preventDefault(),t}return!1}getDrawingHistorySizes(){return{undoSize:this._mode.undoSize&&typeof this._mode.undoSize==`function`?this._mode.undoSize():0,redoSize:this._mode.redoSize&&typeof this._mode.redoSize==`function`?this._mode.redoSize():0}}emitDrawingPushIfHistoryChangedFromLastSnapshot(){this.drawingUndoRedo&&this.drawingUndoRedo.emitPushIfHistoryChangedFromLastSnapshot()}emitDrawingPushIfHistoryChanged(e){this.drawingUndoRedo&&this.drawingUndoRedo.emitPushIfHistoryChanged(e)}emitHistoryChangeAfterFinish(){var e;(e=this.undoRedoCoordinator)==null||e.emitPushAfterFinish()}getModeStyles(){let e={},t=this._instanceSelectModes.includes(this._mode.mode)?this._mode.mode:void 0;return Object.keys(this._modes).forEach(n=>{e[n]=e=>t&&e.properties[A.SELECTED]?this._modes[t].styleFeature.bind(this._modes[t])(e):this._modes[n].styleFeature.bind(this._modes[n])(e)}),e}featuresAtLocation({lng:e,lat:t},n){let r=n&&n.pointerDistance!==void 0?n.pointerDistance:30,i=!n||n.ignoreSelectFeatures===void 0||n.ignoreSelectFeatures,a=!(!n||n.ignoreCoordinatePoints===void 0)&&n.ignoreCoordinatePoints,o=!(!n||n.ignoreCurrentlyDrawing===void 0)&&n.ignoreCurrentlyDrawing,s=!(!n||n.ignoreClosingPoints===void 0)&&n.ignoreClosingPoints,c=!(!n||n.ignoreSnappingPoints===void 0)&&n.ignoreSnappingPoints,l=this._adapter.unproject.bind(this._adapter),u=this._adapter.project.bind(this._adapter),d=u(e,t),f=It({unproject:l,point:d,pointerDistance:r});return this._store.search(f).filter(l=>{if(i&&(l.properties[A.MID_POINT]||l.properties[A.SELECTION_POINT])||a&&l.properties[j.COORDINATE_POINT]||s&&l.properties[j.CLOSING_POINT]||o&&l.properties[j.CURRENTLY_DRAWING]||c&&l.properties[j.SNAPPING_POINT])return!1;if(l.geometry.type===`Point`){let e=l.geometry.coordinates;return W(d,u(e[0],e[1]))<r}if(l.geometry.type===`LineString`){let e=l.geometry.coordinates;for(let t=0;t<e.length-1;t++){let n=e[t],i=e[t+1];if(Nn(d,u(n[0],n[1]),u(i[0],i[1]))<r)return!0}return!1}if(Mn([e,t],l.geometry.coordinates))return!0;if(n!=null&&n.includePolygonsWithinPointerDistance){let e=l.geometry.coordinates;for(let t of e)for(let e=0;e<t.length-1;e++){let n=t[e],i=t[e+1];if(Nn(d,u(n[0],n[1]),u(i[0],i[1]))<r)return!0}}return!1}).map(r=>{if(n==null||!n.addClosestCoordinateInfoToProperties)return r;let i;if(r.geometry.type===`Polygon`)i=r.geometry.coordinates[0].slice(0,-1);else{if(r.geometry.type!==`LineString`)return r;i=r.geometry.coordinates}let a,o=-1,s=1/0;for(let e=0;e<i.length;e++){let t=i[e],n=W(u(t[0],t[1]),d);n<s&&(o=e,s=n,a=t)}return r.properties.closestCoordinateIndexToEvent=o,r.properties.closestCoordinatePixelDistanceToEvent=s,r.properties.closestCoordinateDistanceKmToEvent=P(a,[e,t]),r})}getSelectModeOrThrow(e=void 0){let t=this.getSelectMode({switchToSelectMode:!0,selectMode:e});if(!t)throw Error(`No select mode defined in instance`);return t}getSelectMode({switchToSelectMode:e,selectMode:t}){this.checkEnabled();let n=this.getMode();if(this._instanceSelectModes.length===0)return null;if(t!==void 0&&!this._instanceSelectModes.includes(t))throw Error(`No select mode with this name present: ${t}`);let r;return r=t===void 0?this._instanceSelectModes.includes(n)?n:this._instanceSelectModes[0]:t,e&&n!==r&&this.setMode(r),this._modes[r]}isGuidanceFeature(e){return!!(e.properties[A.MID_POINT]||e.properties[A.SELECTION_POINT]||e.properties[j.COORDINATE_POINT]||e.properties[j.SNAPPING_POINT])}setModeStyles(e,t){if(this.checkEnabled(),!this._modes[e])throw Error(`No mode with this name present`);this._modes[e].styles=t}updateModeOptions(e,t){if(this.checkEnabled(),!this._modes[e])throw Error(`No mode with this name present`);this._modes[e].updateOptions(t)}getSnapshot(){return this._store.copyAll()}getSnapshotFeature(e){if(this._store.has(e))return this._store.copy(e)}clear(){this.checkEnabled(),this._adapter.clear()}get enabled(){return this._enabled}set enabled(e){throw Error(`Enabled is read only`)}getMode(){return this._mode.mode}getModeState(){return this._mode.state}setMode(e){if(this.checkEnabled(),!this._modes[e])throw Error(`No mode with this name present`);this._mode.stop(),this._mode=this._modes[e],this._mode.start()}removeFeatures(e){this.checkEnabled();let t=[],n=[],r;e.forEach(e=>{if(!this._store.has(e))throw Error(`No feature with id ${e}, can not delete`);let i=this._store.getPropertiesCopy(e);i[A.SELECTED]&&this.deselectFeature(e),i[j.CURRENTLY_DRAWING]&&this._modes[i.mode]?r=i.mode:(i[j.COORDINATE_POINT_IDS]&&t.push(...i[j.COORDINATE_POINT_IDS]),n.push(e))}),this._store.delete([...n,...t],{origin:`api`}),r&&this._modes[r]&&this._modes[r].cleanUp()&&this._modes[r].cleanUp()}selectFeature(e,t){this.getSelectModeOrThrow(t).selectFeature(e)}deselectFeature(e){this.getSelectModeOrThrow().deselectFeature(e)}getFeatureId(){return this._store.getId()}hasFeature(e){return this._store.has(e)}checkIsReservedProperty(e){return![...Object.values(A),...Object.values(j)].includes(e)}updateFeatureProperties(e,t){if(!this._store.has(e))throw Error(`No feature with id ${e} present in store`);let n=this._store.copy(e);if(this.isGuidanceFeature(n))throw Error(`Guidance features are not allowed to be updated directly.`);let r=n.properties.mode;if(!this._modes[r])throw Error(`No mode with name ${r} present in instance`);let i=Object.entries(t);i.forEach(([e,t])=>{if(!this.checkIsReservedProperty(e))throw Error(`You are trying to update a reserved property name: ${e}. Please choose another name.`);if(t!==void 0&&!Nr(t))throw Error(`Invalid JSON value provided for property ${e}`)}),this._store.updateProperty(i.map(([e,t])=>({id:n.id,property:e,value:t})),{origin:`api`})}updateFeatureGeometry(e,t){if(!this._store.has(e))throw Error(`No feature with id ${e} present in store`);let n=this._store.copy(e);if(this.isGuidanceFeature(n))throw Error(`Guidance features are not allowed to be updated directly.`);if(!(n&&t&&t.type&&t.coordinates))throw Error(`Invalid geometry provided`);if(t.type!==n.geometry.type)throw Error(`Geometry type mismatch: expected ${n.geometry.type}, got ${t.type}`);let r=n.properties.mode,i=this._modes[r];if(!i)throw Error(`No mode with name ${r} present in instance`);let a=D({},n,{geometry:t}),o=i.validateFeature(a);if(!o.valid)throw Error(`Feature validation failed: ${o.reason||`Unknown reason`}`);if(this._store.updateGeometry([{id:n.id,geometry:t}],{origin:`api`}),i.afterFeatureUpdated){i.afterFeatureUpdated(a);let e=a.properties[A.SELECTED],t=this.getSelectMode({switchToSelectMode:!1});t&&e&&t.afterFeatureUpdated(a)}}transformFeatureGeometry(e,t){if(!this._store.has(e))throw Error(`No feature with id ${e} present in store`);let n=this._store.copy(e);if(this.isGuidanceFeature(n))throw Error(`Guidance features are not allowed to be updated directly.`);let r=n.properties.mode,i=this._modes[r];if(!i)throw Error(`No mode with name ${r} present in instance`);let a;if(n.geometry.type===`Polygon`)a=n.geometry.coordinates[0];else{if(n.geometry.type!==`LineString`)throw Error(`Feature geometry type ${n.geometry.type} is not supported for transformation`);a=n.geometry.coordinates}if(t.projection!=`web-mercator`)throw Error(`Projection ${t.projection} is not currently supported for transformation`);if(t.type===`scale`){let{x:e,y:n}=L(t.origin[0],t.origin[1]);Hn({coordinates:a,originX:e,originY:n,xScale:t.options.xScale||1,yScale:t.options.yScale||1})}else t.type===`rotate`&&(n=Rn(n,t.options.angle||0),a=n.geometry.type===`Polygon`?n.geometry.coordinates[0]:n.geometry.coordinates);if(a=a.map(e=>[I(e[0],this._adapter.getCoordinatePrecision()),I(e[1],this._adapter.getCoordinatePrecision())]),n.geometry.coordinates=n.geometry.type===`Polygon`?[a]:a,this._store.updateGeometry([{id:n.id,geometry:n.geometry}],{origin:`api`}),i.afterFeatureUpdated){i.afterFeatureUpdated(n);let e=n.properties[A.SELECTED],t=this.getSelectMode({switchToSelectMode:!1});t&&e&&t.afterFeatureUpdated(n)}}undo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.undo()}canUndo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.canUndo()}canRedo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.canRedo()}redo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.redo()}clearUndoRedoHistory(){this.checkEnabled(),this.undoRedoCoordinator&&this.undoRedoCoordinator.clearHistory()}addFeatures(e){return this.checkEnabled(),e.length===0?[]:this._store.load(e,e=>{if(tt(e)){let t=e.properties.mode,n=this._modes[t];if(!n)return{id:e.id,valid:!1,reason:`${t} mode is not in the list of instantiated modes`};let r=n.validateFeature.bind(n)(e);return{id:e.id,valid:r.valid,reason:r.reason?r.reason:r.valid?void 0:`Feature is invalid`}}return{id:e.id,valid:!1,reason:`Mode property does not exist`}},e=>{if(tt(e)){let t=this._modes[e.properties.mode];t&&t.afterFeatureAdded&&t.afterFeatureAdded(e)}},{origin:`api`})}start(){this._enabled||(this._enabled=!0,this._adapter.register({onReady:()=>{this._eventListeners.ready.forEach(e=>{e()})},getState:()=>this._mode.state,onClick:e=>{let t=this.drawingUndoRedo?this.drawingUndoRedo.getHistorySizes():{undoSize:0,redoSize:0};this._mode.onClick(e),this.emitDrawingPushIfHistoryChanged(t)},onMouseMove:e=>{this._mode.onMouseMove(e)},onKeyDown:e=>{this.handleUndoRedoKeyboardShortcut(e)||this._mode.onKeyDown(e)},onKeyUp:e=>{let t=this.drawingUndoRedo?this.drawingUndoRedo.getHistorySizes():{undoSize:0,redoSize:0};this._mode.onKeyUp(e),this.emitDrawingPushIfHistoryChanged(t)},onDragStart:(e,t)=>{this._mode.onDragStart(e,t)},onDrag:(e,t)=>{this._mode.onDrag(e,t)},onDragEnd:(e,t)=>{this._mode.onDragEnd(e,t)},onClear:()=>{this._mode.cleanUp(),this._store.clear({origin:`api`})}}))}getFeaturesAtLngLat(e,t){let{lng:n,lat:r}=e;return this.featuresAtLocation({lng:n,lat:r},t)}getFeaturesAtPointerEvent(e,t){let n=this._adapter.getLngLatFromEvent.bind(this._adapter)(e);return n===null?[]:this.featuresAtLocation(n,t)}stop(){this._enabled&&(this._enabled=!1,this._adapter.unregister())}on(e,t){let n=this._eventListeners[e];n.includes(t)||n.push(t)}off(e,t){let n=this._eventListeners[e];n.includes(t)&&n.splice(n.indexOf(t),1)}},qr=class extends kr.TerraDrawBaseAdapter{constructor(e){super(e),this._renderBeforeLayerId=void 0,this._prefixId=void 0,this._initialDragPan=void 0,this._initialDragRotate=void 0,this._nextRender=void 0,this._map=void 0,this._container=void 0,this.changedIds={deletion:!1,points:!1,linestrings:!1,polygons:!1,styling:!1},this._map=e.map,this._container=this._map.getContainer(),this._initialDragRotate=this._map.dragRotate.isEnabled(),this._initialDragPan=this._map.dragPan.isEnabled(),this._renderBeforeLayerId=e.renderBelowLayerId,this._prefixId=e.prefixId||`td`}hashCode(e){let t=0;for(let n=0;n<e.length;n++)t=(t<<5)-t+e.charCodeAt(n),t|=0;return Math.abs(t)}resizeImage(e,t,n,r){let i=new Image;i.crossOrigin=`anonymous`,i.onload=()=>{let e=document.createElement(`canvas`);e.width=t,e.height=n;let a=e.getContext(`2d`);if(!a)throw Error(`Could not get canvas context`);a.drawImage(i,0,0,t,n),r(e.toDataURL())},i.src=e}_addGeoJSONSource(e,t){this._map.addSource(e,{type:`geojson`,data:{type:`FeatureCollection`,features:t},tolerance:0})}_addFillLayer(e){return this._map.addLayer({id:e,source:e,type:`fill`,layout:{"fill-sort-key":[`get`,`zIndex`]},paint:{"fill-color":[`get`,`polygonFillColor`],"fill-opacity":[`get`,`polygonFillOpacity`]}})}_addFillOutlineLayer(e){return this._map.addLayer({id:e+`-outline`,source:e,type:`line`,layout:{"line-sort-key":[`get`,`zIndex`]},paint:{"line-width":[`get`,`polygonOutlineWidth`],"line-color":[`get`,`polygonOutlineColor`],"line-opacity":[`get`,`polygonOutlineOpacity`]}})}_addLineLayer(e){return this._map.addLayer({id:e,source:e,type:`line`,layout:{"line-sort-key":[`get`,`zIndex`]},paint:{"line-width":[`get`,`lineStringWidth`],"line-color":[`get`,`lineStringColor`],"line-opacity":[`get`,`lineStringOpacity`]}})}_addPointLayer(e){return this._map.addLayer({id:e,source:e,type:`circle`,layout:{"circle-sort-key":[`get`,`zIndex`]},paint:{"circle-stroke-color":[`get`,`pointOutlineColor`],"circle-stroke-width":[`get`,`pointOutlineWidth`],"circle-stroke-opacity":[`get`,`pointOutlineOpacity`],"circle-radius":[`get`,`pointWidth`],"circle-color":[`get`,`pointColor`],"circle-opacity":[`get`,`pointOpacity`]}})}_addMarkerLayer(e){return this._map.addLayer({id:e+`-marker`,source:e,type:`symbol`,filter:[`has`,`markerId`],layout:{"icon-image":[`image`,[`get`,`markerId`]],"icon-anchor":`bottom`,"icon-allow-overlap":!0}})}_addLayer(e,t){t===`Point`&&(this._addPointLayer(e),this._addMarkerLayer(e)),t===`LineString`&&this._addLineLayer(e),t===`Polygon`&&(this._addFillLayer(e),this._addFillOutlineLayer(e))}_addGeoJSONLayer(e,t){let n=`${this._prefixId}-${e.toLowerCase()}`;return this._addGeoJSONSource(n,t),this._addLayer(n,e),n}_setGeoJSONLayerData(e,t){let n=`${this._prefixId}-${e.toLowerCase()}`;return this._map.getSource(n).setData({type:`FeatureCollection`,features:t}),n}updateChangedIds(e){[...e.updated,...e.created].forEach(e=>{e.geometry.type===`Point`?this.changedIds.points=!0:e.geometry.type===`LineString`?this.changedIds.linestrings=!0:e.geometry.type===`Polygon`&&(this.changedIds.polygons=!0)}),e.deletedIds.length>0&&(this.changedIds.deletion=!0),e.created.length===0&&e.updated.length===0&&e.deletedIds.length===0&&(this.changedIds.styling=!0)}getLngLatFromEvent(e){let{left:t,top:n}=this._container.getBoundingClientRect();return this.unproject(e.clientX-t,e.clientY-n)}getMapEventElement(){return this._map.getCanvas()}setDraggability(e){e?(this._initialDragRotate&&this._map.dragRotate.enable(),this._initialDragPan&&this._map.dragPan.enable()):(this._initialDragRotate&&this._map.dragRotate.disable(),this._initialDragPan&&this._map.dragPan.disable())}project(e,t){let{x:n,y:r}=this._map.project({lng:e,lat:t});return{x:n,y:r}}unproject(e,t){let{lng:n,lat:r}=this._map.unproject({x:e,y:t});return{lng:n,lat:r}}setCursor(e){let t=this._map.getCanvas();e===`unset`?t.style.removeProperty(`cursor`):t.style.cursor=e}setDoubleClickToZoom(e){e?this._map.doubleClickZoom.enable():this._map.doubleClickZoom.disable()}render(e,t){this.updateChangedIds(e),this._nextRender&&cancelAnimationFrame(this._nextRender),this._nextRender=requestAnimationFrame(()=>{if(!this._currentModeCallbacks)return;let n=[...e.created,...e.updated,...e.unchanged],r=[],i=[],a=[];for(let e=0;e<n.length;e++){let o=n[e],{properties:s}=o,c=t[s.mode](o);if(s.zIndex=c.zIndex,s.zIndex=c.zIndex,o.geometry.type===`Point`){s.pointColor=c.pointColor,s.pointOutlineColor=c.pointOutlineColor,s.pointOutlineWidth=c.pointOutlineWidth;let e=c.pointOutlineOpacity;s.pointOutlineOpacity=e===void 0?1:e,s.pointWidth=c.pointWidth;let t=c.pointOpacity;if(s.pointOpacity=t===void 0?1:t,c.markerUrl&&c.markerWidth&&c.markerHeight){let e=`marker-${this.hashCode(c.markerUrl)}`;this._map.hasImage(e)||this.resizeImage(c.markerUrl,c.markerWidth,c.markerHeight,t=>{this._map.loadImage(t).then(t=>{this._map.hasImage(e)||this._map.addImage(e,t.data)})}),s.markerId=e,s.pointWidth=0}r.push(o)}else if(o.geometry.type===`LineString`){s.lineStringColor=c.lineStringColor,s.lineStringWidth=c.lineStringWidth;let e=c.lineStringOpacity;s.lineStringOpacity=e===void 0?1:e,i.push(o)}else if(o.geometry.type===`Polygon`){let e=c.polygonOutlineOpacity;s.polygonFillColor=c.polygonFillColor,s.polygonFillOpacity=c.polygonFillOpacity,s.polygonOutlineOpacity=e===void 0?1:e,s.polygonOutlineColor=c.polygonOutlineColor,s.polygonOutlineWidth=c.polygonOutlineWidth,a.push(o)}}let o=this.changedIds.deletion||this.changedIds.styling,s=o||this.changedIds.linestrings,c=o||this.changedIds.polygons;(o||this.changedIds.points)&&this._setGeoJSONLayerData(`Point`,r),s&&this._setGeoJSONLayerData(`LineString`,i),c&&this._setGeoJSONLayerData(`Polygon`,a),this.changedIds={points:!1,linestrings:!1,polygons:!1,deletion:!1,styling:!1}})}clear(){this._currentModeCallbacks&&(this._currentModeCallbacks.onClear(),this._nextRender&&=(cancelAnimationFrame(this._nextRender),void 0),this._setGeoJSONLayerData(`Point`,[]),this._setGeoJSONLayerData(`LineString`,[]),this._setGeoJSONLayerData(`Polygon`,[]))}getCoordinatePrecision(){return super.getCoordinatePrecision()}unregister(){super.unregister(),this.changedIds={points:!1,linestrings:!1,polygons:!1,deletion:!1,styling:!1},this._map.removeLayer(`${this._prefixId}-point`),this._map.removeLayer(`${this._prefixId}-point-marker`),this._map.removeSource(`${this._prefixId}-point`),this._map.removeLayer(`${this._prefixId}-linestring`),this._map.removeSource(`${this._prefixId}-linestring`),this._map.removeLayer(`${this._prefixId}-polygon`),this._map.removeLayer(`${this._prefixId}-polygon-outline`),this._map.removeSource(`${this._prefixId}-polygon`)}register(e){var t;super.register(e);let n=this._addGeoJSONLayer(`Polygon`,[]),r=this._addGeoJSONLayer(`LineString`,[]),i=this._addGeoJSONLayer(`Point`,[]);var a;this._renderBeforeLayerId&&(this._map.moveLayer(i,this._renderBeforeLayerId),this._map.moveLayer(r,i),this._map.moveLayer(`${n}-outline`,r),this._map.moveLayer(n,`${n}-outline`)),(t=this._currentModeCallbacks)!=null&&t.onReady&&((a=this._currentModeCallbacks)==null||a.onReady())}},Jr={modes:[`render`,`point`,`marker`,`linestring`,`polygon`,`rectangle`,`angled-rectangle`,`sensor`,`sector`,`circle`,`freehand`,`freehand-linestring`,`select`,`delete-selection`,`delete`,`undo`,`redo`,`download`],open:!1},Yr={modes:[`render`,`point`,`marker`,`linestring`,`polygon`,`rectangle`,`angled-rectangle`,`sensor`,`sector`,`circle`,`freehand`,`freehand-linestring`,`select`,`delete-selection`,`delete`,`undo`,`redo`,`download`],open:!1,modeOptions:{point:new vn({editable:!0,styles:{pointColor:`#FFFFFF`,pointWidth:5,pointOutlineColor:`#666666`,pointOutlineWidth:1}}),marker:new Fr({editable:!0,styles:{markerUrl:`data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'%20standalone='no'?%3e%3csvg%20xmlns:dc='http://purl.org/dc/elements/1.1/'%20xmlns:cc='http://creativecommons.org/ns%23'%20xmlns:rdf='http://www.w3.org/1999/02/22-rdf-syntax-ns%23'%20xmlns:svg='http://www.w3.org/2000/svg'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:sodipodi='http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd'%20xmlns:inkscape='http://www.inkscape.org/namespaces/inkscape'%20inkscape:version='1.0%20(4035a4fb49,%202020-05-01)'%20sodipodi:docname='poi.svg'%20id='svg4460'%20height='100'%20width='100'%20version='1.1'%3e%3csodipodi:namedview%20inkscape:document-rotation='0'%20inkscape:current-layer='svg4460'%20inkscape:window-maximized='1'%20inkscape:window-y='-8'%20inkscape:window-x='-8'%20inkscape:cy='70.031285'%20inkscape:cx='-78.460726'%20inkscape:zoom='2.02'%20showgrid='false'%20id='namedview11'%20inkscape:window-height='1017'%20inkscape:window-width='1920'%20inkscape:pageshadow='2'%20inkscape:pageopacity='0'%20guidetolerance='10'%20gridtolerance='10'%20objecttolerance='10'%20borderopacity='1'%20bordercolor='%23666666'%20pagecolor='%23ffffff'%20/%3e%3cdefs%20id='defs4462'%20/%3e%3cmetadata%20id='metadata4465'%3e%3crdf:RDF%3e%3ccc:Work%20rdf:about=''%3e%3cdc:format%3eimage/svg+xml%3c/dc:format%3e%3cdc:type%20rdf:resource='http://purl.org/dc/dcmitype/StillImage'%20/%3e%3cdc:title%3e%3c/dc:title%3e%3c/cc:Work%3e%3c/rdf:RDF%3e%3c/metadata%3e%3cpath%20d='M%2050.001528,3.3861402e-7%20C%2030.763177,3.3861402e-7%2015,15.718144%2015,34.901534%20c%200,7.432782%202.373565,14.339962%206.391689,20.019029%20l%2024.338528,42.073163%20c%203.40849,4.452814%205.674917,3.607154%208.509014,-0.23458%20L%2081.083105,51.075788%20C%2081.625418,50.0948%2082.050328,49.050173%2082.421327,47.983517%2084.078241,43.936622%2085.000002,39.521943%2085,34.901534%2085,15.718144%2069.23988,3.3861402e-7%2050.001528,3.3861402e-7%20Z%20m%200,16.35400066138598%20c%2010.359296,0%2018.597616,8.21783%2018.597618,18.547533%200,10.329703%20-8.238322,18.544487%20-18.597618,18.544487%20-10.359299,0%20-18.600672,-8.214784%20-18.600672,-18.544487%200,-10.329703%208.241373,-18.547533%2018.600672,-18.547533%20z'%20style='fill:rgb(95,%2099,%20104);stroke-width:4.26019'%20id='path4135'%20/%3e%3c/svg%3e`,markerWidth:27,markerHeight:27}}),linestring:new dn({editable:!0,styles:{lineStringColor:`#666666`,lineStringWidth:2,closingPointColor:`#FFFFFF`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),polygon:new xn({editable:!0,styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2,closingPointColor:`#FAFAFA`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),rectangle:new wn({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),"angled-rectangle":new br({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),circle:new jt({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),freehand:new Ft({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2,closingPointColor:`#FAFAFA`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),"freehand-linestring":new Mr({styles:{lineStringColor:`#666666`,lineStringWidth:2,closingPointColor:`#FFFFFF`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),sensor:new Dr({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2,centerPointColor:`#FAFAFA`,centerPointWidth:3,centerPointOutlineColor:`#666666`,centerPointOutlineWidth:1}}),sector:new wr({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),select:new Kn({flags:{point:{feature:{draggable:!1}},marker:{feature:{draggable:!1}},polygon:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},linestring:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},freehand:{feature:{draggable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},"freehand-linestring":{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},circle:{feature:{draggable:!0,coordinates:{resizable:`center`,deletable:!1,midpoints:!1}}},rectangle:{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},"angled-rectangle":{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},sensor:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},sector:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}}}})},pointLayerLabelSpec:{id:`{prefix}-point-label`,type:`symbol`,source:`{prefix}-point`,filter:[`all`,[`==`,`$type`,`Point`],[`any`,[`==`,`mode`,`point`],[`==`,`mode`,`marker`]]],layout:{"text-field":[`case`,[`all`,[`has`,`elevation`],[`>`,[`get`,`elevation`],0]],[`concat`,`Alt. `,[`to-string`,[`floor`,[`get`,`elevation`]]],` `,[`get`,`elevationUnit`]],``],"symbol-placement":`point`,"text-size":[`interpolate`,[`linear`],[`zoom`],5,10,10,12,13,14,14,16,18,18],"text-overlap":`always`,"text-variable-anchor":[`left`,`right`,`top`,`bottom`],"text-radial-offset":.5,"text-justify":`center`,"text-letter-spacing":.05},paint:{"text-halo-color":`#F7F7F7`,"text-halo-width":2,"text-color":`#232E3D`}},lineLayerLabelSpec:{id:`{prefix}-line-label`,type:`symbol`,source:`{prefix}-line-source`,filter:[`==`,`$type`,`Point`],layout:{"text-field":[`concat`,[`to-string`,[`get`,`distance`]],` `,[`get`,`unit`],[`case`,[`==`,[`get`,`total`],0],``,[`concat`,`
|
|
1
|
+
(function(e,t){typeof exports==`object`&&typeof module<`u`?t(exports,require(`maplibre-gl`),require(`@turf/bbox`)):typeof define==`function`&&define.amd?define([`exports`,`maplibre-gl`,`@turf/bbox`],t):(e=typeof globalThis<`u`?globalThis:e||self,t(e.TeeeMapSDK={},e.maplibregl,e.turfBbox))})(this,function(e,t,n){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var r=Object.create,i=Object.defineProperty,a=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.getPrototypeOf,c=Object.prototype.hasOwnProperty,l=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var s=o(t),l=0,u=s.length,d;l<u;l++)d=s[l],!c.call(e,d)&&d!==n&&i(e,d,{get:(e=>t[e]).bind(null,d),enumerable:!(r=a(t,d))||r.enumerable});return e},u=(e,t,n)=>(n=e==null?{}:r(s(e)),l(t||!e||!e.__esModule?i(n,`default`,{value:e,enumerable:!0}):n,e));t=u(t,1),n=u(n,1);var d=async()=>{let e=document.createElement(`canvas`);e.width=25,e.height=17;let t=e.getContext(`2d`);if(!t)throw Error(`无法获取 Canvas 上下文`);t.rect(0,0,e.width,e.height),t.fillStyle=`rgba(0, 0, 0, 0)`,t.fill(),t.strokeStyle=`red`,t.lineWidth=3,t.stroke();let n=new Image;return n.src=e.toDataURL(),new Promise((e,t)=>{n.onload=()=>e(n),n.onerror=()=>t(Error(`Failed to load redBoxIcon image`))})},f=async()=>{let e=document.createElement(`canvas`);e.width=64,e.height=64;let t=e.getContext(`2d`);if(!t)throw Error(`无法获取 Canvas 上下文`);let n=e.width/2,r=e.height/2;t.beginPath(),t.arc(n,r,20,0,Math.PI*2),t.fillStyle=`rgba(0, 0, 0, 0)`,t.fill(),t.strokeStyle=`#ffffff`,t.lineWidth=3,t.setLineDash([6,6]),t.lineCap=`round`,t.lineJoin=`round`,t.stroke();let i=new Image;return i.src=e.toDataURL(),new Promise((e,t)=>{i.onload=()=>e(i),i.onerror=()=>t(Error(`Failed to load dashCircle image`))})},p=async(e=`h`,t=`r`,n=``,r=``)=>{let i=e===`h`,a=t===`r`,o=`transparent`,s=n||o,c=r||o,l=27*.5,u=3*1.75,d=i?27*1.25:27,f=12*1.2,p=3+(i?f:0)+54+u,m=d+l,h=document.createElement(`canvas`);h.width=p,h.height=m;let g=h.getContext(`2d`);if(!g)throw Error(`无法获取 Canvas 上下文`);g.clearRect(0,0,p,m),g.save(),a||(g.translate(p/2,m/2),g.scale(1,-1),g.translate(-p/2,-m/2)),g.strokeStyle=`rgb(255,255,255)`,g.fillStyle=`rgb(255,255,255)`,3/2-u/2+5;let _=m-l;g.beginPath(),g.rect(3.875,_,u,l),g.fill(),g.beginPath(),g.lineWidth=3;let v=6.5,y=m-l-d,ee=m-l;g.moveTo(v,y),g.lineTo(v,ee),g.stroke(),g.lineWidth=2;let b=y+27/2,x=16+(i?f:0)+5,te=x+27-1;if(g.beginPath(),g.strokeStyle=`rgb(255,255,255)`,g.lineWidth=2,g.fillStyle=s,g.arc(x,b,12,0,Math.PI*2),g.fill(),g.stroke(),g.beginPath(),g.strokeStyle=`rgb(255,255,255)`,g.lineWidth=2,g.fillStyle=c,g.arc(te,b,12,0,Math.PI*2),g.fill(),g.stroke(),i){g.beginPath(),g.lineWidth=2,g.strokeStyle=`rgb(255,255,255)`,v+3/2;let e=x-12-2/2,t=b;g.moveTo(8,t),g.lineTo(e,t),g.stroke()}g.restore();let ne=new Image;return ne.src=h.toDataURL(),new Promise((e,t)=>{ne.onload=()=>e(ne),ne.onerror=t})},m=async(e=`h`,t=`r`)=>{let n=e===`h`,r=t===`r`,i=12*1.2,a=27*.5,o=n?27*1.25:27,s=3+(n?i:0)+54+5.25+8,c=o+a+8,l=document.createElement(`canvas`);l.width=s,l.height=c;let u=l.getContext(`2d`);if(!u)throw Error(`无法获取 Canvas 上下文`);u.clearRect(0,0,s,c),u.save(),r||(u.translate(s/2,c/2),u.scale(1,-1),u.translate(-s/2,-c/2));let d=c-a-o-4+27/2,f=16+(n?i:0)+4+27,p=1.5,m=f+12+4*1.5,h=d-12,g=d+12+8;u.beginPath(),u.setLineDash([8,8]),u.strokeStyle=`#ffffff`,u.lineWidth=3,u.rect(p,h,m-p,g-h),u.stroke(),u.restore();let _=new Image;return _.src=l.toDataURL(),new Promise((e,t)=>{_.onload=()=>e(_),_.onerror=t})},h=async(e=`h`,t=`r`,n=!0)=>{let r=e===`h`,i=t===`r`,a=12*1.2,o=27*.5,s=r?27*1.25:27,c=3+(r?a:0)+54+5.25,l=s+o,u=document.createElement(`canvas`);u.width=c,u.height=l;let d=u.getContext(`2d`);if(!d)throw Error(`无法获取 Canvas 上下文`);d.clearRect(0,0,c,l),d.save(),i||(d.translate(c/2,l/2),d.scale(1,-1),d.translate(-c/2,-l/2));let f=l-o-s+27/2,p=16+(r?a:0)+5,m=p+27;d.lineWidth=4,d.strokeStyle=`#ff0000`,n&&(d.beginPath(),d.moveTo(p-12,f-12),d.lineTo(p+12,f+12),d.moveTo(p+12,f-12),d.lineTo(p-12,f+12),d.stroke()),n&&(d.beginPath(),d.moveTo(m-12,f-12),d.lineTo(m+12,f+12),d.moveTo(m+12,f-12),d.lineTo(m-12,f+12),d.stroke()),d.restore();let h=new Image;return h.src=u.toDataURL(),new Promise((e,t)=>{h.onload=()=>e(h),h.onerror=t})},g=async(e=`h`,t=`r`,n,r)=>{let i=e===`h`,a=t===`r`,o=12*1.2,s=27*.5,c=i?27*1.25:27,l=3+(i?o:0)+54+5.25,u=c+s,d=document.createElement(`canvas`);d.width=l,d.height=u;let f=d.getContext(`2d`);if(!f)throw Error(`无法获取 Canvas 上下文`);f.clearRect(0,0,l,u),f.save(),a||(f.translate(l/2,u/2),f.scale(1,-1),f.translate(-l/2,-u/2));let p=u-s-c+27/2,m=16+(i?o:0)+27+5;f.save(),f.translate(m,p),f.fillStyle=n;let h=r?12:24;f.fillRect(-12,-12,h,24),r&&(f.fillStyle=r,f.fillRect(0,-12,12,24)),f.strokeStyle=`white`,f.lineWidth=2,f.strokeRect(-12,-12,24,24),f.restore(),f.restore();let g=new Image;return g.src=d.toDataURL(),new Promise((e,t)=>{g.onload=()=>e(g),g.onerror=t})},_=`data:image/svg+xml,%3c?xml%20version='1.0'%20standalone='no'?%3e%3c!DOCTYPE%20svg%20PUBLIC%20'-//W3C//DTD%20SVG%201.1//EN'%20'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3csvg%20t='1776081402940'%20class='icon'%20viewBox='0%200%201024%201024'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20p-id='9172'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20width='32'%20height='32'%3e%3cpath%20d='M675.84%20409.6v-102.4a163.84%20163.84%200%201%200-327.68%200v102.4h327.68z%20m-409.6%200v-102.4c0-135.72096%20110.03904-245.76%20245.76-245.76s245.76%20110.03904%20245.76%20245.76v102.4a81.92%2081.92%200%200%201%2081.92%2081.92v225.28c0%20135.72096-110.03904%20245.76-245.76%20245.76h-163.84c-135.72096%200-245.76-110.03904-245.76-245.76V491.52a81.92%2081.92%200%200%201%2081.92-81.92z%20m286.72%20348.16v-51.87584a40.96%2040.96%200%200%201%2014.19264-30.98624%2081.92%2081.92%200%201%200-113.07008-2.56c0.79872%200.79872%201.72032%201.6384%202.7648%202.56A40.96%2040.96%200%200%201%20471.04%20705.88416V757.76a40.96%2040.96%200%201%200%2081.92%200z'%20p-id='9173'%20fill='%23ffffff'%3e%3c/path%3e%3c/svg%3e`,v={BASE_COLOR:`rgb(85,120,182)`,BG_COLOR:`rgb(0,0,0)`},y=(e,t,n)=>{let r=document.createElement(`canvas`);r.width=66,r.height=64;let i=r.getContext(`2d`);return i?(i.clearRect(0,0,r.width,r.height),n===2&&(i.translate(66,0),i.scale(-1,1)),e===1?(i.beginPath(),i.arc(46,20,20-4/2,0,Math.PI*2),i.fillStyle=t||`rgb(255,255,255,0)`,i.strokeStyle=t||v.BASE_COLOR,i.lineWidth=4,i.fill(),i.stroke(),i.beginPath(),i.moveTo(6,40/2),i.lineTo(26,40/2),i.lineWidth=4,i.strokeStyle=v.BASE_COLOR,i.stroke(),i.beginPath(),i.lineCap=`round`,i.moveTo(8/2,0),i.lineTo(8/2,40),i.lineWidth=4,i.strokeStyle=v.BASE_COLOR,i.stroke(),i.beginPath(),i.moveTo(8/2,40),i.lineTo(8/2,64),i.lineWidth=8,i.strokeStyle=v.BASE_COLOR,i.stroke(),r):(i.beginPath(),i.arc(26,20,20-4/2,0,Math.PI*2),i.fillStyle=t||`rgb(255,255,255,0)`,i.strokeStyle=t||v.BASE_COLOR,i.lineWidth=4,i.fill(),i.stroke(),i.beginPath(),i.lineCap=`round`,i.moveTo(8/2,0),i.lineTo(8/2,40),i.lineWidth=4,i.strokeStyle=v.BASE_COLOR,i.stroke(),i.beginPath(),i.moveTo(8/2,40),i.lineTo(8/2,64),i.lineWidth=8,i.strokeStyle=v.BASE_COLOR,i.stroke(),r)):r},ee=()=>{let e=document.createElement(`canvas`);e.width=24,e.height=64;let t=e.getContext(`2d`);return t?(t.fillStyle=v.BG_COLOR,t.fillRect(0,0,24,64),t.strokeStyle=v.BASE_COLOR,t.lineWidth=8,t.strokeRect(0,0,24,64),e):e},b=()=>{let e=document.createElement(`canvas`);e.width=15,e.height=40;let t=e.getContext(`2d`);return t?(t.clearRect(0,0,e.width,e.height),t.beginPath(),t.moveTo(0,4/2),t.lineTo(15-4/2,4/2),t.moveTo(4/2,4/2),t.lineTo(4/2,36),t.moveTo(0,36),t.lineTo(15-4/2,36),t.lineWidth=4,t.strokeStyle=v.BASE_COLOR,t.stroke(),e):e},x=async(e=`h`,t=`r`,n=``)=>{let r=y(e==`h`?1:2,n,t==`l`?1:2),i=new Image;return i.src=r.toDataURL(),new Promise((e,t)=>{i.onload=()=>e(i),i.onerror=t})},te=async()=>{let e=ee(),t=new Image;return t.src=e.toDataURL(),new Promise((e,n)=>{t.onload=()=>e(t),t.onerror=n})},ne=async()=>{let e=b(),t=new Image;return t.src=e.toDataURL(),new Promise((e,n)=>{t.onload=()=>e(t),t.onerror=n})},S=function(e){return e.Blue=`blue`,e.Green=`green`,e.Red=`red`,e.Yellow=`yellow`,e.Gray=`gray`,e.Purple=`purple`,e.Red_Purple=`red-purple`,e}({}),C=function(e){return e.Red=`red`,e.Red_Yellow=`red-yellow`,e.Yellow=`yellow`,e.Yellow_Yellow=`yellow-yellow`,e.Yellow_Green=`yellow-green`,e.Green=`green`,e.Blue=`blue`,e.White=`white`,e}({}),re=async()=>{let[e,t,n,r]=await Promise.all([x(`h`,`r`,``),x(`h`,`l`,``),x(`l`,`r`,``),x(`l`,`l`,``)]),i=new Image;i.src=_;let[a,o,s]=await Promise.all([ne(),d(),f()]),[c,l,u,v]=await Promise.all([p(`h`,`r`,``),p(`h`,`l`,``),p(`l`,`r`,``),p(`l`,`l`,``)]),[y,ee,b,re]=await Promise.all([m(`h`,`r`),m(`h`,`l`),m(`l`,`r`),m(`l`,`l`)]),[w,ie,ae,oe]=await Promise.all([h(`h`,`r`),h(`h`,`l`),h(`l`,`r`),h(`l`,`l`)]),se=[`h`,`l`],ce=[`r`,`l`],le=[S.Blue,S.Green,S.Red,S.Yellow,S.Gray,S.Purple,S.Red_Purple],ue=se.flatMap(e=>ce.flatMap(t=>le.map(n=>({height:e,dir:t,color:n})))),de=await Promise.all(ue.map(({height:e,dir:t,color:n})=>g(e,t,n===S.Red_Purple?`red`:n,n===S.Red_Purple?`purple`:void 0))),fe=[C.Red,C.Red_Yellow,C.Yellow,C.Yellow_Yellow,C.Yellow_Green,C.Green,C.Blue,C.White],pe=se.flatMap(e=>ce.flatMap(t=>fe.map(n=>({height:e,dir:t,color:n})))),me=await Promise.all(pe.map(({height:e,dir:t,color:n})=>{let r=n,i;return n===C.Red_Yellow?(r=`red`,i=`yellow`):n===C.Yellow_Yellow?(r=`yellow`,i=`yellow`):n===C.Yellow_Green&&(r=`yellow`,i=`green`),p(e,t,r,i)})),T=[C.Red,C.Green,C.White,C.Blue],he=se.flatMap(e=>ce.flatMap(t=>T.map(n=>({height:e,dir:t,color:n})))),ge=await Promise.all(he.map(({height:e,dir:t,color:n})=>x(e,t,n))),_e=await te();return[{id:`icon-signal-h-r`,image:e},{id:`icon-signal-h-l`,image:t},{id:`icon-signal-l-r`,image:n},{id:`icon-signal-l-l`,image:r},{id:`icon-lock`,image:i},{id:`icon-bumper`,image:a},{id:`icon-red-box`,image:o},{id:`icon-dash-circle`,image:s},{id:`icon-ctc-signal-h-r`,image:c},{id:`icon-ctc-signal-h-l`,image:l},{id:`icon-ctc-signal-l-r`,image:u},{id:`icon-ctc-signal-l-l`,image:v},{id:`icon-ctc-box-h-r`,image:y},{id:`icon-ctc-box-h-l`,image:ee},{id:`icon-ctc-box-l-r`,image:b},{id:`icon-ctc-box-l-l`,image:re},{id:`icon-ctc-x-h-r`,image:w},{id:`icon-ctc-x-h-l`,image:ie},{id:`icon-ctc-x-l-r`,image:ae},{id:`icon-ctc-x-l-l`,image:oe},{id:`icon-jcw`,image:_e},...de.map((e,t)=>{let n=ue[t];return{id:`icon-ctc-s-${n.height}-${n.dir}-${n.color}`,image:e}}),...me.map((e,t)=>{let n=pe[t];return{id:`icon-ctc-signal-${n.height}-${n.dir}-${n.color}`,image:e}}),...ge.map((e,t)=>{let n=he[t];return{id:`icon-signal-${n.height}-${n.dir}-${n.color}`,image:e}})]},w={geojson:e=>({type:`geojson`,data:e||{type:`FeatureCollection`,features:[]},promoteId:`code`}),raster:e=>({type:`raster`,tiles:[e],scheme:`tms`,tileSize:256}),graph:e=>({type:`vector`,tiles:[e],scheme:`tms`,promoteId:`code`}),geom:e=>({type:`vector`,tiles:[e],scheme:`tms`,promoteId:`code`}),image:(e,t)=>({type:`image`,url:e,coordinates:t}),video:(e,t)=>({type:`video`,urls:e,coordinates:t}),canvas:(e,t)=>({type:`canvas`,canvas:e,coordinates:t}),mbtiles:e=>({type:`vector`,tiles:[e]})},ie={background:(e,t)=>({id:`${e.id}_${t}`,type:`background`,paint:{"background-color":`#131212`}}),track:(e,t)=>[{id:`${e.id}_${t}_lock`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#a7009e`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_lock_icon`,type:`symbol`,source:e.id,"source-layer":t,layout:{"symbol-placement":`line-center`,"icon-anchor":`top`,"icon-image":`icon-lock`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.2,15,.5,16,.6,17,.8],"icon-offset":[0,5],"icon-allow-overlap":!0,"icon-rotation-alignment":`viewport`,"icon-rotate":0},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_poweroff_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_poweroff_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_catenery_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_catenery_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_select_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#ffffff`,"line-dasharray":[.5,.5],"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}_hitarea`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],track_circuit:(e,t)=>[{id:`${e.id}_${t}_poweroff_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`subState1`],`1`],1,0]}},{id:`${e.id}_${t}_poweroff_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`subState1`],`1`],1,0]}},{id:`${e.id}_${t}_select_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#ffffff`,"line-dasharray":[.4,.4],"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}_hitarea`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":3}},{id:`${e.id}_${t}_red`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`red`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_white`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_grey`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`,visibility:`none`},paint:{"line-color":`grey`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_subpath`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`burlywood`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`4`],1,0]}},{id:`${e.id}_${t}_mainpath`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`5`],1,0]}}],signal:(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,.2,16,.6,18,.8,20,1.5],r=[];[S.Blue,S.Green,S.Red,S.Yellow,S.Gray,S.Purple,S.Red_Purple].forEach(i=>{r.push({id:`${e.id}_${t}_square_${i}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-s-h-r-${i}`,`icon-ctc-s-h-l-${i}`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-s-l-r-${i}`,`icon-ctc-s-l-l-${i}`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-right`,`top-right`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`subState1`],i],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})});let i=[];return[C.Red,C.Red_Yellow,C.Yellow,C.Yellow_Yellow,C.Yellow_Green,C.Green,C.Blue,C.White].forEach(r=>{i.push({id:`${e.id}_${t}_${r}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-h-r-${r}`,`icon-ctc-signal-h-l-${r}`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-l-r-${r}`,`icon-ctc-signal-l-l-${r}`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],r],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})}),[...i,{id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-h-r`,`icon-ctc-signal-h-l`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-signal-l-r`,`icon-ctc-signal-l-l`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}},{id:`${e.id}_${t}_box`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-box-h-r`,`icon-ctc-box-h-l`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-box-l-r`,`icon-ctc-box-l-l`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`select`],!0],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}},{id:`${e.id}_${t}_x`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-x-h-r`,`icon-ctc-x-h-l`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-ctc-x-l-r`,`icon-ctc-x-l-l`]],"icon-size":n,"icon-rotate":[`+`,[`to-number`,[`get`,`angle`]],90],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`top-left`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`subState2`],`off`],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}},...r]},bumper:(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-bumper`,"icon-size":.3,"icon-allow-overlap":!0},paint:{"icon-opacity":0}}),switch:(e,t)=>[{id:`${e.id}_${t}_hitarea`,type:`circle`,source:e.id,"source-layer":t,paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,11],"circle-color":`red`,"circle-opacity":0}},{id:`${e.id}_${t}_dash_circle`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-dash-circle`,"icon-allow-overlap":!0,"icon-size":[`interpolate`,[`linear`],[`zoom`],17,.5]},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,11,22,15],"text-font":[`Open Sans Regular`],"text-anchor":`top`,"text-offset":[0,.5],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":[`match`,[`feature-state`,`state`],`2`,`lightgreen`,`3`,`yellow`,`4`,`red`,`white`]}},{id:`${e.id}_${t}_lock`,type:`circle`,source:e.id,"source-layer":t,layout:{visibility:`visible`},paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,8],"circle-stroke-width":1.7,"circle-stroke-color":[`match`,[`feature-state`,`state`],`2`,`green`,`3`,`yellow`,`4`,`red`,`white`],"circle-color":`transparent`,"circle-stroke-opacity":[`case`,[`==`,[`feature-state`,`subState2`],`1`],1,0]}},{id:`${e.id}_${t}_danfen`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-red-box`,"icon-allow-overlap":!0,"icon-offset":[0,15],"icon-size":[`interpolate`,[`linear`],[`zoom`],5,.2,10,.5,18,1]},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`subState3`],`1`],1,0]}}],switch_loc:(e,t)=>[{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":5,"line-color":`#000000`}},{id:`${e.id}_${t}_normal`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`green`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_reverse`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`yellow`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_fourway`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":4,"line-color":`#000000`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`4`],1,0]}},{id:`${e.id}_${t}_normal_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_reverse_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_normal_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}},{id:`${e.id}_${t}_reverse_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}}],insulation:(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,1,15,1.5,16,2,17,4];return{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],paint:{"circle-radius":n,"circle-stroke-width":n,"circle-stroke-color":`#ffbb00`},layout:{visibility:`none`}}},label:(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],10,[`==`,[`get`,`category`],96],8,7],22,[`case`,[`==`,[`get`,`category`],50],16,[`==`,[`get`,`category`],96],12,13]],"text-font":[`Open Sans Regular`],"text-anchor":[`case`,[`==`,[`get`,`angle`],90],`bottom-left`,`top-right`],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`#C0C33F`}}),prevention:(e,t)=>[{id:`${e.id}_${t}_circle`,type:`circle`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[`2`,`8`,`20`,`87`],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,3,20,10],"circle-stroke-width":2,"circle-stroke-color":`red`},layout:{visibility:`none`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[`2`,`8`,`20`,`87`],!0,!1],layout:{"text-field":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`2`],`网`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`8`],`停`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`20`],`界`,`门`],"text-font":[`Open Sans Regular`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,2,20,12],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0,visibility:`none`},paint:{"text-color":`white`}}]},ae=e=>{let t=[];return e.layers.forEach((n,r)=>{let i=ie[n],a=e.sourceLayers[r];if(i){let n=i(e,a);Array.isArray(n)?t.push(...n):t.push(n)}else console.warn(`图层 ${n} 尚未实现`)}),t},oe=(e,t)=>({id:`${e.id}_${t}`,type:`background`,paint:{"background-color":`#131212`}}),se=(e,t)=>[{id:`${e.id}_${t}_lock`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#a7009e`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_lock_icon`,type:`symbol`,source:e.id,"source-layer":t,layout:{"symbol-placement":`line-center`,"icon-anchor":`top`,"icon-image":`icon-lock`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.2,15,.5,16,.6,17,.8],"icon-offset":[0,5],"icon-allow-overlap":!0,"icon-rotation-alignment":`viewport`,"icon-rotate":0},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_poweroff_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_poweroff_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_catenery_border`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_catenery_fill`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],ce=(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,2,16,3.5,18,4.5,20,5];return[{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":3}},{id:`${e.id}_${t}_red`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`red`,"line-width":n,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e.id}_${t}_white`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":n,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_grey`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`,visibility:`none`},paint:{"line-color":`grey`,"line-width":n,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_white_label`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_red_label`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`red`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}}]},le=(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,.2,16,.6,18,.8,20,1.5],r=[];return[C.Red,C.Green,C.White,C.Blue].forEach(i=>{r.push({id:`${e.id}_${t}_${i}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-h-l-${i}`,`icon-signal-h-r-${i}`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-l-l-${i}`,`icon-signal-l-r-${i}`]],"icon-size":n,"icon-rotate":[`case`,[`==`,[`get`,`posi_side`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],i],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})}),[...r,{id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-h-l`,`icon-signal-h-r`],[`case`,[`==`,[`get`,`posi_side`],1],`icon-signal-l-l`,`icon-signal-l-r`]],"icon-size":n,"icon-rotate":[`case`,[`==`,[`get`,`posi_side`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}}]},ue=(e,t)=>[{id:`${e.id}_${t}_hitarea`,type:`circle`,source:e.id,"source-layer":t,paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,11],"circle-color":`red`,"circle-opacity":0}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,11,22,15],"text-font":[`Open Sans Regular`],"text-anchor":`top`,"text-offset":[0,.5],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":[`match`,[`feature-state`,`state`],`2`,`lightgreen`,`3`,`darkorange`,`4`,`red`,`white`]}},{id:`${e.id}_${t}_lock`,type:`circle`,source:e.id,"source-layer":t,layout:{visibility:`visible`},paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,8],"circle-stroke-width":1.7,"circle-stroke-color":[`match`,[`feature-state`,`state`],`2`,`green`,`3`,`darkorange`,`4`,`red`,`white`],"circle-color":`transparent`,"circle-stroke-opacity":[`case`,[`==`,[`feature-state`,`subState2`],`1`],1,0]}},{id:`${e.id}_${t}_danfen`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-red-box`,"icon-allow-overlap":!0,"icon-offset":[0,15],"icon-size":[`interpolate`,[`linear`],[`zoom`],5,.2,10,.5,18,1]},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`subState3`],`1`],1,0]}}],de=(e,t)=>[{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":5,"line-color":`#000000`}},{id:`${e.id}_${t}_normal`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`green`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e.id}_${t}_reverse`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`darkorange`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e.id}_${t}_fourway`,type:`line`,source:e.id,"source-layer":t,paint:{"line-width":4,"line-color":`#000000`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`4`],1,0]}},{id:`${e.id}_${t}_normal_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_reverse_white`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`white`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`2`]],1,0]}},{id:`${e.id}_${t}_normal_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`2`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}},{id:`${e.id}_${t}_reverse_red`,type:`line`,source:e.id,"source-layer":t,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`red`,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],`3`],[`==`,[`feature-state`,`subState1`],`3`]],1,0]}}],fe=(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":`icon-bumper`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-rotate":[`get`,`angle`],"icon-allow-overlap":!0,"icon-anchor":`left`}}),pe=(e,t)=>({id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],10,[`==`,[`get`,`category`],96],8,7],22,[`case`,[`==`,[`get`,`category`],50],16,[`==`,[`get`,`category`],96],12,13]],"text-font":[`Open Sans Regular`],"text-anchor":[`case`,[`==`,[`get`,`angle`],90],`bottom-left`,`top-right`],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`#C0C33F`}}),me=(e,t)=>{let n=[`interpolate`,[`exponential`,2],[`zoom`],12,1,15,1.5,16,2,17,4];return{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,filter:[`!=`,[`get`,`category`],2],paint:{"circle-radius":n,"circle-stroke-width":n,"circle-stroke-color":`#ffbb00`},layout:{visibility:`none`}}},T=function(e){return e[e.NULL=0]=`NULL`,e[e.BUMPER=1]=`BUMPER`,e[e.CONTACTLINEEND=2]=`CONTACTLINEEND`,e[e.FIXEDDERAILER=3]=`FIXEDDERAILER`,e[e.CONTACTLINENOSTOP=4]=`CONTACTLINENOSTOP`,e[e.CONTACTLINENOSTOPIN=5]=`CONTACTLINENOSTOPIN`,e[e.OTHERPROMPT=6]=`OTHERPROMPT`,e[e.OTHERBRAKE=7]=`OTHERBRAKE`,e[e.ONESTOP=8]=`ONESTOP`,e[e.SPEEDLIMITED=9]=`SPEEDLIMITED`,e[e.SPEEDNOTICE=10]=`SPEEDNOTICE`,e[e.CROSSSPEEDLIMITED=11]=`CROSSSPEEDLIMITED`,e[e.CONTACTLINEPSS=12]=`CONTACTLINEPSS`,e[e.SSG=13]=`SSG`,e[e.CONTACTLINEPSSIN=14]=`CONTACTLINEPSSIN`,e[e.CONTACTLINENOAREA=15]=`CONTACTLINENOAREA`,e[e.HIGHPOSTSIGNAL=16]=`HIGHPOSTSIGNAL`,e[e.RESCUEVEHICLE=17]=`RESCUEVEHICLE`,e[e.RAILWAYCROSS=18]=`RAILWAYCROSS`,e[e.TRAIN=19]=`TRAIN`,e[e.STATIONBOUND=20]=`STATIONBOUND`,e[e.SHORTPOSTSIGNAL=21]=`SHORTPOSTSIGNAL`,e[e.BRIDGE=22]=`BRIDGE`,e[e.WHITE=23]=`WHITE`,e[e.WHITEBLUE=24]=`WHITEBLUE`,e[e.BLUE=25]=`BLUE`,e[e.BLUEWHITE=26]=`BLUEWHITE`,e[e.SLOPE=27]=`SLOPE`,e[e.PEOPLE=28]=`PEOPLE`,e[e.TUNNEL=29]=`TUNNEL`,e[e.DANGER=30]=`DANGER`,e[e.SIGNAL=31]=`SIGNAL`,e[e.SWERVE=32]=`SWERVE`,e[e.SWITCH=33]=`SWITCH`,e[e.FOULINGPOST=38]=`FOULINGPOST`,e[e.CUNCHE=39]=`CUNCHE`,e[e.STATIONBOUNDEXTEND=40]=`STATIONBOUNDEXTEND`,e[e.RED=41]=`RED`,e[e.GREEN=42]=`GREEN`,e[e.YELLOW=43]=`YELLOW`,e[e.BLOCKLINE=50]=`BLOCKLINE`,e[e.WORKAREA=51]=`WORKAREA`,e[e.ROUTELINE=52]=`ROUTELINE`,e[e.PARK=53]=`PARK`,e[e.WORKBUOND=54]=`WORKBUOND`,e[e.WORKBUONDCROSS=55]=`WORKBUONDCROSS`,e[e.LEFTHIGHPLATFORM=61]=`LEFTHIGHPLATFORM`,e[e.RIGHTHIGHPLATFORM=62]=`RIGHTHIGHPLATFORM`,e[e.BOTHSIDEHIGHPLATFORM=63]=`BOTHSIDEHIGHPLATFORM`,e[e.TGQ=47]=`TGQ`,e[e.DOOR=87]=`DOOR`,e[e.OTHER=95]=`OTHER`,e[e.SIDE=253]=`SIDE`,e[e.NONE=254]=`NONE`,e[e.MAX=255]=`MAX`,e[e.ISOLATE=35]=`ISOLATE`,e[e.ISOLATESWITCH=100]=`ISOLATESWITCH`,e}({}),he={background:oe,signal:le,track:se,track_circuit:ce,bumper:fe,switch:ue,switch_loc:de,insulation:me,label:pe,prevention:(e,t)=>[{id:`${e.id}_${t}_jcw`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],String(T.CONTACTLINEEND)],`icon-jcw`,``],"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-allow-overlap":!0,"icon-anchor":`left`}},{id:`${e.id}_${t}_circle`,type:`circle`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[String(T.ONESTOP),String(T.STATIONBOUND),String(T.DOOR)],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,6,20,18],"circle-stroke-width":2,"circle-stroke-color":`red`},layout:{visibility:`visible`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[String(T.CONTACTLINEEND),String(T.ONESTOP),String(T.STATIONBOUND),String(T.DOOR)],!0,!1],layout:{"text-field":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],String(T.ONESTOP)],`停`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],String(T.STATIONBOUND)],`界`,``],"text-font":[`Open Sans Regular`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,20,18],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0,visibility:`visible`},paint:{"text-color":`white`}}]},ge=e=>{let t=[];return e.layers.forEach((n,r)=>{let i=he[n],a=e.sourceLayers[r];if(i){let n=i(e,a);Array.isArray(n)?t.push(...n):t.push(n)}else console.warn(`图层 ${n} 尚未实现`)}),t},_e={background:(e,t)=>({id:`${e.id}_${t}`,type:`background`,paint:{"background-color":`#131212`}}),signal:(e,t)=>[{id:`${e.id}_${t}`,type:`symbol`,source:e.id,"source-layer":t,layout:{"icon-image":[`case`,[`==`,[`get`,`inst_type`],1],[`case`,[`==`,[`get`,`posi_side`],2],`icon-signal-h-r`,`icon-signal-h-l`],[`case`,[`==`,[`get`,`posi_side`],2],`icon-signal-l-r`,`icon-signal-l-l`]],"icon-allow-overlap":!0,"icon-rotate":[`case`,[`==`,[`get`,`posi_side`],2],[`-`,270,[`to-number`,[`get`,`angle`]]],[`-`,90,[`to-number`,[`get`,`angle`]]]],"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,0,16,.3,18,.5,20,1],"icon-anchor":[`case`,[`==`,[`get`,`posi_side`],1],`bottom-left`,`bottom-right`],"icon-offset":[0,2]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`get`,`name`],"text-font":[`Arial Unicode MS Bold`],"text-size":[`interpolate`,[`linear`],[`zoom`],12,5,14,8,18,14],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0,"text-offset":[0,.6]},paint:{"text-color":`gold`}}],track:(e,t)=>[{id:`${e.id}_${t}_hitarea`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`select`],!0],1,0]}},{id:`${e.id}_${t}`,type:`line`,source:e.id,"source-layer":t,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],track_circuit:null,bumper:(e,t)=>[{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,3,12,3,14,5,16,6,20,8],"circle-stroke-width":2,"circle-stroke-color":`red`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":`档`,"text-font":[`Arial Unicode MS Bold`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,12,8,14,10,16,12,20,12],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`}}],switch:null,switch_loc:null,insulation:null,label:null,prevention:(e,t)=>[{id:`${e.id}_${t}`,type:`circle`,source:e.id,"source-layer":t,filter:[`match`,[`to-string`,[`get`,`uc_oob_type`]],[`2`,`8`,`20`,`87`],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,3,12,3,14,5,16,6,20,8],"circle-stroke-width":2,"circle-stroke-color":`red`}},{id:`${e.id}_${t}_text`,type:`symbol`,source:e.id,"source-layer":t,layout:{"text-field":[`case`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`2`],`网`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`8`],`停`,[`==`,[`to-string`,[`get`,`uc_oob_type`]],`20`],`界`,`门`],"text-font":[`Arial Unicode MS Bold`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,12,8,14,10,16,12,20,12],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`}}]},ve=e=>{let t=[];return e.layers.forEach((n,r)=>{let i=_e[n],a=e.sourceLayers[r];if(i){let n=i(e,a);Array.isArray(n)?t.push(...n):t.push(n)}else console.warn(`图层 ${n} 尚未实现`)}),t},ye=e=>[{id:`${e}_raster_layer`,type:`raster`,source:e,paint:{"raster-opacity":.8}}],be={background:e=>({id:`${e}_background`,type:`background`,paint:{"background-color":`#131212`}}),signal:e=>{let t=[`interpolate`,[`exponential`,2],[`zoom`],12,.2,16,.6,18,.8,20,1.5];return[...[C.Red,C.Green,C.White,C.Blue].map(n=>({id:`${e}_signal_${n}`,type:`symbol`,source:e,layout:{"icon-image":[`case`,[`==`,[`get`,`installType`],1],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-h-l-${n}`,`icon-signal-h-r-${n}`],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-l-l-${n}`,`icon-signal-l-r-${n}`]],"icon-size":t,"icon-rotate":[`case`,[`==`,[`get`,`positionSide`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`positionSide`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],n],[`!=`,[`feature-state`,`visiable`],!1]],1,0]}})),{id:`${e}_signal`,type:`symbol`,source:e,layout:{"icon-image":[`case`,[`==`,[`get`,`installType`],1],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-h-l`,`icon-signal-h-r`],[`case`,[`==`,[`get`,`positionSide`],1],`icon-signal-l-l`,`icon-signal-l-r`]],"icon-size":t,"icon-rotate":[`case`,[`==`,[`get`,`positionSide`],2],[`+`,270,[`to-number`,[`get`,`angle`]]],[`+`,90,[`to-number`,[`get`,`angle`]]]],"icon-allow-overlap":!0,"icon-anchor":[`case`,[`==`,[`get`,`positionSide`],1],`bottom-left`,`bottom-right`]},paint:{"icon-opacity":[`case`,[`!=`,[`feature-state`,`visiable`],!1],1,0]}}]},track:e=>[{id:`${e}_track_lock`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`#a7009e`,"line-width":3,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e}_track_lock_icon`,type:`symbol`,source:e,layout:{"symbol-placement":`line-center`,"icon-anchor":`top`,"icon-image":`icon-lock`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.2,15,.5,16,.6,17,.8],"icon-offset":[0,5],"icon-allow-overlap":!0,"icon-rotation-alignment":`viewport`,"icon-rotate":0},paint:{"icon-opacity":[`case`,[`==`,[`feature-state`,`state`],`1`],1,0]}},{id:`${e}_track_poweroff_border`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`green`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e}_track_poweroff_fill`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e}_track_catenery_border`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":9,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e}_track_catenery_fill`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`black`,"line-width":6,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}},{id:`${e}_track`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`#85A0D9`,"line-width":2}}],track_circuit:e=>{let t=[`interpolate`,[`exponential`,2],[`zoom`],12,2,16,3.5,18,4.5,20,5];return[{id:`${e}_trackcircuit_bad`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":[`case`,[`==`,[`feature-state`,`state`],1],`#ff0000`,[`==`,[`feature-state`,`state`],2],`#ffffff`,[`==`,[`feature-state`,`state`],3],`#808080`,`#000000`],"line-width":t,"line-dasharray":[4,4],"line-opacity":[`case`,[`==`,[`feature-state`,`substate`],0],1,0]}},{id:`${e}_trackcircuit_grey`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`grey`,"line-width":t,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],3],[`!=`,[`feature-state`,`substate`],0]],1,0]}},{id:`${e}_trackcircuit_red`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`red`,"line-width":t,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],1],[`!=`,[`feature-state`,`substate`],0]],1,0]}},{id:`${e}_trackcircuit_white`,type:`line`,source:e,layout:{"line-join":`round`},paint:{"line-color":`white`,"line-width":t,"line-opacity":[`case`,[`all`,[`==`,[`feature-state`,`state`],2],[`!=`,[`feature-state`,`substate`],0]],1,0]}},{id:`${e}_trackcircuit_white_label`,type:`symbol`,source:e,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],2],1,0]}},{id:`${e}_trackcircuit_red_label`,type:`symbol`,source:e,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":`bottom`,"text-offset":[0,-1],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`red`,"text-opacity":[`case`,[`==`,[`feature-state`,`state`],1],1,0]}}]},bumper:e=>({id:`${e}_bumper`,type:`symbol`,source:e,layout:{"icon-image":`icon-bumper`,"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-rotate":[`get`,`angle`],"icon-allow-overlap":!0,"icon-anchor":`left`}}),switch:e=>[{id:`${e}_switch_hitarea`,type:`circle`,source:e,paint:{"circle-radius":[`interpolate`,[`linear`],[`zoom`],5,11],"circle-color":`red`,"circle-opacity":0}},{id:`${e}_switch_text`,type:`symbol`,source:e,layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,11,22,15],"text-font":[`Open Sans Regular`],"text-anchor":`top`,"text-offset":[0,.5],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":[`match`,[`feature-state`,`state`],`2`,`lightgreen`,`3`,`darkorange`,`4`,`red`,`white`]}}],switch_loc:e=>[{id:`${e}_switchloc`,type:`line`,source:e,paint:{"line-width":5,"line-color":`#000000`}},{id:`${e}_switchloc_normal`,type:`line`,source:e,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`2`]],paint:{"line-width":4,"line-color":`green`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`2`],1,0]}},{id:`${e}_switchloc_reverse`,type:`line`,source:e,filter:[`any`,[`==`,[`get`,`location`],`1`],[`==`,[`get`,`location`],`3`]],paint:{"line-width":4,"line-color":`darkorange`,"line-opacity":[`case`,[`==`,[`feature-state`,`state`],`3`],1,0]}}],insulation:e=>{let t=[`interpolate`,[`exponential`,2],[`zoom`],12,1,15,1.5,16,2,17,4];return{id:`${e}_insulation`,type:`circle`,source:e,filter:[`!=`,[`get`,`category`],2],paint:{"circle-radius":t,"circle-stroke-width":t,"circle-stroke-color":`#ffbb00`}}},label:e=>({id:`${e}_label`,type:`symbol`,source:e,filter:[`!=`,[`get`,`category`],2],layout:{"text-field":[`get`,`name`],"text-size":[`interpolate`,[`linear`],[`zoom`],15,[`case`,[`==`,[`get`,`category`],50],12,[`==`,[`get`,`category`],96],10,9],22,[`case`,[`==`,[`get`,`category`],50],18,[`==`,[`get`,`category`],96],14,15]],"text-font":[`Open Sans Regular`],"text-anchor":[`case`,[`==`,[`get`,`angle`],90],`bottom-left`,`top-right`],"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`yellow`}}),prevention:e=>[{id:`${e}_prevention_jcw`,type:`symbol`,source:e,layout:{"icon-image":[`case`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.CONTACTLINEEND],`icon-jcw`,``],"icon-size":[`interpolate`,[`exponential`,2],[`zoom`],12,.1,16,.5,18,.7,20,1.4],"icon-allow-overlap":!0,"icon-anchor":`left`}},{id:`${e}_prevention_circle`,type:`circle`,source:e,filter:[`match`,[`to-number`,[`get`,`ucOobType`]],[T.ONESTOP,T.STATIONBOUND,T.DOOR],!0,!1],paint:{"circle-radius":[`interpolate`,[`exponential`,2],[`zoom`],10,6,20,18],"circle-stroke-width":2,"circle-stroke-color":`red`}},{id:`${e}_prevention_text`,type:`symbol`,source:e,filter:[`match`,[`to-number`,[`get`,`ucOobType`]],[T.CONTACTLINEEND,T.ONESTOP,T.STATIONBOUND,T.DOOR],!0,!1],layout:{"text-field":[`case`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.ONESTOP],`停`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.STATIONBOUND],`界`,[`==`,[`to-number`,[`get`,`ucOobType`]],T.DOOR],`门`,``],"text-font":[`Open Sans Regular`],"text-size":[`interpolate`,[`linear`],[`zoom`],10,6,20,18],"text-anchor":`center`,"symbol-placement":`point`,"text-allow-overlap":!0},paint:{"text-color":`white`}}]},E={ctc:ae,graph:ge,geom:ve,raster:ye,geojson:(e,t)=>{let n=[];return e.forEach((e,r)=>{let i=t[r],a=be[e];if(!a){console.warn(`GeoJSON 图层 ${e} 尚未实现`);return}let o=a(i);Array.isArray(o)?n.push(...o):n.push(o)}),n}};function xe(){if(!this.mapConfigs)return;let e=this.mapConfigs.id;this.mapConfigs.sourceLayers.forEach(t=>{(t.includes(`switch`)||t.includes(`signal`)||t.includes(`track`))&&this.map.querySourceFeatures(e,{sourceLayer:t}).forEach(e=>{this.initCTCFeatureState(e)})})}function Se(e){if(!e||e.length<11)return``;let t=e.charAt(10),n=e.charAt(9);return t===`1`&&n===`0`?`track`:t===`3`?`signal`:t===`2`&&n===`0`||t===`1`&&n===`1`?`switch`:t===`2`&&n===`1`?`circuit`:``}function Ce(e){if(!e)return;let t=e.properties.code,n=Se(t);if(n===`switch`){let t={state:``,select:!1,visiable:!0,subState1:``,subState2:``,subState3:``};t.state=`2`;let n=e.properties;this.updateFeatureState(n.code,t)}else if(n===`signal`){let t=e.properties,n=t.attach||0,r=t.func_type,i={state:``,select:!1,visiable:!0,subState1:`grey`,subState2:``,subState3:``};r==1&&n==0||(r==2||r==3)&&n==0||(r==2||r==3||r==11)&&n==1?(i.state=`red`,i.subState1=`blue`,this.updateFeatureState(t.code,i)):(r==4||r==5||r==12)&&n==0?(i.state=`blue`,i.subState1=`green`,this.updateFeatureState(t.code,i)):r==6&&n==0||(r==7||r==11)&&n==0?(i.state=`red`,i.subState1=`blue`,this.updateFeatureState(t.code,i)):(i.state=``,i.subState1=`grey`,this.updateFeatureState(t.code,i))}else if(n===`signal`||n===`circuit`){let t={state:``,select:!1,visiable:!0,subState1:``,subState2:``,subState3:``},n=e.properties;this.updateFeatureState(n.code,t)}}function we(e){e.initCTCFeatureState=Ce,e.initState=xe,e.map.once(`idle`,()=>{e&&(e.map.moveLayer(`${e.mapConfigs.id}_${e.mapConfigs.sourceLayers[e.mapConfigs.layers.indexOf(`track`)]}_lock`),setTimeout(()=>{e.initState(),e.map.dragPan.enable(),e.map.scrollZoom.enable(),e.map.touchZoomRotate.enable(),e.map.doubleClickZoom.enable(),e.map.boxZoom.enable(),e.map.keyboard.enable()},1e3))})}function Te(e,t){let n=this.map;if(n&&!n.getSource(e)){let r=w.graph(t);n.addSource(e,r)}}function Ee(e,t){let n=this.map;if(n&&!n.getSource(e)){let r=w.raster(t);n.addSource(e,r)}}function De(e,t){let n=this.map;if(!n){console.error(`地图实例未初始化`);return}try{if(n.getSource(e))console.warn(`源已存在,跳过添加: ${e}`);else{let r=t?w.geojson(t):w.geojson(void 0);n.addSource(e,r),console.log(`成功添加 GeoJSON 源: ${e}`)}}catch(t){console.error(` 添加源失败 [${e}]:`,t)}}function Oe(e){let t=this.map;if(t)if(t.getSource(e))try{(t.getStyle().layers||[]).filter(t=>{if(`source`in t)return t.source===e}).forEach(e=>{t.removeLayer(e.id),console.log(`移除关联图层: ${e.id}`)}),t.removeSource(e),console.log(`成功移除源: ${e}`)}catch(t){console.error(`移除源失败 [${e}]:`,t)}else console.warn(`源不存在,无法移除: ${e}`)}function ke(e,t){let n=this.map;if(!n)return;let r=n.getSource(e);r?(r.setData(t),console.log(`更新源数据: ${e}`)):this.addGeoJsonSource(e,t)}function Ae(e,t,n=`fill`,r,i){let a=this.map;if(!a)return;if(!a.getSource(t)){console.error(`无法添加图层: 源 '${t}' 不存在`);return}a.getLayer(e)&&a.removeLayer(e);let o={};n===`fill`&&(o[`fill-color`]=`#3b82f6`),n===`line`&&(o[`line-color`]=`#3b82f6`),n===`circle`&&(o[`circle-color`]=`#3b82f6`);let s={id:e,type:n,source:t,paint:{...o,...r},layout:i||{}};a.addLayer(s)}function je(e,t){let n=this.map;n&&(n.getLayer(e)?(Object.keys(t).forEach(r=>{n.setPaintProperty(e,r,t[r])}),console.log(`样式已更新: ${e}`)):console.warn(` 图层不存在,无法更新样式: ${e}`))}function Me(e){let t=this.map;t&&(t.getLayer(e)?(t.removeLayer(e),console.log(`图层已移除: ${e}`)):console.warn(` 图层不存在,无法删除: ${e}`))}function Ne(e,t){let n=this.map;if(!n)return;let r=Array.isArray(e)?e:[e];n.on(`click`,e=>{let i=n.queryRenderedFeatures(e.point,{layers:r});if(!i.length)return;let a=i[0];t(a,e.lngLat)}),n.on(`mouseenter`,r[r.length-1],()=>{n.getCanvas().style.cursor=`pointer`}),n.on(`mouseleave`,r[r.length-1],()=>{n.getCanvas().style.cursor=``})}function Pe(){this.stashFeatures.clear(),this.map&&(this.map.remove(),console.log(`地图实例已移除`))}function Fe(e){e.addGeoJsonSource=De,e.addVectorTileSource=Te,e.addRasterTileSource=Ee,e.updateGeoJsonSource=ke,e.removeSource=Oe,e.addGeoJsonLayer=Ae,e.updateLayerStyle=je,e.removeLayer=Me,e.onFeatureClick=Ne,e.destroy=Pe}var Ie=class{signalExist=!0;productInfo;stationCode;time;interlockInfo=new Map;getProductInfo(){return this.productInfo}getStCode(){return this.stationCode}getInterlockInfo(){return this.interlockInfo}isSignalExist(){return this.signalExist}setYardSignal(e){let t=e.split(`&`);this.time=t[0];let n=[],r=[],i=[];this.stationCode=t[1];let a=t[1],o=0;t.length===6&&(this.productInfo=t[2],o=1);let s=t[2],c=a+`:`+s;if(t[2+o]!==``){let e=t[2+o].split(`;`);for(let t of e){let e=t.split(`:`);n.push({name:e[0]+`:`+a,state:e[1]})}}if(t[3+o]!==``){let e=t[3+o].split(`;`);for(let t of e){let e=t.split(`:`);r.push({name:e[0]+`:`+a,state:e[1]})}}if(t[4+o]!==``){let e=t[4+o].split(`;`);for(let t of e){let e=t.split(`:`);i.push({name:e[0]+`:`+a,state:e[1]})}}this.interlockInfo.set(c,{signalInterlock:n,switchInterlock:r,circuitInterlock:i})}reset(){}resetInterlockInfo(){this.interlockInfo=new Map}},Le=class{insulationSignalMap=new Map;signalInsulationMap=new Map;setInsulation(e){this.insulationSignalMap.clear(),this.signalInsulationMap.clear(),e.length===0&&console.warn(`没有绝缘节数据!`),e.forEach(e=>{let t=String(e.id??e.properties?.code??``),n=e.properties?.upSignal??null,r=e.properties?.downSignal??null,i=e.properties?.name??``;this.insulationSignalMap.set(t,{upsignal:n,downsignal:r}),n!=null&&this.signalInsulationMap.set(String(n),t+`-`+i),r!=null&&this.signalInsulationMap.set(String(r),t+`-`+i)})}getInsulationBySignalKey(e){return this.signalInsulationMap.get(e)}getSignalByInsulationKey(e){return this.insulationSignalMap.get(e)}},Re=function(e){return e.RedLight=`red`,e.GreenLight=`green`,e.BlueLight=`blue`,e.WhiteLight=`white`,e}({}),ze={1:Re.RedLight,2:Re.GreenLight,3:Re.WhiteLight,4:Re.BlueLight},Be=class{map;layers;firstSwitches;updateFeatureState;signalStore=new Ie;interLockInsulation=new Le;interLockState={signal:new Map,switch:new Map,circuit:new Map};pathCircuits=[];pathCircuitsCodes=[];linkWhiteCircuits=[];constructor(e){if(this.map=e.map,this.firstSwitches=e.firstSwitches??[],this.updateFeatureState=e.updateFeatureState,`mode`in e&&e.mode===`geojson`){let t=e.sourceIds;this.layers={signal:{sourceId:t.signal},switch:{sourceId:t.switch},switch_loc:{sourceId:t.switch_loc},track_circuit:{sourceId:t.track_circuit},track:{sourceId:t.track},insulation:{sourceId:t.insulation}}}else{let t=e.sourceId,n=e.sourceLayers;this.layers={signal:{sourceId:t,sourceLayer:n.signal},switch:{sourceId:t,sourceLayer:n.switch},switch_loc:{sourceId:t,sourceLayer:n.switch_loc},track_circuit:{sourceId:t,sourceLayer:n.track_circuit},track:{sourceId:t,sourceLayer:n.track},insulation:{sourceId:t,sourceLayer:n.insulation}}}}queryFeatures(e){let t=this.layers[e];return this.map.querySourceFeatures(t.sourceId,t.sourceLayer?{sourceLayer:t.sourceLayer}:void 0)}setFeatureState(e,t,n){if(this.updateFeatureState)return this.updateFeatureState(t,n);let r=this.layers[e];this.map.setFeatureState(r.sourceLayer?{source:r.sourceId,sourceLayer:r.sourceLayer,id:t}:{source:r.sourceId,id:t},n)}getFeatureState(e,t){let n=this.layers[e];return this.map.getFeatureState(n.sourceLayer?{source:n.sourceId,sourceLayer:n.sourceLayer,id:t}:{source:n.sourceId,id:t})}initInsulation(){let e=this.queryFeatures(`insulation`);this.interLockInsulation.setInsulation(e)}handleSignalData(e){this.signalStore.resetInterlockInfo(),!e||e.length===0?this.signalStore.signalExist=!1:(this.signalStore.signalExist=!0,this.signalStore.setYardSignal(e)),this.signalStore.isSignalExist()&&this.signalStore.getInterlockInfo().forEach((e,t)=>{let n=t.split(`:`)[0],r=t.split(`:`)[1];this.arrToMap(this.interLockState.signal,e.signalInterlock),this.arrToMap(this.interLockState.switch,e.switchInterlock),this.arrToMap(this.interLockState.circuit,e.circuitInterlock),r===`ZK01`?this.visualizeZK(e,r,n):this.visualizeYD(e,r,n)})}turnOffSignals(){this.interLockState={signal:new Map,switch:new Map,circuit:new Map}}reset(e){this.clearCircuits(e),this.clearSwitchLocs(e)}clearCircuits(e){this.queryFeatures(`track_circuit`).forEach(t=>{t.properties?.stcode===e&&this.setFeatureState(`track_circuit`,t.properties.code,{state:``,visiable:!0})})}clearSwitchLocs(e){this.queryFeatures(`switch_loc`).forEach(t=>{t.properties?.stcode===e&&this.setFeatureState(`switch_loc`,t.properties.code,{state:``,visiable:!0})})}visualizeZK(e,t,n){this.reset(n);for(let t of e.signalInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getSignalFeature(e,n);r&&this.setFeatureState(`signal`,r.properties.code,{state:ze[Number(t.state)],visiable:!0})}for(let t of e.switchInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1];this.getSwitchLocFeatures(e,n,t.state).forEach(e=>{this.setFeatureState(`switch_loc`,e.properties.code,{state:t.state})})}for(let t of e.circuitInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getCircuitFeature(e,n);r&&this.setFeatureState(`track_circuit`,r.properties.code,{state:t.state,visiable:!0})}this.applyHandSwitchPaths(n,e.switchInterlock)}visualizeYD(e,t,n){this.reset(n);for(let t of e.signalInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getSignalFeature(e,n);r&&this.setFeatureState(`signal`,r.properties.code,{state:ze[Number(t.state)],visiable:!0})}for(let t of e.switchInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1];this.getSwitchLocFeatures(e,n,t.state).forEach(e=>{this.setFeatureState(`switch_loc`,e.properties.code,{state:t.state,visiable:!0})})}this.pathCircuits=[],this.pathCircuitsCodes=[],this.linkWhiteCircuits=[];for(let t of e.circuitInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getCircuitFeature(e,n);r&&(this.pathCircuits.push(r),this.pathCircuitsCodes.push(String(r.properties?.code??``)))}for(let t of e.circuitInterlock){let e=t.name.split(`:`)[0],n=t.name.split(`:`)[1],r=this.getCircuitFeature(e,n);if(!r){console.warn(`没有找到对应的区段YD`,t.name,t.state);continue}if(t.state===`1`)this.setFeatureState(`track_circuit`,r.properties.code,{state:t.state,controlName:``,visiable:!0});else{let e=String(r.properties?.fromCode??``),n=String(r.properties?.toCode??``);try{let i=this.getCircuitState([e,n],null);i?(this.setFeatureState(`track_circuit`,r.properties.code,{state:i.circuitState,controlName:i.controlName,link:i.controlName===``?void 0:0,visiable:!0}),i.controlName!==``&&this.linkWhiteCircuits.push(r)):this.setFeatureState(`track_circuit`,r.properties.code,{state:t.state,visiable:!0})}catch(e){if(e instanceof Error&&e.message!==`End Loop`)throw e}}}this.queryFeatures(`track_circuit`).forEach(e=>{let t=String(e.properties?.code??``),n=this.linkWhiteCircuits.find(e=>String(e.properties?.code??``)===t);if(n){let t=this.getFeatureState(`track_circuit`,e.id);t.state!==`2`&&t.state!==2&&t.state!==`1`&&t.state!==1&&this.setFeatureState(`track_circuit`,e.properties.code,{state:2,link:1,controlName:n.properties?.controlName??``,visiable:!0})}}),this.applyHandSwitchPaths(n,e.switchInterlock)}applyHandSwitchPaths(e,t){let n=[];for(let r of this.firstSwitches)this.findHandSwitchPath(r,e,t,n,[]);n.forEach(e=>{this.setFeatureState(`track`,e,{state:5,visiable:!0})})}findHandSwitchPath(e,t,n,r,i){let a=this.findSwitchInfo(e,t,n);if(!this.validSwitchInfo(a))return;let o=this.getSwitchLocFeatures(e,t,a.state);for(let a of o){let o=String(a.properties?.t_code??``),s=String(a.properties?.s_code??``),c=this.getTrackByCode(o);if(!c)continue;let l=String(c.properties?.fromCode??``),u=String(c.properties?.toCode??``),d=c.properties?.fromLyr,f=c.properties?.toLyr,p=``,m=null;if(l===s?(p=u,m=f):u===s&&(p=l,m=d),m===2){let a=this.getSwitchByCode(p);if(a){r.push(o);let s=String(a.properties?.name??``),c=this.findSwitchInfo(s,t,n);c&&this.validSwitchInfo(c)&&!i.includes(s)&&this.doseTrackConnectSwitch(o,c)&&(i.push(e),this.findHandSwitchPath(s,t,n,r,i))}}else r.push(o)}}doseTrackConnectSwitch(e,t){let n=t.name.split(`:`)[0],r=t.name.split(`:`)[1];return this.getSwitchLocFeatures(n,r,t.state).some(t=>String(t.properties?.t_code??``)===e)}getCircuitState(e,t){let n=4,r=null;try{e.forEach((i,a)=>{let o=this.interLockInsulation.getSignalByInsulationKey(i),s=this.getInsulationSignalState(o??null);if(t==null&&s!=null&&(r=s),s==null&&t!=null&&(s={name:t.name,dir:t.dir,state:`3`}),s!=null&&s.state===`3`){n=2;let t=e.find(e=>e!==i),r=this.findNextCircuit(t,s);if(r!=null){let e=this.interLockInsulation.getSignalByInsulationKey(t);if(this.getControlSignalState(e??null,s)!=4){let e=String(r.properties?.fromCode??``),t=String(r.properties?.toCode??``),n={...r,properties:{...r.properties,controlName:s.name}};this.linkWhiteCircuits.push(n),this.getCircuitState([e,t],s)}}}})}catch(e){console.error(e)}return{circuitState:n,controlName:r==null?``:r.name}}findNextCircuit(e,t){let n=this.pathCircuits.find(n=>{let r=String(n.properties?.fromCode??``),i=String(n.properties?.toCode??``);return t.dir===`up`&&r===e||t.dir===`down`&&i===e});return n?this.linkWhiteCircuits.find(e=>String(e.properties?.code??``)===String(n.properties?.code??``))?null:n:null}getInsulationSignalState(e){if(!e)return null;if(e.upsignal){let t=this.getSignalById(String(e.upsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``),r=this.interLockState.signal.get(e+`:`+n);if(r===`3`)return{name:e,state:r,dir:`up`}}}if(e.downsignal){let t=this.getSignalById(String(e.downsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``),r=this.interLockState.signal.get(e+`:`+n);if(r===`3`)return{name:e,state:r,dir:`down`}}}return null}getControlSignalState(e,t){if(e){if(t.dir===`up`&&e.upsignal){let t=this.getSignalById(String(e.upsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``);return this.interLockState.signal.get(e+`:`+n)}}if(t.dir===`down`&&e.downsignal){let t=this.getSignalById(String(e.downsignal));if(t){let e=String(t.properties?.name??``),n=String(t.properties?.stcode??``);return this.interLockState.signal.get(e+`:`+n)}}}}getSignalFeature(e,t){return this.queryFeatures(`signal`).find(n=>n.properties?.name===e&&String(n.properties?.code??``).includes(t))}getSignalById(e){return this.queryFeatures(`signal`).find(t=>String(t.id??t.properties?.code??``)===e)}getSwitchLocFeatures(e,t,n){let r=this.queryFeatures(`switch`).find(n=>n.properties?.name===e&&String(n.properties?.code??``).includes(t));if(!r)return[];let i=String(r.properties?.code??``),a=this.queryFeatures(`switch_loc`);return n===`4`?a.filter(e=>String(e.properties?.s_code??``)===i):a.filter(e=>String(e.properties?.s_code??``)===i&&(String(e.properties?.location??``)===n||String(e.properties?.location??``)===`1`))}getSwitchByCode(e){return this.queryFeatures(`switch`).find(t=>String(t.id??t.properties?.code??``)===e)}getTrackByCode(e){return this.queryFeatures(`track`).find(t=>String(t.id??t.properties?.code??``)===e)}getCircuitFeature(e,t){let n=this.queryFeatures(`track_circuit`).filter(n=>n.properties?.name===e&&String(n.properties?.code??``).includes(t));if(n.length===0)return;let r;if(n.length>=1&&(n[0].properties?.type===`1`||n[0].properties?.type===1))return n[0];for(let e of n){if(r)break;if(e.properties?.type===2||e.properties?.type===`2`){let t=String(e.properties?.switches??``).split(`,`),n=String(e.properties?.positions??``).replace(/\s+/g,``).split(`,`).filter(e=>e!==`1`);for(let i=0;i<t.length;i++){let a=t[i],o=n[i],s=this.getSwitchNameByCode(a);if(!s||o!==this.interLockState.switch.get(s+`:`+a.substring(0,9)))break;if(i==t.length-1){r=e;break}}}}return r}getSwitchNameByCode(e){let t=this.queryFeatures(`switch`).find(t=>String(t.properties?.code??``)===e);return t?String(t.properties?.name??``):void 0}findSwitchInfo(e,t,n){let r=e+`:`+t;return n.find(e=>e.name===r)??null}validSwitchInfo(e){return e?e.state===`2`||e.state===`3`:!1}arrToMap(e,t){t?.forEach(t=>e.set(t.name,t.state))}};function Ve(){if(!this.mapConfigs)return;let e=this.mapConfigs.id;this.mapConfigs.sourceLayers?.forEach(t=>{(t.includes(`switch`)||t.includes(`signal`)||t.includes(`track`))&&this.map.querySourceFeatures(e,{sourceLayer:t}).forEach(e=>{this.initGraphFeatureState(e)})})}function He(e){if(!e||e.length<11)return``;let t=e.charAt(10),n=e.charAt(9);return t===`1`&&n===`0`?`track`:t===`3`?`signal`:t===`2`&&n===`0`||t===`1`&&n===`1`?`switch`:t===`2`&&n===`1`?`circuit`:``}function Ue(e){if(!e)return;let t=e.properties.code,n=He(t);if(n===`switch`){let t={state:``,visiable:!0};t.state=`2`;let n=e.properties;this.updateFeatureState(n.code,t)}else if(n===`signal`){let t=e.properties,n=t.attach||0,r=t.func_type,i={state:``,visiable:!0};r==1&&n==0||(r==2||r==3)&&n==0||(r==2||r==3||r==11)&&n==1?(i.state=`red`,this.updateFeatureState(t.code,i)):(r==4||r==5||r==12)&&n==0?(i.state=`blue`,this.updateFeatureState(t.code,i)):r==6&&n==0||(r==7||r==11)&&n==0?(i.state=`red`,this.updateFeatureState(t.code,i)):(i.state=``,this.updateFeatureState(t.code,i))}else if(n===`signal`||n===`circuit`){let t={state:``,visiable:!0},n=e.properties;this.updateFeatureState(n.code,t)}}function We(e){if(!e.mapConfigs)return;let t=e.mapConfigs.id,n=e.mapConfigs.layers?.reduce((t,n,r)=>(t[n]=e.mapConfigs.sourceLayers[r],t),{});if(n)return new Be({map:e.map,sourceId:t,sourceLayers:n,updateFeatureState:(t,n)=>e.updateFeatureState(t,n)})}function Ge(e){e.initGraphFeatureState=Ue,e.initState=Ve,e.interLockVisualization=We(e),e.map.once(`idle`,()=>{})}function Ke(){this.mapConfigs&&(this.mapConfigs.layers??[]).forEach(e=>{let t=`geojson_${e}`;this.map.getSource(t)&&this.stashFeatures.forEach(n=>{n.sourceLayer!==t||!n.properties||this.initGeoJsonFeatureState({properties:n.properties},e)})})}function qe(e,t){if(!e)return;let n=e.properties,r=n?.code;if(r)if(t===`switch`||t===`switch_loc`)this.updateFeatureState(r,{state:`2`,visiable:!0});else if(t===`signal`){let e=n?.attach||0,t=n?.functionType,i={state:``,visiable:!0};t==1&&e==0||(t==2||t==3)&&e==0||(t==2||t==3||t==11)&&e==1||t==6&&e==0||(t==7||t==11)&&e==0?i.state=`red`:(t==4||t==5||t==12)&&e==0&&(i.state=`blue`),this.updateFeatureState(r,i)}else t===`track_circuit`&&this.updateFeatureState(r,{state:3,substate:1,visiable:!0})}function Je(e){if(!e.mapConfigs)return;let t=[`signal`,`switch`,`switch_loc`,`track_circuit`,`track`,`insulation`].reduce((e,t)=>(e[t]=`geojson_${t}`,e),{});return new Be({mode:`geojson`,map:e.map,sourceIds:t,updateFeatureState:(t,n)=>e.updateFeatureState(t,n)})}function Ye(e){e.initGeoJsonFeatureState=qe,e.initGeoJsonState=Ke,e.interLockVisualization=Je(e),e.map.once(`idle`,()=>{})}function D(){return D=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},D.apply(null,arguments)}var O=`draw`,Xe=`edit`,Ze=`deleteCoordinate`,Qe=`insertMidpoint`,k;(function(e){e.Commit=`commit`,e.Provisional=`provisional`,e.Finish=`finish`})(k||={});var $e=`https://raw.githubusercontent.com/JamesLMilner/terra-draw/refs/heads/main/assets/markers/marker-blue.png`,A={SELECTED:`selected`,MID_POINT:`midPoint`,SELECTION_POINT_FEATURE_ID:`selectionPointFeatureId`,SELECTION_POINT:`selectionPoint`},j={MODE:`mode`,CURRENTLY_DRAWING:`currentlyDrawing`,EDITED:`edited`,CLOSING_POINT:`closingPoint`,SNAPPING_POINT:`snappingPoint`,COORDINATE_POINT:`coordinatePoint`,COORDINATE_POINT_FEATURE_ID:`coordinatePointFeatureId`,COORDINATE_POINT_IDS:`coordinatePointIds`,PROVISIONAL_COORDINATE_COUNT:`provisionalCoordinateCount`,COMMITTED_COORDINATE_COUNT:`committedCoordinateCount`,MARKER:`marker`},M=10;function et(e){return!!(e&&typeof e==`object`&&e&&!Array.isArray(e))}function tt(e){return!!(e&&typeof e==`object`&&`properties`in e&&typeof e.properties==`object`&&e.properties!==null&&`mode`in e.properties)}function nt(e){return!!function(e){return typeof e==`number`&&!isNaN(new Date(e).valueOf())}(e)}var rt=`Feature mode property does not match the mode being added to`,it;(function(e){e.Drawing=`drawing`,e.Select=`select`,e.Static=`static`,e.Render=`render`})(it||={});var at={rightClick:!0,contextMenu:!1,leftClick:!0,onDragStart:!0,onDrag:!0,onDragEnd:!0},N=class{get state(){return this._state}set state(e){throw Error(`Please use the modes lifecycle methods`)}get styles(){return this._styles}set styles(e){if(typeof e!=`object`)throw Error(`Styling must be an object`);this.onStyleChange&&this.onStyleChange([],`styling`),this._styles=e}registerBehaviors(e){}constructor(e,t=!1){this._state=`unregistered`,this._styles={},this.pointerEvents=at,this.behaviors=[],this.validate=void 0,this.pointerDistance=40,this.coordinatePrecision=void 0,this.undoRedoMaxStackSize=void 0,this.onStyleChange=void 0,this.store=void 0,this.projection=`web-mercator`,this.setDoubleClickToZoom=void 0,this.unproject=void 0,this.project=void 0,this.setCursor=void 0,this.isInitialUpdate=!1,this.type=it.Drawing,this.mode=`base`,t?this.isInitialUpdate=!0:this.updateOptions(D({},e))}updateOptions(e){e!=null&&e.styles&&(this.styles=D({},this._styles,e.styles)),e!=null&&e.pointerDistance&&(this.pointerDistance=e.pointerDistance),e!=null&&e.validation&&(this.validate=e&&e.validation),e!=null&&e.projection&&(this.projection=e.projection),e?.pointerEvents!==void 0&&(this.pointerEvents=e.pointerEvents),e!=null&&e.modeName&&!0===this.isInitialUpdate&&(this.mode=e.modeName),this.isInitialUpdate=!1}allowPointerEvent(e,t){return typeof e==`boolean`?e:typeof e!=`function`||e(t)}setDrawing(){if(this._state!==`started`)throw Error(`Mode must be unregistered or stopped to start`);this._state=`drawing`}setStarted(){if(this._state!==`stopped`&&this._state!==`registered`&&this._state!==`drawing`&&this._state!==`selecting`)throw Error(`Mode must be unregistered or stopped to start`);this._state=`started`,this.setDoubleClickToZoom(!1)}setStopped(){if(this._state!==`started`)throw Error(`Mode must be started to be stopped`);this._state=`stopped`,this.setDoubleClickToZoom(!0)}register(e){if(this._state!==`unregistered`)throw Error(`Can not register unless mode is unregistered`);this._state=`registered`,this.store=e.store,this.store.registerOnChange(e.onChange),this.setDoubleClickToZoom=e.setDoubleClickToZoom,this.project=e.project,this.unproject=e.unproject,this.onSelect=e.onSelect,this.onDeselect=e.onDeselect,this.setCursor=e.setCursor,this.onStyleChange=e.onChange,this.onFinish=e.onFinish,this.coordinatePrecision=e.coordinatePrecision,this.undoRedoMaxStackSize=e.undoRedoMaxStackSize,this.registerBehaviors({mode:e.mode,store:this.store,project:this.project,unproject:this.unproject,pointerDistance:this.pointerDistance,coordinatePrecision:e.coordinatePrecision,projection:this.projection,undoRedoMaxStackSize:e.undoRedoMaxStackSize})}validateFeature(e){return this.performFeatureValidation(e)}afterFeatureAdded(e){}afterFeatureUpdated(e){}performFeatureValidation(e){if(this._state===`unregistered`)throw Error(`Mode must be registered`);let t=function(e,t){let n;if(et(e))if(e.id==null)n=`Feature has no id`;else if(typeof e.id!=`string`&&typeof e.id!=`number`)n=`Feature must be string or number as per GeoJSON spec`;else if(t(e.id))if(et(e.geometry))if(et(e.properties))if(typeof e.geometry.type==`string`&&[`Polygon`,`LineString`,`Point`].includes(e.geometry.type))if(Array.isArray(e.geometry.coordinates)){if(!e.properties.mode||typeof e.properties.mode!=`string`)return{valid:!1,reason:`Feature does not have a valid mode property`}}else n=`Feature coordinates is not an array`;else n=`Feature is not Point, LineString or Polygon`;else n=`Feature has no properties`;else n=`Feature has no geometry`;else n=`Feature must match the id strategy (default is UUID4)`;else n=`Feature is not object`;return n?{valid:!1,reason:n}:{valid:!0}}(e,this.store.idStrategy.isValidId);if(!t.valid)return t;if(this.validate){let n=this.validate(e,{project:this.project,unproject:this.unproject,coordinatePrecision:this.coordinatePrecision,updateType:k.Provisional});return{valid:t.valid&&n.valid,reason:n.reason}}return{valid:t.valid,reason:t.reason}}validateModeFeature(e,t){let n=this.performFeatureValidation(e);return n.valid?e.properties.mode===this.mode?t(e):{valid:!1,reason:rt}:{valid:!1,reason:n.reason}}onFinish(e,t){}onDeselect(e){}onSelect(e){}onKeyDown(e){}onKeyUp(e){}undo(){}clearHistory(){}undoSize(){return 0}redoSize(){return 0}redo(){}onMouseMove(e){}onClick(e){}onDragStart(e,t){}onDrag(e,t){}onDragEnd(e,t){}getHexColorStylingValue(e,t,n){return this.getStylingValue(e,t,n)}getNumericStylingValue(e,t,n){return this.getStylingValue(e,t,n)}getUrlStylingValue(e,t,n){return this.getStylingValue(e,t,n)}getStylingValue(e,t,n){return e===void 0?t:typeof e==`function`?(r=e(n))??t:e;var r}},ot=class extends N{constructor(...e){super(...e),this.type=it.Select}};function P(e,t){let n=e=>e*Math.PI/180,r=n(e[1]),i=n(e[0]),a=n(t[1]),o=a-r,s=n(t[0])-i,c=Math.sin(o/2)*Math.sin(o/2)+Math.cos(r)*Math.cos(a)*Math.sin(s/2)*Math.sin(s/2);return 2*Math.atan2(Math.sqrt(c),Math.sqrt(1-c))*6371e3/1e3}var st=6371008.8;function F(e){return e%360*Math.PI/180}function ct(e){return e/6371.0088}function lt(e){return e%(2*Math.PI)*180/Math.PI}function I(e,t=9){let n=10**t;return Math.round(e*n)/n}var ut=57.29577951308232,dt=.017453292519943295,ft=6378137,L=(e,t)=>({x:e===0?0:e*dt*ft,y:t===0?0:Math.log(Math.tan(Math.PI/4+t*dt/2))*ft}),R=(e,t)=>({lng:e===0?0:e/ft*ut,lat:t===0?0:(2*Math.atan(Math.exp(t/ft))-Math.PI/2)*ut});function pt(e,t,n){let r=F(e[0]),i=F(e[1]),a=F(n),o=ct(t),s=Math.asin(Math.sin(i)*Math.cos(o)+Math.cos(i)*Math.sin(o)*Math.cos(a));return[lt(r+Math.atan2(Math.sin(a)*Math.sin(o)*Math.cos(i),Math.cos(o)-Math.sin(i)*Math.sin(s))),lt(s)]}function mt(e){let{center:t,radiusKilometers:n,coordinatePrecision:r}=e,i=e.steps?e.steps:64,a=[];for(let e=0;e<i;e++){let o=pt(t,n,-360*e/i);a.push([I(o[0],r),I(o[1],r)])}return a.push(a[0]),{type:`Feature`,geometry:{type:`Polygon`,coordinates:[a]},properties:{}}}function ht(e){let t;if(e.geometry.type===`Polygon`)t=e.geometry.coordinates;else{if(e.geometry.type!==`LineString`)throw Error(`Self intersects only accepts Polygons and LineStrings`);t=[e.geometry.coordinates]}let n=[];for(let e=0;e<t.length;e++)for(let n=0;n<t[e].length-1;n++)for(let r=0;r<t.length;r++)for(let a=0;a<t[r].length-1;a++)i(e,n,r,a);return n.length>0;function r(e){return e<0||e>1}function i(e,i,a,o){let s=t[e][i],c=t[e][i+1],l=t[a][o],u=t[a][o+1],d=function(e,t,n,r){if(gt(e,n)||gt(e,r)||gt(t,n)||gt(r,n))return null;let i=e[0],a=e[1],o=t[0],s=t[1],c=n[0],l=n[1],u=r[0],d=r[1],f=(i-o)*(l-d)-(a-s)*(c-u);return f===0?null:[((i*s-a*o)*(c-u)-(i-o)*(c*d-l*u))/f,((i*s-a*o)*(l-d)-(a-s)*(c*d-l*u))/f]}(s,c,l,u);if(d===null)return;let f,p;f=c[0]===s[0]?(d[1]-s[1])/(c[1]-s[1]):(d[0]-s[0])/(c[0]-s[0]),p=u[0]===l[0]?(d[1]-l[1])/(u[1]-l[1]):(d[0]-l[0])/(u[0]-l[0]),r(f)||r(p)||(d.toString(),n.push(d))}}function gt(e,t){return e[0]===t[0]&&e[1]===t[1]}function _t(e,t){return yt(e[0])<=t&&yt(e[1])<=t}function vt(e){return e.length===2&&typeof e[0]==`number`&&typeof e[1]==`number`&&e[0]!==1/0&&e[1]!==1/0&&(n=e[0])>=-180&&n<=180&&(t=e[1])>=-90&&t<=90;var t,n}function yt(e){let t=1,n=0;for(;Math.round(e*t)/t!==e;)t*=10,n++;return n}var bt=`Feature has holes`,xt=`Feature has less than 4 coordinates`,St=`Feature has invalid coordinates`,Ct=`Feature coordinates are not closed`;function wt(e,t){if(e.geometry.type!==`Polygon`)return{valid:!1,reason:`Feature is not a Polygon`};if(e.geometry.coordinates.length!==1)return{valid:!1,reason:bt};if(e.geometry.coordinates[0].length<4)return{valid:!1,reason:xt};for(let n=0;n<e.geometry.coordinates[0].length;n++){if(!vt(e.geometry.coordinates[0][n]))return{valid:!1,reason:St};if(!_t(e.geometry.coordinates[0][n],t))return{valid:!1,reason:`Feature has coordinates with excessive precision`}}return(n=e.geometry.coordinates[0][0])[0]!==(r=e.geometry.coordinates[0][e.geometry.coordinates[0].length-1])[0]||n[1]!==r[1]?{valid:!1,reason:Ct}:{valid:!0};var n,r}function Tt(e,t){let n=wt(e,t);return n.valid?ht(e)?{valid:!1,reason:`Feature intersects itself`}:{valid:!0}:n}var z=class{constructor({store:e,mode:t,project:n,unproject:r,pointerDistance:i,coordinatePrecision:a,projection:o,undoRedoMaxStackSize:s}){this.store=void 0,this.mode=void 0,this.project=void 0,this.unproject=void 0,this.pointerDistance=void 0,this.coordinatePrecision=void 0,this.projection=void 0,this.undoRedoMaxStackSize=void 0,this.store=e,this.mode=t,this.project=n,this.unproject=r,this.pointerDistance=i,this.coordinatePrecision=a,this.projection=o,this.undoRedoMaxStackSize=s}};function Et(e){if(!function(e){let t=e.coordinates[0],n=0;for(let e=0;e<t.length-1;e++){let[r,i]=t[e],[a,o]=t[e+1];n+=(a-r)*(o+i)}return n<0}(e))return{type:`Polygon`,coordinates:[e.coordinates[0].reverse()]}}var Dt=`insert-before`,B=`insert-after`,V=`update`,Ot=`delete`,H=`replace`,U=class extends z{constructor(e,t){super(e),this.options=void 0,this.options=t}createPoint({coordinates:e,properties:t,context:n}){if(n?.updateType!==k.Finish||this.validateGeometryWithUpdateType({geometry:{type:`Point`,coordinates:e},properties:t,updateType:k.Finish}))return this.handleCreateFeature({geometry:{type:`Point`,coordinates:e},properties:t})}createLineString({coordinates:e,properties:t}){return this.handleCreateFeature({geometry:{type:`LineString`,coordinates:e},properties:t})}createPolygon({coordinates:e,properties:t}){let n=Et({type:`Polygon`,coordinates:[e]});return this.handleCreateFeature({geometry:{type:`Polygon`,coordinates:n?n.coordinates:[e]},properties:t})}createGuidancePoint({coordinate:e,type:t}){return this.createGuidancePoints({coordinates:[e],type:t})[0]}createGuidancePoints({coordinates:e,type:t,additionalProperties:n}){let r=e.map((e,r)=>({type:`Feature`,geometry:{type:`Point`,coordinates:e},properties:D({mode:this.mode,[t]:!0},n?n(r):{})}));return this.createFeatures(r)}updatePoint({featureId:e,coordinateMutations:t,propertyMutations:n,context:r}){return this.handleMutateFeature({type:`Point`,featureId:e,coordinateMutations:t,propertyMutations:n,context:r})}updatePolygon({featureId:e,coordinateMutations:t,context:n,propertyMutations:r}){return this.handleMutateFeature({type:`Polygon`,featureId:e,coordinateMutations:t,propertyMutations:r,context:n})}updateLineString({featureId:e,coordinateMutations:t,context:n,propertyMutations:r}){return this.handleMutateFeature({type:`LineString`,featureId:e,coordinateMutations:t,propertyMutations:r,context:n})}deleteFeatureIfPresent(e){e&&this.store.has(e)&&this.store.delete([e])}deleteFeaturesIfPresent(e){if(e.length===0)return;let t=e.filter(e=>this.store.has(e));t.length&&this.store.delete(t)}setDeselected(e){let t=e.filter(e=>this.store.has(e)).map(e=>({featureId:e,properties:{[A.SELECTED]:!1}}));this.updateFeatureProperties(t)}setSelected(e){let{type:t}=this.store.getGeometryCopy(e),n={featureId:e,propertyMutations:{[A.SELECTED]:!0},context:{updateType:k.Commit}};t===`Polygon`?this.updatePolygon(n):t===`LineString`?this.updateLineString(n):t===`Point`&&this.updatePoint(n)}updateGuidancePoints(e){this.updateFeatureGeometries(e.map(({featureId:e,coordinate:t})=>({id:e,geometry:{type:`Point`,coordinates:t}})))}handleCreateFeature({geometry:e,properties:t}){return this.createFeatureWithGeometry({geometry:e,properties:t})}handleMutateFeature({type:e,featureId:t,coordinateMutations:n,propertyMutations:r,context:i}){if(!this.mutateFeature({type:e,featureId:t,coordinateMutations:n,propertyMutations:r,context:i.updateType===k.Finish?D({},i,{correctRightHandRule:!0}):D({},i)}))return null;let a=this.buildFeatureWithGeometry(t);return i.updateType!==k.Finish||n||this.validateGeometryWithUpdateType({geometry:a.geometry,properties:a.properties,updateType:i.updateType})?a:null}mutateFeature({type:e,featureId:t,coordinateMutations:n,propertyMutations:r,context:i}){if(!t)return!1;let a=this.store.getGeometryCopy(t),o=this.store.getPropertiesCopy(t);if(a.type!==e)throw Error(`${e} geometries cannot be updated on features with ${a.type} geometries`);if(n){let e=this.applyCoordinateMutations(a,n);if(i.correctRightHandRule&&e.type===`Polygon`){let t=Et(e);t&&(e=t)}if(!this.validateGeometryWithUpdateType({geometry:e,properties:o,updateType:i.updateType}))return!1;this.updateFeatureGeometries([{id:t,geometry:e}])}return r&&this.updateFeatureProperties([{featureId:t,properties:r}]),!0}applyCoordinateMutations(e,t){if(this.isReplaceMutation(t))return D({},e,{coordinates:t.coordinates});if(e.type===`Point`)throw Error(`Coordinate mutations are not supported for Point geometries`);let n=e.type===`Polygon`,r=n?e.coordinates[0].slice():e.coordinates.slice(),i=r.length,a=e=>{let t=e<0?i+e:e;if(t<0||t>=i)throw RangeError(`Index ${e} (normalized to ${t}) is out of bounds`);return t},o=Array(i).fill(void 0),s=Array.from({length:i},()=>[]),c=Array.from({length:i},()=>[]),l=[];for(let e of t){if(e.type===Dt||e.type===B){let t=e.index,n=t<0?i+t:t;if(n<0||n>i)throw RangeError(`Index ${e.index} (normalized to ${n}) is out of bounds`);if(e.type===Dt){if(n>=i)throw RangeError(`INSERT_BEFORE index ${e.index} (normalized to ${n}) is out of bounds for length ${i}`);s[n].push(e)}else n===i?l.push(e):c[n].push(e);continue}let t=a(e.index);o[t]=D({},e,{index:t})}let u=[];for(let e=0;e<i;e++){let t=s[e];for(let e of t)u.push(e.coordinate);let n=o[e];n?n.type===Ot||u.push(n.coordinate):u.push(r[e]);let i=c[e];for(let e of i)u.push(e.coordinate)}for(let e of l)u.push(e.coordinate);return D({},e,n?{coordinates:[u,...e.coordinates.slice(1)]}:{coordinates:u})}isReplaceMutation(e){return e.type===H}createFeatureWithGeometry({geometry:e,properties:t}){let[n]=this.createFeatures([{type:`Feature`,geometry:e,properties:t}]);return{id:n,type:`Feature`,properties:this.store.getPropertiesCopy(n),geometry:this.store.getGeometryCopy(n)}}validateGeometryWithUpdateType({geometry:e,properties:t,updateType:n}){return!this.options.validate||this.options.validate({type:`Feature`,geometry:e,properties:t||{}},{project:this.project,unproject:this.unproject,coordinatePrecision:this.coordinatePrecision,updateType:n}).valid}buildFeatureWithGeometry(e){return{id:e,type:`Feature`,properties:this.store.getPropertiesCopy(e),geometry:this.store.getGeometryCopy(e)}}createFeatures(e){return this.store.create(e)}updateFeatureGeometries(e){this.store.updateGeometry(e)}updateFeatureProperties(e){let t=e.map(({featureId:e,properties:t})=>Object.entries(t).map(([t,n])=>({id:e,property:t,value:n}))).flat();this.store.updateProperty(t)}},kt={cancel:`Escape`,finish:`Enter`},At={start:`crosshair`},jt=class extends N{constructor(e){super(e,!0),this.mode=`circle`,this.center=void 0,this.endPosition=void 0,this.segments=64,this.currentCircleId=void 0,this.keyEvents=kt,this.cursors=At,this.startingRadiusKilometers=1e-5,this.cursorMovedAfterInitialCursorDown=!1,this.drawInteraction=`click-move`,this.drawType=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.startingRadiusKilometers&&(this.startingRadiusKilometers=e.startingRadiusKilometers),e!=null&&e.drawInteraction&&(this.drawInteraction=e.drawInteraction),e!=null&&e.segments&&(this.segments=e.segments<3?3:e.segments)}close(){if(this.currentCircleId===void 0||this.endPosition===void 0||!this.updateCircle(this.endPosition,k.Finish))return;let e=this.currentCircleId;this.cursorMovedAfterInitialCursorDown=!1,this.center=void 0,this.currentCircleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}beginDrawing(e,t=`click`){this.center=[e.lng,e.lat],this.endPosition=[e.lng,e.lat];let n=mt({center:this.center,radiusKilometers:this.startingRadiusKilometers,coordinatePrecision:this.coordinatePrecision}),r=this.mutateFeature.createPolygon({coordinates:n.geometry.coordinates[0],properties:{mode:this.mode,radiusKilometers:this.startingRadiusKilometers,[j.CURRENTLY_DRAWING]:!0}});r&&(this.currentCircleId=r.id,this.cursorMovedAfterInitialCursorDown=!1,this.drawType=t,this.setDrawing())}dragDrawAllowed(){return this.drawInteraction===`click-drag`||this.drawInteraction===`click-move-or-drag`}moveDrawAllowed(){return this.drawInteraction===`click-move`||this.drawInteraction===`click-move-or-drag`}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){this.moveDrawAllowed()&&(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))&&(this.center?this.center&&this.currentCircleId!==void 0&&(this.endPosition=[e.lng,e.lat],this.close()):this.beginDrawing(e))}onMouseMove(e){this.cursorMovedAfterInitialCursorDown=!0,this.endPosition=[e.lng,e.lat],this.updateCircle(this.endPosition,k.Provisional)}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onDragStart(e,t){this.state!==`drawing`&&this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&this.dragDrawAllowed()&&(this.beginDrawing(e,`drag`),t(!1))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.cursorMovedAfterInitialCursorDown=!0,this.endPosition=[e.lng,e.lat],this.updateCircle(this.endPosition,k.Provisional))}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.endPosition=[e.lng,e.lat],this.close(),t(!0))}cleanUp(){let e=this.currentCircleId;this.center=void 0,this.currentCircleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Polygon`&&e.properties.mode===this.mode?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t):t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}updateCircle(e,t){if(this.currentCircleId===void 0||this.center===void 0)return;let n=t===k.Finish,r,i;if(this.cursorMovedAfterInitialCursorDown)if(i=P(this.center,e),this.projection===`web-mercator`){let t=function(e,t){let n=1e3*P(e,t);if(n===0)return 1;let{x:r,y:i}=L(e[0],e[1]),{x:a,y:o}=L(t[0],t[1]);return Math.sqrt((a-r)**2+(o-i)**2)/n}(this.center,e);r=function(e){let{center:t,radiusKilometers:n,coordinatePrecision:r}=e,i=e.steps?e.steps:64,a=1e3*n,[o,s]=t,{x:c,y:l}=L(o,s),u=[];for(let e=0;e<i;e++){let t=360*e/i*Math.PI/180,n=a*Math.cos(t),o=a*Math.sin(t),[s,d]=[c+n,l+o],{lng:f,lat:p}=R(s,d);u.push([I(f,r),I(p,r)])}return u.push(u[0]),{type:`Feature`,geometry:{type:`Polygon`,coordinates:[u]},properties:{}}}({center:this.center,radiusKilometers:i*t,coordinatePrecision:this.coordinatePrecision,steps:this.segments})}else{if(this.projection!==`globe`)throw Error(`Invalid projection`);r=mt({center:this.center,radiusKilometers:i,coordinatePrecision:this.coordinatePrecision,steps:this.segments})}let a={};return r&&i&&(a.radiusKilometers=i),n&&(a[j.CURRENTLY_DRAWING]=void 0),this.mutateFeature.updatePolygon({featureId:this.currentCircleId,coordinateMutations:r?{type:H,coordinates:r.geometry.coordinates}:void 0,propertyMutations:a,context:n?{updateType:t,action:O}:{updateType:t}})}afterFeatureUpdated(e){this.currentCircleId===e.id&&(this.cursorMovedAfterInitialCursorDown=!1,this.center=void 0,this.currentCircleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.mutateFeature=new U(e,{validate:this.validate})}},W=(e,t)=>{let{x:n,y:r}=e,{x:i,y:a}=t,o=i-n,s=a-r;return Math.sqrt(s*s+o*o)};function Mt(e,t){return e[0]===t[0]&&e[1]===t[1]}var G=class extends z{constructor(e){super(e)}getGeometryType(e){return this.store.getGeometryCopy(e).type}coordinateAtIndexIsIdentical({featureId:e,newCoordinate:t,index:n}){let r=this.store.getGeometryCopy(e),i;if(r.type===`Polygon`)i=r.coordinates[0][n];else if(r.type===`LineString`)i=r.coordinates[n];else{if(n!==0)throw Error(`Point geometries only have one coordinate at index 0`);i=r.coordinates}return Mt(t,i)}getGeometry(e){return this.store.getGeometryCopy(e)}getCoordinates(e){let{type:t,coordinates:n}=this.store.getGeometryCopy(e);return t===`Polygon`?n[0]:n}getCoordinate(e,t){let n=this.getCoordinates(e),r=t<0?n.length+t:t;if(r<0||r>=n.length)throw RangeError(`Index ${t} (normalized to ${r}) is out of bounds`);return n[r]}getProperties(e){return this.store.getPropertiesCopy(e)}hasFeature(e){return this.store.has(e)}getAllFeatureIdsWhere(e){return this.store.copyAllWhere(e).map(({id:e})=>e)}},Nt={cancel:`Escape`,finish:`Enter`},Pt={start:`crosshair`,close:`pointer`},Ft=class extends N{constructor(e){super(e,!0),this.mode=`freehand`,this.canClose=!1,this.currentId=void 0,this.closingPointId=void 0,this.minDistance=20,this.keyEvents=Nt,this.cursors=Pt,this.preventPointsNearClose=!0,this.autoClose=!1,this.autoCloseTimeout=500,this.hasLeftStartingPoint=!1,this.preventNewFeature=!1,this.drawInteraction=`click-move`,this.drawType=void 0,this.smoothing=0,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.minDistance&&(this.minDistance=e.minDistance),e?.smoothing!==void 0&&(this.smoothing=Math.min(Math.max(e.smoothing,0),.999)),e?.preventPointsNearClose!==void 0&&(this.preventPointsNearClose=e.preventPointsNearClose),e?.autoClose!==void 0&&(this.autoClose=e.autoClose),e!=null&&e.autoCloseTimeout&&(this.autoCloseTimeout=e.autoCloseTimeout),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.drawInteraction&&(this.drawInteraction=e.drawInteraction)}moveDrawAllowed(){return this.drawInteraction===`click-move`||this.drawInteraction===`click-move-or-drag`}dragDrawAllowed(){return this.drawInteraction===`click-drag`||this.drawInteraction===`click-move-or-drag`}beginDrawing(e,t=`click`){let{id:n}=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.currentId=n,this.drawType=t,this.closingPointId=this.mutateFeature.createGuidancePoint({coordinate:[e.lng,e.lat],type:j.CLOSING_POINT}),this.canClose=!0,this.state!==`drawing`&&this.setDrawing()}addCoordinate(e){if(this.currentId===void 0||!1===this.canClose)return void this.setCursor(this.cursors.start);let[t,n]=this.readFeature.getCoordinate(this.currentId,-2),{x:r,y:i}=this.project(t,n),a=W({x:r,y:i},{x:e.containerX,y:e.containerY}),[o,s]=this.readFeature.getCoordinate(this.currentId,0),{x:c,y:l}=this.project(o,s);if(W({x:c,y:l},{x:e.containerX,y:e.containerY})<this.pointerDistance){if(this.autoClose&&this.hasLeftStartingPoint&&(this.preventNewFeature=!0,setTimeout(()=>{this.preventNewFeature=!1},this.autoCloseTimeout),this.close()),this.setCursor(this.cursors.close),this.preventPointsNearClose)return}else this.hasLeftStartingPoint=!0,this.setCursor(this.cursors.start);if(a<this.minDistance)return;let u=this.getSmoothedCoordinate([t,n],[e.lng,e.lat]);this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:Dt,index:-1,coordinate:u}],context:{updateType:k.Provisional}})}getSmoothedCoordinate(e,t){if(this.smoothing===0)return t;let[n,r]=e,[i,a]=t;return[n*this.smoothing+i*(1-this.smoothing),r*this.smoothing+a*(1-this.smoothing)]}close(){if(this.currentId===void 0||!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.mutateFeature.deleteFeatureIfPresent(this.closingPointId),this.canClose=!1,this.currentId=void 0,this.closingPointId=void 0,this.hasLeftStartingPoint=!1,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){this.moveDrawAllowed()&&this.drawType===`click`&&this.addCoordinate(e)}onClick(e){if(this.moveDrawAllowed()&&(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))){if(this.preventNewFeature)return;if(!1===this.canClose)return void this.beginDrawing(e);this.close()}}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&!0===this.canClose&&this.close()}onDragStart(e,t){this.state!==`drawing`&&(this.preventNewFeature||this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&this.dragDrawAllowed()&&(this.beginDrawing(e,`drag`),t(!1)))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&this.addCoordinate(e)}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.preventNewFeature=!0,setTimeout(()=>{this.preventNewFeature=!1},this.autoCloseTimeout),this.close(),t(!0))}cleanUp(){let e=this.currentId,t=this.closingPointId;this.closingPointId=void 0,this.currentId=void 0,this.canClose=!1,this.hasLeftStartingPoint=!1,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(t)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Polygon`&&e.properties.mode===this.mode?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t):e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode?(t.pointWidth=this.getNumericStylingValue(this.styles.closingPointWidth,t.pointWidth,e),t.pointColor=this.getHexColorStylingValue(this.styles.closingPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.closingPointOpacity,t.pointOpacity===void 0?1:t.pointOpacity,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.closingPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.closingPointOutlineWidth,2,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.closingPointOutlineOpacity,t.pointOutlineOpacity===void 0?1:t.pointOutlineOpacity,e),t.zIndex=50,t):t}validateFeature(e){return this.validateModeFeature(e,e=>wt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.mutateFeature.deleteFeatureIfPresent(this.closingPointId),this.canClose=!1,this.currentId=void 0,this.closingPointId=void 0,this.hasLeftStartingPoint=!1)}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}};function It({unproject:e,point:t,pointerDistance:n}){let r=n/2,{x:i,y:a}=t;return{type:`Feature`,properties:{},geometry:{type:`Polygon`,coordinates:[[e(i-r,a-r),e(i+r,a-r),e(i+r,a+r),e(i-r,a+r),e(i-r,a-r)].map(e=>[e.lng,e.lat])]}}}var Lt=class extends z{constructor(e){super(e)}create(e){let{containerX:t,containerY:n}=e;return It({unproject:this.unproject,point:{x:t,y:n},pointerDistance:this.pointerDistance})}},Rt=class extends z{constructor(e){super(e)}measure(e,t){let{x:n,y:r}=this.project(t[0],t[1]);return W({x:n,y:r},{x:e.containerX,y:e.containerY})}},zt=class extends z{constructor(e,t,n){super(e),this.config=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.getSnappableCoordinateFirstClick=e=>this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode)).coordinate,this.getSnappableCoordinate=(e,t)=>this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode&&e.id!==t)).coordinate,this.config=e,this.pixelDistance=t,this.clickBoundingBox=n}getSnappable(e,t){let n=this.clickBoundingBox.create(e),r=this.store.search(n,t),i={featureId:void 0,featureCoordinateIndex:void 0,coordinate:void 0,minDist:1/0};return r.forEach(t=>{let n;if(t.geometry.type===`Polygon`)n=t.geometry.coordinates[0];else{if(t.geometry.type!==`LineString`)return;n=t.geometry.coordinates}n.forEach((n,r)=>{let a=this.pixelDistance.measure(e,n);a<i.minDist&&a<this.pointerDistance&&(i.coordinate=n,i.minDist=a,i.featureId=t.id,i.featureCoordinateIndex=r)})}),i}};function Bt(e,t,n){let r=F(e[0]),i=F(e[1]),a=F(n),o=ct(t),s=Math.asin(Math.sin(i)*Math.cos(o)+Math.cos(i)*Math.sin(o)*Math.cos(a));return[lt(r+Math.atan2(Math.sin(a)*Math.sin(o)*Math.cos(i),Math.cos(o)-Math.sin(i)*Math.sin(s))),lt(s)]}function Vt({x:e,y:t},n,r){let i=F(r);return{x:e+n*Math.cos(i),y:t+n*Math.sin(i)}}function Ht(e,t){let n=F(e[0]),r=F(t[0]),i=F(e[1]),a=F(t[1]),o=Math.sin(r-n)*Math.cos(a),s=Math.cos(i)*Math.sin(a)-Math.sin(i)*Math.cos(a)*Math.cos(r-n);return lt(Math.atan2(o,s))}function K({x:e,y:t},{x:n,y:r}){let i=n-e,a=r-t;if(i===0&&a===0)return 0;let o=Math.atan2(a,i);return o*=180/Math.PI,o>180?o-=360:o<-180&&(o+=360),o}function Ut(e){return(e+360)%360}function Wt(e,t,n){let r=[],i=e.length,a,o,s,c=0;for(let i=0;i<e.length&&!(t>=c&&i===e.length-1);i++){if(c>t&&r.length===0){if(a=t-c,!a)return r.push(e[i]),r;o=Ht(e[i],e[i-1])-180,s=Bt(e[i],a,o),r.push(s)}if(c>=n)return a=n-c,a?(o=Ht(e[i],e[i-1])-180,s=Bt(e[i],a,o),r.push(s),r):(r.push(e[i]),r);if(c>=t&&r.push(e[i]),i===e.length-1)return r;c+=P(e[i],e[i+1])}if(c<t&&e.length===i)throw Error(`Start position is beyond line`);let l=e[e.length-1];return[l,l]}function Gt(e){return Math.PI/180*e}function Kt(e){return 180/Math.PI*e}var qt=class extends z{constructor(e){super(e),this.config=void 0,this.config=e}generateInsertionCoordinates(e,t,n){let r=[e,t],i=0;for(let e=0;e<r.length-1;e++)i+=P(r[0],r[1]);if(i<=n)return r;let a=i/n-1;Number.isInteger(a)||(a=Math.floor(a)+1);let o=[];for(let e=0;e<a;e++){let t=Wt(r,n*e,n*(e+1));o.push(t)}let s=[];for(let e=0;e<o.length;e++)s.push(o[e][1]);return this.limitCoordinates(s)}generateInsertionGeodesicCoordinates(e,t,n){let r=P(e,t),i=function(e,t,n){let r=[],i=Gt(e[1]),a=Gt(e[0]),o=Gt(t[1]),s=Gt(t[0]);n+=1;let c=2*Math.asin(Math.sqrt(Math.sin((o-i)/2)**2+Math.cos(i)*Math.cos(o)*Math.sin((s-a)/2)**2));if(c===0||isNaN(c))return r;for(let e=0;e<=n;e++){let t=e/n,l=Math.sin((1-t)*c)/Math.sin(c),u=Math.sin(t*c)/Math.sin(c),d=l*Math.cos(i)*Math.cos(a)+u*Math.cos(o)*Math.cos(s),f=l*Math.cos(i)*Math.sin(a)+u*Math.cos(o)*Math.sin(s),p=l*Math.sin(i)+u*Math.sin(o);if(isNaN(d)||isNaN(f)||isNaN(p))continue;let m=Math.atan2(p,Math.sqrt(d**2+f**2)),h=Math.atan2(f,d);isNaN(m)||isNaN(h)||r.push([Kt(h),Kt(m)])}return r.slice(1,-1)}(e,t,Math.floor(r/n));return this.limitCoordinates(i)}limitCoordinates(e){return e.map(e=>[I(e[0],this.config.coordinatePrecision),I(e[1],this.config.coordinatePrecision)])}};function Jt(e,t){if(e.geometry.type!==`LineString`)return{valid:!1,reason:`Feature is not a LineString`};if(e.geometry.coordinates.length<2)return{valid:!1,reason:`Feature has less than 2 coordinates`};for(let n=0;n<e.geometry.coordinates.length;n++){if(!vt(e.geometry.coordinates[n]))return{valid:!1,reason:`Feature has invalid coordinates`};if(!_t(e.geometry.coordinates[n],t))return{valid:!1,reason:`Feature has coordinates with excessive precision`}}return{valid:!0}}function Yt(e){return Math.sqrt(e[0]**2+e[1]**2+e[2]**2)}function Xt(e,t){let n=function(e,t){let[n,r,i]=e,[a,o,s]=t;return n*a+r*o+i*s}(e,t)/(Yt(e)*Yt(t));return Math.acos(Math.min(Math.max(n,-1),1))}function Zt(e){let t=F(e[1]),n=F(e[0]);return[Math.cos(t)*Math.cos(n),Math.cos(t)*Math.sin(n),Math.sin(t)]}function Qt(e){let[t,n,r]=e,i=lt(Math.asin(r));return[lt(Math.atan2(n,t)),i]}function $t(e,t,n){let r=Zt(e),i=Zt(t),[a,o,s]=Zt(n),[c,l,u]=function(e,t){let[n,r,i]=e,[a,o,s]=t;return[r*s-i*o,i*a-n*s,n*o-r*a]}(r,i),d=l*s-u*o,f=u*a-c*s,p=c*o-l*a,m=p*l-f*u,h=d*u-p*c,g=f*c-d*l,_=1/Math.sqrt(m**2+h**2+g**2),v=[m*_,h*_,g*_],y=[-1*m*_,-1*h*_,-1*g*_],ee=Xt(r,i),b=Xt(r,v),x=Xt(i,v),te=Xt(r,y),ne=Xt(i,y),S;return S=b<te&&b<ne||x<te&&x<ne?v:y,Xt(r,S)>ee||Xt(i,S)>ee?P(Qt(S),Qt(r))<=P(Qt(S),Qt(i))?[Qt(r),!0,!1]:[Qt(i),!1,!0]:[Qt(S),!1,!1]}function en(e,t,n){let r=t.x-e.x,i=t.y-e.y,a=Math.max(0,Math.min(1,((n.x-e.x)*r+(n.y-e.y)*i)/(r*r+i*i)));return{x:e.x+a*r,y:e.y+a*i}}var tn=class extends z{constructor(e,t,n){super(e),this.config=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.getSnappableCoordinateFirstClick=e=>{let t=this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode));return t.coordinate?[I(t.coordinate[0],this.config.coordinatePrecision),I(t.coordinate[1],this.config.coordinatePrecision)]:void 0},this.getSnappableCoordinate=(e,t)=>{let n=this.getSnappable(e,e=>!!(e.properties&&e.properties.mode===this.mode&&e.id!==t));return n.coordinate?[I(n.coordinate[0],this.config.coordinatePrecision),I(n.coordinate[1],this.config.coordinatePrecision)]:void 0},this.config=e,this.pixelDistance=t,this.clickBoundingBox=n}getSnappable(e,t){let n=this.clickBoundingBox.create(e),r=this.store.search(n,t),i={featureId:void 0,featureCoordinateIndex:void 0,coordinate:void 0,minDistance:1/0};return r.forEach(t=>{let n;if(t.geometry.type===`Polygon`)n=t.geometry.coordinates[0];else{if(t.geometry.type!==`LineString`)return;n=t.geometry.coordinates}let r=[];for(let e=0;e<n.length-1;e++)r.push([n[e],n[e+1]]);let a,o=[e.lng,e.lat];if(this.config.projection===`web-mercator`?a=function(e,t){let n=[1/0,1/0],r=1/0,i=0;for(let a of t){let o=a[0],s=a[1],c,l=1/0,u=L(o[0],o[1]),d=L(s[0],s[1]),f=L(e[0],e[1]);if(o[0]===e[0]&&o[1]===e[1])c=o;else if(s[0]===e[0]&&s[1]===e[1])c=s;else{let{x:e,y:t}=en(u,d,f),{lng:n,lat:r}=R(e,t);c=[n,r]}c&&(l=W(f,L(c[0],c[1])),l<r&&(n=c,r=l,i=t.indexOf(a)))}return r===1/0?void 0:{coordinate:n,lineIndex:i,distance:r}}(o,r):this.config.projection===`globe`&&(a=function(e,t){let n=[1/0,1/0],r=1/0,i=0;for(let a of t){let o=a[0],s=a[1],c,l=1/0;o[0]===e[0]&&o[1]===e[1]?c=o:s[0]===e[0]&&s[1]===e[1]?c=s:[c]=$t(o,s,e),c&&(l=P(e,c),l<r&&(n=c,r=l,i=t.indexOf(a)))}return r===1/0?void 0:{coordinate:n,distance:r,lineIndex:i}}(o,r)),!a)return;let s=this.pixelDistance.measure(e,a.coordinate);s<i.minDistance&&s<this.pointerDistance&&(i.featureId=t.id,i.coordinate=[I(a.coordinate[0],this.config.coordinatePrecision),I(a.coordinate[1],this.config.coordinatePrecision)],i.featureCoordinateIndex=a.lineIndex,i.minDistance=s)}),i}};function nn(e){return Array.isArray(e)&&e.length>0&&Array.isArray(e[0])&&Array.isArray(e[0][0])}var rn=e=>nn(e)?e[0].slice(0,-1):e,an=e=>nn(e)?e[0]:e,on=class extends z{constructor(e,t,n,r){super(e),this.config=void 0,this.pixelDistance=void 0,this.mutateFeatureBehavior=void 0,this.readFeatureBehavior=void 0,this._startEndPoints=[],this.config=e,this.pixelDistance=t,this.mutateFeatureBehavior=n,this.readFeatureBehavior=r}get ids(){return this._startEndPoints.concat()}set ids(e){}create(e){if(this.ids.length)throw Error(`Opening and closing points already created`);let t=nn(e),n=an(e);if(t){if(n.length<=3)throw Error(`Requires at least 4 coordinates`);this._startEndPoints=this.mutateFeatureBehavior.createGuidancePoints({coordinates:[n[0],n[n.length-2]],type:j.CLOSING_POINT})}else this._startEndPoints=[this.mutateFeatureBehavior.createGuidancePoint({coordinate:n[n.length-2],type:j.CLOSING_POINT})]}delete(){this.ids.length&&(this.mutateFeatureBehavior.deleteFeaturesIfPresent(this.ids),this._startEndPoints=[])}updateOne(e,t){this.mutateFeatureBehavior.updateGuidancePoints([{featureId:this.ids[e],coordinate:t}])}update(e){let t=an(e);this.ids.length===1?this.mutateFeatureBehavior.updateGuidancePoints([{featureId:this.ids[0],coordinate:t[t.length-2]}]):this.ids.length===2&&this.mutateFeatureBehavior.updateGuidancePoints([{featureId:this.ids[0],coordinate:t[0]},{featureId:this.ids[1],coordinate:t[t.length-3]}])}isLineStringClosingPoint(e){if(this.ids.length!==1)return{isClosing:!1};let t=this.readFeatureBehavior.getGeometry(this.ids[0]);return{isClosing:this.pixelDistance.measure(e,t.coordinates)<this.pointerDistance}}isPolygonClosingPoints(e){if(this.ids.length!==2)return{isClosing:!1,isPreviousClosing:!1};let t=this.readFeatureBehavior.getGeometry(this.ids[0]),n=this.readFeatureBehavior.getGeometry(this.ids[1]),r=this.pixelDistance.measure(e,t.coordinates),i=this.pixelDistance.measure(e,n.coordinates);return{isClosing:r<this.pointerDistance,isPreviousClosing:i<this.pointerDistance}}},sn=class extends z{constructor(e,t,n){super(e),this.readFeature=void 0,this.mutateFeature=void 0,this.readFeature=t,this.mutateFeature=n}createOrUpdate({featureId:e,featureCoordinates:t}){if(!this.readFeature.hasFeature(e))return void this.deleteOrphanedPoints(e);let n=rn(t),r=this.readFeature.getProperties(e),i=r.coordinatePointIds;if(i)if(i&&i.every(e=>this.readFeature.hasFeature(e))){let t=r.coordinatePointIds,i=t.map(e=>this.readFeature.getGeometry(e).coordinates);if(t.length!==n.length){this.deleteCoordinatePoints(t);let i=this.createPoints(n,r.mode,e);this.setFeatureCoordinatePoints(e,i)}else{let e=[];n.forEach((n,r)=>{n[0]===i[r][0]&&n[1]===i[r][1]||e.push({featureId:t[r],coordinate:n})}),this.mutateFeature.updateGuidancePoints(e)}}else{let t=i.filter(e=>this.readFeature.hasFeature(e));t.length&&this.deleteCoordinatePoints(t);let a=this.createPoints(n,r.mode,e);this.setFeatureCoordinatePoints(e,a)}else{let t=this.createPoints(n,r.mode,e);this.setFeatureCoordinatePoints(e,t)}}deletePointsByFeatureIds(e){for(let t of e)this.deleteIfPresent(t)}updateOneAtIndex(e,t,n){let r=this.readFeature.getProperties(e).coordinatePointIds;r&&r.length!==0&&r[t]!==void 0&&this.mutateFeature.updateGuidancePoints([{featureId:r[t],coordinate:n}])}updateAllInPlace({featureId:e,featureCoordinates:t}){let n=this.readFeature.getProperties(e);if(!n.coordinatePointIds)return;let r=rn(t);r.length===n.coordinatePointIds.length&&this.mutateFeature.updateGuidancePoints(n.coordinatePointIds.map((e,t)=>({featureId:e,coordinate:r[t]})))}createPoints(e,t,n){return this.mutateFeature.createGuidancePoints({coordinates:e,type:j.COORDINATE_POINT,additionalProperties:e=>({mode:t,[j.COORDINATE_POINT]:!0,[j.COORDINATE_POINT_FEATURE_ID]:n,index:e})})}setFeatureCoordinatePoints(e,t,n=k.Commit){let r=this.readFeature.getGeometryType(e),i={featureId:e,propertyMutations:{[j.COORDINATE_POINT_IDS]:t},context:{updateType:n}};if(r===`Polygon`)this.mutateFeature.updatePolygon(i);else{if(r!==`LineString`)throw Error(`Unsupported geometry type for coordinate points`);this.mutateFeature.updateLineString(i)}}deleteCoordinatePoints(e){this.mutateFeature.deleteFeaturesIfPresent(e)}deleteIfPresent(e){if(!this.readFeature.hasFeature(e))return;let t=this.readFeature.getProperties(e).coordinatePointIds;t&&(this.deleteCoordinatePoints(t),this.setFeatureCoordinatePoints(e,null))}deleteOrphanedPoints(e){let t=this.readFeature.getAllFeatureIdsWhere(t=>t[j.COORDINATE_POINT_FEATURE_ID]===e);this.mutateFeature.deleteFeaturesIfPresent(t)}},cn=class{constructor(e){this.undoHistory=[],this.redoHistory=[],this.cloneCoordinatesFunction=void 0,this.maxStackSize=void 0,this.cloneCoordinatesFunction=e=>this.cloneRecursively(e);let t=e?.maxStackSize;this.maxStackSize=t!==void 0&&Number.isFinite(t)?Math.max(0,Math.floor(t)):1/0}setMaxStackSize(e){Number.isFinite(e)?(this.maxStackSize=Math.max(0,Math.floor(e)),this.trimHistoryToMax(this.undoHistory),this.trimHistoryToMax(this.redoHistory)):this.maxStackSize=1/0}trimHistoryToMax(e){if(Number.isFinite(this.maxStackSize))for(;e.length>this.maxStackSize;)e.shift()}pushUndoEntry(e){this.maxStackSize!==0&&(this.undoHistory.push(e),this.trimHistoryToMax(this.undoHistory))}pushRedoEntry(e){this.maxStackSize!==0&&(this.redoHistory.push(e),this.trimHistoryToMax(this.redoHistory))}cloneRecursively(e){return Array.isArray(e)?e.map(e=>this.cloneRecursively(e)):typeof e==`object`&&e?D({},e):e}cloneCoordinates(e){return this.cloneCoordinatesFunction(e)}cloneEntry(e){return{featureCoordinates:this.cloneCoordinates(e.featureCoordinates),currentCoordinate:e.currentCoordinate}}clear(){this.undoHistory=[],this.redoHistory=[]}undoSize(){return this.undoHistory.length}redoSize(){return this.redoHistory.length}recordSnapshot(e){this.pushUndoEntry(this.cloneEntry(e)),this.redoHistory=[]}beginUndo(){let e=this.undoHistory.pop();if(!e)return;let t=this.cloneEntry(e);this.pushRedoEntry(t);let n=this.undoHistory[this.undoHistory.length-1];return{undoneEntry:t,previousEntry:n?this.cloneEntry(n):void 0}}takeRedo(){let e=this.redoHistory.pop();if(e)return this.cloneEntry(e)}commitRedo(e){this.pushUndoEntry(this.cloneEntry(e))}},ln={cancel:`Escape`,finish:`Enter`},un={start:`crosshair`,close:`pointer`,dragStart:`grabbing`,dragEnd:`crosshair`},dn=class extends N{constructor(e){super(e,!0),this.mode=`linestring`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=ln,this.snapping=void 0,this.cursors=un,this.mouseMove=!1,this.insertCoordinates=void 0,this.lastCommittedCoordinates=void 0,this.snappedPointId=void 0,this.lastMouseMoveEvent=void 0,this.showCoordinatePoints=!1,this.finishOnNthCoordinate=void 0,this.editable=!1,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0,this.editedInsertIndex=void 0,this.editedPointId=void 0,this.coordinateSnapping=void 0,this.insertPoint=void 0,this.lineSnapping=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.closingPoints=void 0,this.coordinatePoints=void 0,this.undoRedo=void 0,this.updateOptions(e)}updateOptions(e){if(super.updateOptions(e),e?.finishOnNthCoordinate!==void 0&&Number.isInteger(e.finishOnNthCoordinate)&&e.finishOnNthCoordinate>1&&(this.finishOnNthCoordinate=Math.floor(e.finishOnNthCoordinate)),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.snapping&&(this.snapping=e.snapping),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.insertCoordinates&&(this.insertCoordinates=e.insertCoordinates),e&&e.editable&&(this.editable=e.editable),e?.showCoordinatePoints!==void 0){if(this.showCoordinatePoints=e.showCoordinatePoints,this.coordinatePoints&&!0===e.showCoordinatePoints)this.store.copyAllWhere(e=>e.mode===this.mode).forEach(e=>{this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})});else if(this.coordinatePoints&&!1===this.showCoordinatePoints){let e=this.store.copyAllWhere(e=>e.mode===this.mode&&!!e[j.COORDINATE_POINT_IDS]?.length);this.coordinatePoints.deletePointsByFeatureIds(e.map(e=>e.id))}}}shouldFinishOnCommit(e){return!!this.finishOnNthCoordinate&&Math.max(0,e.coordinates.length-1)>=this.finishOnNthCoordinate}updateSnappedCoordinate(e){let t=this.snapCoordinate(e);return t?(this.snappedPointId?this.mutateFeature.updateGuidancePoints([{featureId:this.snappedPointId,coordinate:t}]):this.snappedPointId=this.mutateFeature.createGuidancePoint({coordinate:t,type:j.SNAPPING_POINT}),e.lng=t[0],e.lat=t[1]):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),t}close(){if(this.currentId===void 0)return;let e=this.mutateFeature.updateLineString({featureId:this.currentId,context:{updateType:k.Finish,action:O},coordinateMutations:[{type:Ot,index:-1}],propertyMutations:{[j.CURRENTLY_DRAWING]:void 0}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates});let t=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.lastCommittedCoordinates=void 0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted(),this.closingPoints.delete(),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0),this.onFinish(t,{mode:this.mode,action:O})}generateInsertCoordinates(e,t){if(!this.insertCoordinates||!this.lastCommittedCoordinates)throw Error(`Not able to insert coordinates`);if(this.insertCoordinates.strategy!==`amount`)throw Error(`Strategy does not exist`);let n=P(e,t)/(this.insertCoordinates.value+1),r=[];return this.projection===`globe`?r=this.insertPoint.generateInsertionGeodesicCoordinates(e,t,n):this.projection===`web-mercator`&&(r=this.insertPoint.generateInsertionCoordinates(e,t,n)),r}createLine(e){let t=this.mutateFeature.createLineString({coordinates:[e,e],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.lastCommittedCoordinates=t.geometry.coordinates,this.currentId=t.id,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.setDrawing(),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates})}firstUpdateToLine(e){if(!this.currentId)return;this.setCursor(this.cursors.close);let t=this.mutateFeature.updateLineString({featureId:this.currentId,context:{updateType:k.Commit},coordinateMutations:[{type:B,index:-1,coordinate:e}]});t&&(this.closingPoints.create(t.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates}),this.lastCommittedCoordinates=t.geometry.coordinates,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.shouldFinishOnCommit(t.geometry)&&this.close())}updateToLine(e,t){if(!this.currentId)return;let{isClosing:n}=this.closingPoints.isLineStringClosingPoint(e);if(n)return void this.close();this.setCursor(this.cursors.close);let r=this.mutateFeature.updateLineString({featureId:this.currentId,context:{updateType:k.Commit},coordinateMutations:[{type:B,index:-1,coordinate:t}]});r&&(this.closingPoints.update(r.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:r.geometry.coordinates}),this.lastCommittedCoordinates=r.geometry.coordinates,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.shouldFinishOnCommit(r.geometry)&&this.close())}undoSize(){return this.undoRedo.undoSize()}clearHistory(){this.undoRedo.clear()}pushHistorySnapshot(e,t){let n=this.readFeature.getGeometry(e);this.undoRedo.recordSnapshot({featureCoordinates:n.coordinates,currentCoordinate:t})}updateSnappedGuidancePointFromLastMouseMove(){this.snapping&&this.lastMouseMoveEvent?this.updateSnappedCoordinate(this.lastMouseMoveEvent):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0)}syncClosingPoints(e){this.currentCoordinate>=2?this.closingPoints.ids.length?this.closingPoints.update(e):this.closingPoints.create(e):this.closingPoints.delete()}undo(){if(this.state!==`drawing`||!this.currentId)return;let e=this.undoRedo.beginUndo();if(!e)return;let{previousEntry:t}=e;if(!t){let e=this.currentId;this.currentId=void 0,this.currentCoordinate=0,this.lastCommittedCoordinates=void 0,this.closingPoints.delete(),this.state===`drawing`&&this.setStarted(),this.showCoordinatePoints&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.updateSnappedGuidancePointFromLastMouseMove();return}let n=this.mutateFeature.updateLineString({featureId:this.currentId,coordinateMutations:{type:H,coordinates:t.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0},context:{updateType:k.Commit}});n&&(this.currentCoordinate=t.currentCoordinate,this.lastCommittedCoordinates=n.geometry.coordinates,this.syncClosingPoints(n.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:n.geometry.coordinates}),this.updateSnappedGuidancePointFromLastMouseMove())}redoSize(){return this.undoRedo.redoSize()}redo(){let e=this.undoRedo.takeRedo();if(e){if(this.currentId){let t=this.mutateFeature.updateLineString({featureId:this.currentId,coordinateMutations:{type:H,coordinates:e.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0},context:{updateType:k.Commit}});if(!t)return;this.currentCoordinate=e.currentCoordinate,this.lastCommittedCoordinates=t.geometry.coordinates,this.syncClosingPoints(t.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates})}else{let{id:t,geometry:n}=this.mutateFeature.createLineString({coordinates:e.featureCoordinates,properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.currentId=t,this.currentCoordinate=e.currentCoordinate,this.lastCommittedCoordinates=n.coordinates,this.state===`started`&&this.setDrawing(),this.syncClosingPoints(n.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:t,featureCoordinates:n.coordinates})}this.undoRedo.commitRedo(e),this.updateSnappedGuidancePointFromLastMouseMove()}}registerBehaviors(e){this.insertPoint=new qt(e),this.clickBoundingBox=new Lt(e),this.pixelDistance=new Rt(e),this.lineSnapping=new tn(e,this.pixelDistance,this.clickBoundingBox),this.coordinateSnapping=new zt(e,this.pixelDistance,this.clickBoundingBox),this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate}),this.closingPoints=new on(e,this.pixelDistance,this.mutateFeature,this.readFeature),this.coordinatePoints=new sn(e,this.readFeature,this.mutateFeature),this.undoRedo=new cn({maxStackSize:e.undoRedoMaxStackSize})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){this.mouseMove=!0,this.setCursor(this.cursors.start),this.lastMouseMoveEvent=e;let t=this.updateSnappedCoordinate(e)||[e.lng,e.lat];if(this.currentId===void 0||this.currentCoordinate===0)return;let{isClosing:n}=this.closingPoints.isLineStringClosingPoint(e);n&&this.setCursor(this.cursors.close);let r=[{type:V,index:-1,coordinate:t}];if(this.insertCoordinates){let e=this.getInsertCoordinates(t);e&&(r={type:H,coordinates:e})}let i=this.mutateFeature.updateLineString({coordinateMutations:r,featureId:this.currentId,context:{updateType:k.Provisional}});i&&this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:i.geometry.coordinates})}getInsertCoordinates(e){if(!this.lastCommittedCoordinates)return;let t=this.lastCommittedCoordinates[this.lastCommittedCoordinates.length-1];if(Mt(t,e))return;let n=this.generateInsertCoordinates(t,e);return[...this.lastCommittedCoordinates.slice(0,-1),...n,e]}onRightClick(e){if(!this.editable||this.state!==`started`)return;let{featureId:t,featureCoordinateIndex:n}=this.coordinateSnapping.getSnappable(e,e=>this.lineStringFilter(e));if(!t||n===void 0)return;let r=this.readFeature.getGeometry(t),i;if(r.type!==`LineString`||(i=r.coordinates,i.length<=2))return;let a=this.mutateFeature.updateLineString({featureId:t,coordinateMutations:[{type:Ot,index:n}],context:{updateType:k.Finish,action:Xe}});a&&this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:t,featureCoordinates:a.geometry.coordinates}),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0),this.closingPoints.delete(),this.onFinish(t,{mode:this.mode,action:Ze})}onLeftClick(e){this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0);let t=this.snapCoordinate(e)||[e.lng,e.lat];this.currentCoordinate===0?this.createLine(t):this.currentCoordinate===1&&this.currentId?this.firstUpdateToLine(t):this.currentId&&this.updateToLine(e,t)}onClick(e){this.currentId===void 0||this.readFeature.hasFeature(this.currentId)||this.cleanUp(),(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))&&(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,e.button===`right`?this.onRightClick(e):e.button===`left`&&this.onLeftClick(e))}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel&&this.cleanUp(),e.key===this.keyEvents.finish&&this.close()}onDragStart(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragStart,e)||!this.editable)return;let n;if(this.state===`started`){let t=this.lineSnapping.getSnappable(e,e=>this.lineStringFilter(e));t.coordinate&&(this.editedSnapType=`line`,this.editedFeatureCoordinateIndex=t.featureCoordinateIndex,this.editedFeatureId=t.featureId,n=t.coordinate);let r=this.coordinateSnapping.getSnappable(e,e=>this.lineStringFilter(e));r.coordinate&&(this.editedSnapType=`coordinate`,this.editedFeatureCoordinateIndex=r.featureCoordinateIndex,this.editedFeatureId=r.featureId,n=r.coordinate)}this.editedFeatureId&&n&&(this.editedPointId||=this.mutateFeature.createGuidancePoint({coordinate:n,type:j.EDITED}),this.setCursor(this.cursors.dragStart),t(!1))}onDrag(e,t){if(this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.editedFeatureId!==void 0&&this.editedFeatureCoordinateIndex!==void 0){if(this.editedSnapType===`coordinate`||this.editedSnapType===`line`&&this.editedInsertIndex!==void 0){let t=this.mutateFeature.updateLineString({featureId:this.editedFeatureId,context:{updateType:k.Provisional},coordinateMutations:[{type:V,index:this.editedFeatureCoordinateIndex,coordinate:[e.lng,e.lat]}]});if(!t)return;this.showCoordinatePoints&&(this.editedInsertIndex===void 0?this.coordinatePoints.updateOneAtIndex(this.editedFeatureId,this.editedFeatureCoordinateIndex,[e.lng,e.lat]):this.coordinatePoints.createOrUpdate({featureId:this.editedFeatureId,featureCoordinates:t.geometry.coordinates}))}else if(this.editedSnapType===`line`&&this.editedInsertIndex===void 0){this.editedInsertIndex=this.editedFeatureCoordinateIndex+1;let e=this.mutateFeature.updateLineString({featureId:this.editedFeatureId,context:{updateType:k.Provisional}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.editedFeatureId,featureCoordinates:e.geometry.coordinates}),this.editedFeatureCoordinateIndex++}this.snapping&&this.snappedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),this.snappedPointId=void 0),this.editedPointId&&this.mutateFeature.updateGuidancePoints([{featureId:this.editedPointId,coordinate:[e.lng,e.lat]}]),this.mutateFeature.updateLineString({featureId:this.editedFeatureId,context:{updateType:k.Provisional},propertyMutations:{[j.EDITED]:!0}})}}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||(this.setCursor(this.cursors.dragEnd),!this.mutateFeature.updateLineString({featureId:this.editedFeatureId,propertyMutations:{[j.EDITED]:!1},context:{updateType:k.Finish,action:Xe}})))return;let n=this.editedFeatureId;t(!0),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0),this.closingPoints.delete(),this.onFinish(n,{mode:this.mode,action:Xe})}cleanUp(){let e=this.currentId,t=this.snappedPointId;this.snappedPointId=void 0,this.currentId=void 0,this.currentCoordinate=0,this.lastCommittedCoordinates=void 0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted(),e&&this.showCoordinatePoints&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(t),this.closingPoints.delete()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.type===`Feature`&&e.geometry.type===`LineString`&&e.properties.mode===this.mode)return t.lineStringColor=this.getHexColorStylingValue(this.styles.lineStringColor,t.lineStringColor,e),t.lineStringOpacity=this.getNumericStylingValue(this.styles.lineStringOpacity,t.lineStringOpacity===void 0?1:t.lineStringOpacity,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.lineStringWidth,t.lineStringWidth,e),t.zIndex=M,t;if(e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode){let n=e.properties[j.COORDINATE_POINT],r=e.properties[j.CLOSING_POINT]?`closingPoint`:e.properties[j.SNAPPING_POINT]?`snappingPoint`:n?`coordinatePoint`:void 0;if(!r)return t;let i={closingPoint:{width:this.styles.closingPointWidth,color:this.styles.closingPointColor,opacity:this.styles.closingPointOpacity,outlineColor:this.styles.closingPointOutlineColor,outlineWidth:this.styles.closingPointOutlineWidth,outlineOpacity:this.styles.closingPointOutlineOpacity},snappingPoint:{width:this.styles.snappingPointWidth,color:this.styles.snappingPointColor,opacity:this.styles.snappingPointOpacity,outlineColor:this.styles.snappingPointOutlineColor,outlineWidth:this.styles.snappingPointOutlineWidth,outlineOpacity:this.styles.snappingPointOutlineOpacity},coordinatePoint:{width:this.styles.coordinatePointWidth,color:this.styles.coordinatePointColor,opacity:this.styles.coordinatePointOpacity,outlineColor:this.styles.coordinatePointOutlineColor,outlineWidth:this.styles.coordinatePointOutlineWidth,outlineOpacity:this.styles.coordinatePointOutlineOpacity}};return t.pointWidth=this.getNumericStylingValue(i[r].width,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(i[r].opacity,1,e),t.pointColor=this.getHexColorStylingValue(i[r].color,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(i[r].outlineColor,`#ffffff`,e),t.pointOutlineWidth=this.getNumericStylingValue(i[r].outlineWidth,2,e),t.pointOutlineOpacity=this.getNumericStylingValue(i[r].outlineOpacity,1,e),t.zIndex=n?20:50,t}return t}validateFeature(e){return this.validateModeFeature(e,e=>Jt(e,this.coordinatePrecision))}lineStringFilter(e){return!!(e.geometry.type===`LineString`&&e.properties&&e.properties.mode===this.mode)}snapCoordinate(e){var t,n,r;let i;if((t=this.snapping)!=null&&t.toLine){let t;t=this.currentId?this.lineSnapping.getSnappableCoordinate(e,this.currentId):this.lineSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((n=this.snapping)!=null&&n.toCoordinate){let t;t=this.currentId?this.coordinateSnapping.getSnappableCoordinate(e,this.currentId):this.coordinateSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((r=this.snapping)!=null&&r.toCustom){let t=this.snapping.toCustom(e,{currentCoordinate:this.currentCoordinate,currentId:this.currentId,getCurrentGeometrySnapshot:this.currentId?()=>this.readFeature.getGeometry(this.currentId):()=>null,project:this.project,unproject:this.unproject});t&&(i=t)}return i}afterFeatureUpdated(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates}),this.editedFeatureId===e.id&&this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0),this.snappedPointId&&this.lastMouseMoveEvent&&this.updateSnappedCoordinate(this.lastMouseMoveEvent),this.currentId===e.id&&(this.closingPoints.delete(),this.currentCoordinate=0,this.currentId=void 0,this.lastCommittedCoordinates=void 0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted())}afterFeatureAdded(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})}},fn=`Feature is not a Point`,pn=`Feature has invalid coordinates`,mn=`Feature has coordinates with excessive precision`;function hn(e,t){return e.geometry.type===`Point`?vt(e.geometry.coordinates)?_t(e.geometry.coordinates,t)?{valid:!0}:{valid:!1,reason:mn}:{valid:!1,reason:pn}:{valid:!1,reason:fn}}var gn=class extends z{constructor(e,t,n){super(e),this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.pixelDistance=t,this.clickBoundingBox=n}getNearestPointFeature(e){let t=this.clickBoundingBox.create(e),n=this.store.search(t),r,i=1/0;for(let t=0;t<n.length;t++){let a=n[t];if(a.geometry.type!==`Point`||a.properties.mode!==this.mode)continue;let o=this.pixelDistance.measure(e,a.geometry.coordinates);o>i||o>this.pointerDistance||(i=o,r=a)}return r}},_n={create:`crosshair`,dragStart:`grabbing`,dragEnd:`crosshair`},vn=class extends N{constructor(e){super(e,!0),this.mode=`point`,this.cursors=_n,this.editable=!1,this.editedFeatureId=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.pointSearch=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.editable&&(this.editable=e.editable)}start(){this.setStarted(),this.setCursor(this.cursors.create)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}onMouseMove(){}onKeyDown(){}onKeyUp(){}cleanUp(){this.editedFeatureId=void 0}onDragStart(e,t){this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&(this.editable&&(this.editedFeatureId=this.pointSearch.getNearestPointFeature(e)?.id),this.editedFeatureId&&(this.setCursor(this.cursors.dragStart),t(!1)))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.editedFeatureId!==void 0&&this.mutateFeature.updatePoint({featureId:this.editedFeatureId,coordinateMutations:{type:H,coordinates:[e.lng,e.lat]},propertyMutations:{[j.EDITED]:!0},context:{updateType:k.Provisional}})}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||!this.mutateFeature.updatePoint({featureId:this.editedFeatureId,propertyMutations:{mode:this.mode,[j.EDITED]:!1},context:{updateType:k.Finish,action:`edit`}}))return;let n=this.editedFeatureId;this.setCursor(this.cursors.dragEnd),this.editedFeatureId=void 0,t(!0),this.onFinish(n,{mode:this.mode,action:O})}registerBehaviors(e){this.pixelDistance=new Rt(e),this.clickBoundingBox=new Lt(e),this.pointSearch=new gn(e,this.pixelDistance,this.clickBoundingBox),this.mutateFeature=new U(e,{validate:this.validate})}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode){let n=!!(e.id&&this.editedFeatureId===e.id);t.pointWidth=this.getNumericStylingValue(n?this.styles.editedPointWidth:this.styles.pointWidth,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(this.styles.pointOpacity,t.pointOpacity===void 0?1:t.pointOpacity,e),t.pointColor=this.getHexColorStylingValue(n?this.styles.editedPointColor:this.styles.pointColor,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(n?this.styles.editedPointOutlineColor:this.styles.pointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.pointOutlineOpacity,t.pointOutlineOpacity===void 0?1:t.pointOutlineOpacity,e),t.pointOutlineWidth=this.getNumericStylingValue(n?this.styles.editedPointOutlineWidth:this.styles.pointOutlineWidth,2,e),t.zIndex=30}return t}validateFeature(e){return this.validateModeFeature(e,e=>hn(e,this.coordinatePrecision))}onLeftClick(e){let t=this.mutateFeature.createPoint({coordinates:[e.lng,e.lat],properties:{mode:this.mode},context:{updateType:k.Finish,action:O}});t&&this.onFinish(t.id,{mode:this.mode,action:O})}onRightClick(e){if(!this.editable)return;let t=this.pointSearch.getNearestPointFeature(e);t&&this.mutateFeature.deleteFeatureIfPresent(t.id)}afterFeatureUpdated(e){this.editedFeatureId===e.id&&(this.editedFeatureId=void 0,this.setCursor(this.cursors.create))}},yn={cancel:`Escape`,finish:`Enter`},bn={start:`crosshair`,close:`pointer`,dragStart:`grabbing`,dragEnd:`crosshair`},xn=class extends N{constructor(e){super(e,!0),this.mode=`polygon`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=yn,this.cursors=bn,this.mouseMove=!1,this.showCoordinatePoints=!1,this.lastMouseMoveEvent=void 0,this.snapping=void 0,this.snappedPointId=void 0,this.editable=!1,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0,this.editedInsertIndex=void 0,this.editedPointId=void 0,this.coordinatePoints=void 0,this.lineSnapping=void 0,this.coordinateSnapping=void 0,this.pixelDistance=void 0,this.closingPoints=void 0,this.clickBoundingBox=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.undoRedo=void 0,this.updateOptions(e)}updateOptions(e){if(super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.snapping&&(this.snapping=e.snapping),e?.editable!==void 0&&(this.editable=e.editable),e?.pointerEvents!==void 0&&(this.pointerEvents=e.pointerEvents),e?.showCoordinatePoints!==void 0){if(this.showCoordinatePoints=e.showCoordinatePoints,this.coordinatePoints&&!0===e.showCoordinatePoints)this.store.copyAllWhere(e=>e.mode===this.mode).filter(e=>e.geometry.type===`Polygon`).forEach(e=>{this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})});else if(this.coordinatePoints&&!1===this.showCoordinatePoints){let e=this.store.copyAllWhere(e=>e.mode===this.mode&&!!e[j.COORDINATE_POINT_IDS]).filter(e=>e.geometry.type===`Polygon`);this.coordinatePoints.deletePointsByFeatureIds(e.map(e=>e.id))}}}close(){if(this.currentId===void 0||this.readFeature.getCoordinates(this.currentId).length<5)return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:Ot,index:-2}],propertyMutations:{[j.CURRENTLY_DRAWING]:void 0,[j.COMMITTED_COORDINATE_COUNT]:void 0,[j.PROVISIONAL_COORDINATE_COUNT]:void 0},context:{updateType:k.Finish,action:O}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.state===`drawing`&&this.setStarted(),this.editedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),void 0),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.closingPoints.delete();let t=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.undoRedo.clear(),this.onFinish(t,{mode:this.mode,action:O})}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate}),this.clickBoundingBox=new Lt(e),this.pixelDistance=new Rt(e),this.lineSnapping=new tn(e,this.pixelDistance,this.clickBoundingBox),this.coordinateSnapping=new zt(e,this.pixelDistance,this.clickBoundingBox),this.closingPoints=new on(e,this.pixelDistance,this.mutateFeature,this.readFeature),this.coordinatePoints=new sn(e,this.readFeature,this.mutateFeature),this.undoRedo=new cn({maxStackSize:e.undoRedoMaxStackSize})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}updateSnappedCoordinate(e){let t=this.snapCoordinate(e);t?(this.snappedPointId?this.mutateFeature.updateGuidancePoints([{featureId:this.snappedPointId,coordinate:t}]):this.snappedPointId=this.mutateFeature.createGuidancePoint({coordinate:t,type:j.SNAPPING_POINT}),e.lng=t[0],e.lat=t[1]):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0)}undoSize(){return this.undoRedo.undoSize()}clearHistory(){this.undoRedo.clear()}pushHistorySnapshot(e,t){let n=this.readFeature.getGeometry(e);this.undoRedo.recordSnapshot({featureCoordinates:n.coordinates,currentCoordinate:t})}updateSnappedGuidancePointFromLastMouseMove(){this.snapping&&this.lastMouseMoveEvent?this.updateSnappedCoordinate(this.lastMouseMoveEvent):this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0)}syncClosingPoints(e){this.currentCoordinate>=3?this.closingPoints.ids.length?this.closingPoints.update(e):this.closingPoints.create(e):this.closingPoints.delete()}undo(){if(this.state!==`drawing`||!this.currentId)return;let e=this.undoRedo.beginUndo();if(!e)return;let{previousEntry:t}=e;if(!t){let e=this.currentId;this.currentId=void 0,this.currentCoordinate=0,this.closingPoints.delete(),this.state===`drawing`&&this.setStarted(),this.showCoordinatePoints&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.updateSnappedGuidancePointFromLastMouseMove();return}let n=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:{type:H,coordinates:t.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:t.currentCoordinate,[j.PROVISIONAL_COORDINATE_COUNT]:t.currentCoordinate},context:{updateType:k.Commit}});n&&(this.currentCoordinate=t.currentCoordinate,this.syncClosingPoints(n.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:n.geometry.coordinates}),this.updateSnappedGuidancePointFromLastMouseMove())}redoSize(){return this.undoRedo.redoSize()}redo(){let e=this.undoRedo.takeRedo();if(e){if(this.currentId){let t=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:{type:H,coordinates:e.featureCoordinates},propertyMutations:{[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:e.currentCoordinate,[j.PROVISIONAL_COORDINATE_COUNT]:e.currentCoordinate},context:{updateType:k.Commit}});if(!t)return;this.currentCoordinate=e.currentCoordinate,this.syncClosingPoints(t.geometry.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:t.geometry.coordinates})}else{let t=this.undoRedo.cloneCoordinates(e.featureCoordinates)[0],{id:n,geometry:r}=this.mutateFeature.createPolygon({coordinates:t,properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:e.currentCoordinate,[j.PROVISIONAL_COORDINATE_COUNT]:e.currentCoordinate}});this.currentId=n,this.currentCoordinate=e.currentCoordinate,this.state===`started`&&this.setDrawing(),this.syncClosingPoints(r.coordinates),this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:n,featureCoordinates:r.coordinates})}this.undoRedo.commitRedo(e),this.updateSnappedGuidancePointFromLastMouseMove()}}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.lastMouseMoveEvent=e,this.updateSnappedCoordinate(e),this.currentId===void 0||this.currentCoordinate===0)return;let t=this.readFeature.getCoordinate(this.currentId,0),n=[e.lng,e.lat],r;if(this.currentCoordinate===1)r=[{type:V,index:1,coordinate:n},{type:V,index:2,coordinate:[e.lng,e.lat]}];else if(this.currentCoordinate===2)r=[{type:V,index:2,coordinate:n}];else{let{isClosing:i,isPreviousClosing:a}=this.closingPoints.isPolygonClosingPoints(e);a||i?(this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.setCursor(this.cursors.close),r=[{type:V,index:-1,coordinate:t},{type:V,index:-2,coordinate:t}]):r=[{type:V,index:-2,coordinate:n},{type:V,index:-1,coordinate:t}]}let i=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:r,propertyMutations:{[j.PROVISIONAL_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Provisional}});i&&this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:i.geometry.coordinates})}snapCoordinate(e){var t,n,r;let i;if((t=this.snapping)!=null&&t.toLine){let t;t=this.currentId?this.lineSnapping.getSnappableCoordinate(e,this.currentId):this.lineSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((n=this.snapping)!=null&&n.toCoordinate){let t;t=this.currentId?this.coordinateSnapping.getSnappableCoordinate(e,this.currentId):this.coordinateSnapping.getSnappableCoordinateFirstClick(e),t&&(i=t)}if((r=this.snapping)!=null&&r.toCustom){let t=this.snapping.toCustom(e,{currentCoordinate:this.currentCoordinate,currentId:this.currentId,getCurrentGeometrySnapshot:this.currentId?()=>this.readFeature.getGeometry(this.currentId):()=>null,project:this.project,unproject:this.unproject});t&&(i=t)}return i}polygonFilter(e){return!!(e.geometry.type===`Polygon`&&e.properties&&e.properties.mode===this.mode)}onRightClick(e){if(!this.editable||this.state!==`started`)return;let{featureId:t,featureCoordinateIndex:n}=this.coordinateSnapping.getSnappable(e,e=>this.polygonFilter(e));if(!t||n===void 0)return;let r=this.readFeature.getGeometry(t);if(r.type!==`Polygon`)return;let i=r.coordinates[0];if(i.length<=4)return;let a;a=n===0||n===i.length-1?[{type:Ot,index:0},{type:Ot,index:-1},{type:B,index:-1,coordinate:i[1]}]:[{type:Ot,index:n}];let o=this.mutateFeature.updatePolygon({featureId:t,coordinateMutations:a,context:{updateType:k.Finish,action:Xe}});if(o){if(this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:t,featureCoordinates:o.geometry.coordinates}),this.snappedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),this.snappedPointId=void 0,this.snapping)){let t=this.snapCoordinate(e);if(t){let[e]=this.mutateFeature.createGuidancePoints({type:j.SNAPPING_POINT,coordinates:[t]});this.snappedPointId=e}}this.onFinish(t,{mode:this.mode,action:Xe})}}onLeftClick(e){this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0);let t=this.snapCoordinate(e)||[e.lng,e.lat];if(this.currentCoordinate===0){let{id:e,geometry:n}=this.mutateFeature.createPolygon({coordinates:[t,t,t,t],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0,[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1,[j.PROVISIONAL_COORDINATE_COUNT]:this.currentCoordinate+1}});this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e,featureCoordinates:n.coordinates}),this.currentId=e,this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.setDrawing()}else if(this.currentCoordinate===1&&this.currentId){if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,newCoordinate:t,index:0}))return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:1,coordinate:t},{type:V,index:2,coordinate:t}],propertyMutations:{[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Commit}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate)}else if(this.currentCoordinate===2&&this.currentId){if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,newCoordinate:t,index:1}))return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:2,coordinate:t},{type:B,index:2,coordinate:t}],propertyMutations:{[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Commit}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.currentCoordinate===2&&this.closingPoints.create(e.geometry.coordinates),this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate)}else if(this.currentId){let{isClosing:n,isPreviousClosing:r}=this.closingPoints.isPolygonClosingPoints(e);if(r||n)this.close();else{if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,newCoordinate:t,index:this.currentCoordinate-1}))return;let e=this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:Dt,index:-1,coordinate:t}],propertyMutations:{[j.COMMITTED_COORDINATE_COUNT]:this.currentCoordinate+1},context:{updateType:k.Commit}});if(!e)return;this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:this.currentId,featureCoordinates:e.geometry.coordinates}),this.currentCoordinate++,this.pushHistorySnapshot(this.currentId,this.currentCoordinate),this.closingPoints.ids.length&&this.closingPoints.update(e.geometry.coordinates)}}}onClick(e){this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onKeyDown(){}onDragStart(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragStart,e)||!this.editable)return;let n;if(this.state===`started`){let t=this.lineSnapping.getSnappable(e,e=>this.polygonFilter(e));t.coordinate&&(this.editedSnapType=`line`,this.editedFeatureCoordinateIndex=t.featureCoordinateIndex,this.editedFeatureId=t.featureId,n=t.coordinate);let r=this.coordinateSnapping.getSnappable(e,e=>this.polygonFilter(e));r.coordinate&&(this.editedSnapType=`coordinate`,this.editedFeatureCoordinateIndex=r.featureCoordinateIndex,this.editedFeatureId=r.featureId,n=r.coordinate)}this.editedFeatureId&&n&&(this.editedPointId||=this.mutateFeature.createGuidancePoint({coordinate:n,type:j.EDITED}),this.setCursor(this.cursors.dragStart),t(!1))}onDrag(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDrag,e)||this.editedFeatureId===void 0||this.editedFeatureCoordinateIndex===void 0)return;let n=this.readFeature.getGeometry(this.editedFeatureId),r=[e.lng,e.lat],i=[];if(this.editedSnapType===`coordinate`||this.editedSnapType===`line`&&this.editedInsertIndex!==void 0?i=this.editedFeatureCoordinateIndex===0||this.editedFeatureCoordinateIndex===n.coordinates[0].length-1?[{type:V,index:0,coordinate:r},{type:V,index:-1,coordinate:r}]:[{type:V,index:this.editedFeatureCoordinateIndex,coordinate:r}]:this.editedSnapType===`line`&&this.editedInsertIndex===void 0&&(this.editedInsertIndex=this.editedFeatureCoordinateIndex+1,i=[{type:Dt,index:this.editedInsertIndex,coordinate:r}],this.editedFeatureCoordinateIndex++),i.length===0)return;let a=this.mutateFeature.updatePolygon({featureId:this.editedFeatureId,coordinateMutations:i,propertyMutations:{[j.EDITED]:!0},context:{updateType:k.Provisional}});a&&(this.showCoordinatePoints&&(this.editedInsertIndex?this.coordinatePoints.createOrUpdate({featureId:this.editedFeatureId,featureCoordinates:a.geometry.coordinates}):this.coordinatePoints.updateOneAtIndex(this.editedFeatureId,this.editedFeatureCoordinateIndex,a.geometry.coordinates[0][this.editedFeatureCoordinateIndex])),this.snapping&&this.snappedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),this.snappedPointId=void 0),this.editedPointId&&this.mutateFeature.updateGuidancePoints([{featureId:this.editedPointId,coordinate:r}]))}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||(this.setCursor(this.cursors.dragEnd),!this.mutateFeature.updatePolygon({featureId:this.editedFeatureId,propertyMutations:{[j.EDITED]:!1},context:{updateType:k.Finish,action:Xe}})))return;let n=this.editedFeatureId;this.editedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),void 0),this.snappedPointId&&=(this.mutateFeature.deleteFeatureIfPresent(this.snappedPointId),void 0),this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0,t(!0),this.onFinish(n,{mode:this.mode,action:Xe})}cleanUp(){let e=this.currentId,t=this.snappedPointId,n=this.editedPointId;this.currentId=void 0,this.snappedPointId=void 0,this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedInsertIndex=void 0,this.editedSnapType=void 0,this.currentCoordinate=0,this.undoRedo.clear(),this.state===`drawing`&&this.setStarted(),e&&this.coordinatePoints.deletePointsByFeatureIds([e]),this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(n),this.mutateFeature.deleteFeatureIfPresent(t),this.closingPoints.ids.length&&this.closingPoints.delete()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.properties.mode===this.mode){if(e.geometry.type===`Polygon`)return t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.zIndex=M,t;if(e.geometry.type===`Point`){let n=e.properties[j.EDITED],r=e.properties[j.COORDINATE_POINT],i=n?`editedPoint`:e.properties[j.CLOSING_POINT]?`closingPoint`:e.properties[j.SNAPPING_POINT]?`snappingPoint`:r?`coordinatePoint`:void 0;if(!i)return t;let a={editedPoint:{width:this.styles.editedPointOutlineWidth,color:this.styles.editedPointColor,opacity:this.styles.editedPointOpacity,outlineColor:this.styles.editedPointOutlineColor,outlineWidth:this.styles.editedPointOutlineWidth,outlineOpacity:this.styles.editedPointOutlineOpacity},closingPoint:{width:this.styles.closingPointWidth,color:this.styles.closingPointColor,opacity:this.styles.closingPointOpacity,outlineColor:this.styles.closingPointOutlineColor,outlineWidth:this.styles.closingPointOutlineWidth,outlineOpacity:this.styles.closingPointOutlineOpacity},snappingPoint:{width:this.styles.snappingPointWidth,color:this.styles.snappingPointColor,opacity:this.styles.snappingPointOpacity,outlineColor:this.styles.snappingPointOutlineColor,outlineWidth:this.styles.snappingPointOutlineWidth,outlineOpacity:this.styles.snappingPointOutlineOpacity},coordinatePoint:{width:this.styles.coordinatePointWidth,color:this.styles.coordinatePointColor,opacity:this.styles.coordinatePointOpacity,outlineColor:this.styles.coordinatePointOutlineColor,outlineWidth:this.styles.coordinatePointOutlineWidth,outlineOpacity:this.styles.coordinatePointOutlineOpacity}};return t.pointWidth=this.getNumericStylingValue(a[i].width,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(a[i].opacity,1,e),t.pointColor=this.getHexColorStylingValue(a[i].color,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(a[i].outlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(a[i].outlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(a[i].outlineWidth,2,e),t.zIndex=n?40:r?20:30,t}}return t}afterFeatureAdded(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates})}afterFeatureUpdated(e){this.showCoordinatePoints&&this.coordinatePoints.createOrUpdate({featureId:e.id,featureCoordinates:e.geometry.coordinates}),this.editedFeatureId===e.id&&this.editedPointId&&(this.mutateFeature.deleteFeatureIfPresent(this.editedPointId),this.editedPointId=void 0,this.editedFeatureId=void 0,this.editedFeatureCoordinateIndex=void 0,this.editedSnapType=void 0),this.snappedPointId&&this.lastMouseMoveEvent&&this.updateSnappedCoordinate(this.lastMouseMoveEvent),this.currentId===e.id&&(this.currentCoordinate=0,this.currentId=void 0,this.undoRedo.clear(),this.closingPoints.delete(),this.state===`drawing`&&this.setStarted())}validateFeature(e){return this.validateModeFeature(e,e=>wt(e,this.coordinatePrecision))}},Sn={cancel:`Escape`,finish:`Enter`},Cn={start:`crosshair`},wn=class extends N{constructor(e){super(e,!0),this.mode=`rectangle`,this.startPosition=void 0,this.endPosition=void 0,this.currentRectangleId=void 0,this.keyEvents=Sn,this.cursors=Cn,this.drawInteraction=`click-move`,this.drawType=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.drawInteraction&&(this.drawInteraction=e.drawInteraction)}updateRectangle(e,t){if(!this.startPosition||!this.currentRectangleId)return;let n=t===k.Finish;return this.mutateFeature.updatePolygon({featureId:this.currentRectangleId,coordinateMutations:[{type:V,index:1,coordinate:[e[0],this.startPosition[1]]},{type:V,index:2,coordinate:e},{type:V,index:3,coordinate:[this.startPosition[0],e[1]]}],propertyMutations:n?{[j.CURRENTLY_DRAWING]:void 0}:{},context:n?{updateType:t,action:O}:{updateType:t}})}close(){if(!this.currentRectangleId||!this.endPosition||!this.updateRectangle(this.endPosition,k.Finish))return;let e=this.currentRectangleId;this.startPosition=void 0,this.currentRectangleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}beginDrawing(e,t=`click`){this.startPosition=[e.lng,e.lat],this.endPosition=[e.lng,e.lat],this.currentRectangleId=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}}).id,this.drawType=t,this.setDrawing()}moveDrawAllowed(){return this.drawInteraction===`click-move`||this.drawInteraction===`click-move-or-drag`}dragDrawAllowed(){return this.drawInteraction===`click-drag`||this.drawInteraction===`click-move-or-drag`}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){this.moveDrawAllowed()&&(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))&&(this.startPosition?(this.endPosition=[e.lng,e.lat],this.close()):this.beginDrawing(e))}onMouseMove(e){this.endPosition=[e.lng,e.lat],this.updateRectangle(this.endPosition,k.Provisional)}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onDragStart(e,t){this.state!==`drawing`&&this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&this.dragDrawAllowed()&&(this.beginDrawing(e,`drag`),t(!1))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.endPosition=[e.lng,e.lat],this.updateRectangle(this.endPosition,k.Provisional))}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&this.dragDrawAllowed()&&this.drawType===`drag`&&(this.endPosition=[e.lng,e.lat],this.close(),t(!0))}cleanUp(){let e=this.currentRectangleId;this.startPosition=void 0,this.currentRectangleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Polygon`&&e.properties.mode===this.mode?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t):t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentRectangleId===e.id&&(this.startPosition=void 0,this.currentRectangleId=void 0,this.drawType=void 0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}},q=class extends N{constructor(e){if(!e.modeName)throw Error(`Mode name is required for TerraDrawRenderMode`);super(e,!0),this.type=it.Render,this.mode=`render`,this.updateOptions(e)}updateOptions(e){super.updateOptions(e)}registerBehaviors(e){this.mode=e.mode}start(){this.setStarted()}stop(){this.setStopped()}onKeyUp(){}onKeyDown(){}onClick(){}onDragStart(){}onDrag(){}onDragEnd(){}onMouseMove(){}cleanUp(){}styleFeature(e){return{pointColor:this.getHexColorStylingValue(this.styles.pointColor,`#3f97e0`,e),pointWidth:this.getNumericStylingValue(this.styles.pointWidth,6,e),pointOpacity:this.getNumericStylingValue(this.styles.pointOpacity,1,e),pointOutlineColor:this.getHexColorStylingValue(this.styles.pointOutlineColor,`#ffffff`,e),pointOutlineWidth:this.getNumericStylingValue(this.styles.pointOutlineWidth,0,e),pointOutlineOpacity:this.getNumericStylingValue(this.styles.pointOutlineOpacity,1,e),polygonFillColor:this.getHexColorStylingValue(this.styles.polygonFillColor,`#3f97e0`,e),polygonFillOpacity:this.getNumericStylingValue(this.styles.polygonFillOpacity,.3,e),polygonOutlineColor:this.getHexColorStylingValue(this.styles.polygonOutlineColor,`#3f97e0`,e),polygonOutlineWidth:this.getNumericStylingValue(this.styles.polygonOutlineWidth,4,e),lineStringWidth:this.getNumericStylingValue(this.styles.lineStringWidth,4,e),lineStringColor:this.getHexColorStylingValue(this.styles.lineStringColor,`#3f97e0`,e),lineStringOpacity:this.getNumericStylingValue(this.styles.lineStringOpacity,1,e),zIndex:this.getNumericStylingValue(this.styles.zIndex,0,e)}}validateFeature(e){let t=super.validateFeature(e);if(t.valid){let t=e,n=hn(t,this.coordinatePrecision).valid||wt(t,this.coordinatePrecision).valid||Jt(t,this.coordinatePrecision).valid;return n?{valid:!0}:{valid:n,reason:`Feature is not a valid Point, Polygon or LineString feature`}}return t}};function Tn(e,t){let n=e,r=t,i=F(n[1]),a=F(r[1]),o=F(r[0]-n[0]);o>Math.PI&&(o-=2*Math.PI),o<-Math.PI&&(o+=2*Math.PI);let s=Math.log(Math.tan(a/2+Math.PI/4)/Math.tan(i/2+Math.PI/4)),c=(lt(Math.atan2(o,s))+360)%360;return c>180?-(360-c):c}function En(e,t,n){let r=t;t<0&&(r=-Math.abs(r));let i=r/st,a=e[0]*Math.PI/180,o=F(e[1]),s=F(n),c=i*Math.cos(s),l=o+c;Math.abs(l)>Math.PI/2&&(l=l>0?Math.PI-l:-Math.PI-l);let u=Math.log(Math.tan(l/2+Math.PI/4)/Math.tan(o/2+Math.PI/4)),d=Math.abs(u)>1e-11?c/u:Math.cos(o),f=[(180*(a+i*Math.sin(s)/d)/Math.PI+540)%360-180,180*l/Math.PI];return f[0]+=f[0]-e[0]>180?-360:e[0]-f[0]>180?360:0,f}function Dn(e,t,n,r,i){let a=r(e[0],e[1]),o=r(t[0],t[1]),{lng:s,lat:c}=i((a.x+o.x)/2,(a.y+o.y)/2);return[I(s,n),I(c,n)]}function On(e,t,n){let r=En(e,1e3*P(e,t)/2,Tn(e,t));return[I(r[0],n),I(r[1],n)]}function kn({featureCoords:e,precision:t,unproject:n,project:r,projection:i}){let a=[];for(let o=0;o<e.length-1;o++){let s;if(i===`web-mercator`)s=Dn(e[o],e[o+1],t,r,n);else{if(i!==`globe`)throw Error(`Invalid projection`);s=On(e[o],e[o+1],t)}a.push(s)}return a}var An=class extends z{constructor(e,t,n,r,i,a){super(e),this.config=void 0,this.selectionPointBehavior=void 0,this.coordinatePointBehavior=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.pixelDistance=void 0,this._midPoints=[],this.config=e,this.selectionPointBehavior=t,this.coordinatePointBehavior=n,this.mutateFeature=r,this.readFeature=i,this.pixelDistance=a}getMidpointConfig(e){return{featureCoords:e,precision:this.coordinatePrecision,project:this.config.project,unproject:this.config.unproject,projection:this.config.projection}}get ids(){return this._midPoints.concat()}set ids(e){}getNearestMidPoint(e){let t,n=1/0;return this.ids.forEach(r=>{let i=this.readFeature.getGeometry(r),a=this.pixelDistance.measure(e,i.coordinates);a<this.pointerDistance&&a<n&&(n=a,t=r)}),t}insert({featureId:e,midPointId:t}){let n=this.readFeature.getGeometry(t),{midPointFeatureId:r,midPointSegment:i}=this.readFeature.getProperties(t),a=this.readFeature.getGeometry(r),o={featureId:r,coordinateMutations:[{type:B,index:i,coordinate:n.coordinates}],context:{updateType:k.Commit}},s=null;if(a.type===`Polygon`)s=this.mutateFeature.updatePolygon(o);else{if(a.type!==`LineString`)throw Error(`Midpoints can only be added to polygons or linestrings`);s=this.mutateFeature.updateLineString(o)}if(!s)throw Error(`Failed to insert midpoint coordinate`);let c=s.geometry.coordinates;this.readFeature.getProperties(e)[j.COORDINATE_POINT_IDS]&&this.coordinatePointBehavior.createOrUpdate({featureId:e,featureCoordinates:c}),this.mutateFeature.deleteFeaturesIfPresent([...this.selectionPointBehavior.ids,...this._midPoints]),this.create({featureCoordinates:c,featureId:r}),this.selectionPointBehavior.create({featureCoordinates:c,featureId:e})}create({featureCoordinates:e,featureId:t}){if(!this.readFeature.hasFeature(t))throw Error(`Store does not have feature with this id`);let n=an(e),r=kn(this.getMidpointConfig(n));this._midPoints=this.mutateFeature.createGuidancePoints({additionalProperties:e=>({mode:this.mode,midPointSegment:e,midPointFeatureId:t,[A.MID_POINT]:!0}),coordinates:r,type:A.MID_POINT})}delete(){this._midPoints.length&&(this.mutateFeature.deleteFeaturesIfPresent(this._midPoints),this._midPoints=[])}updateAllInPlace({featureCoordinates:e}){if(this._midPoints.length===0)return;let t=an(e),n=kn(this.getMidpointConfig(t));this.mutateFeature.updateGuidancePoints(this._midPoints.map((e,t)=>({featureId:e,coordinate:n[t]})))}updateOneAtIndex(e,t){if(e<0&&(e=this._midPoints.length+e),this._midPoints[e]===void 0)return;let n=an(t),r=kn(this.getMidpointConfig(n));this.mutateFeature.updateGuidancePoints([{featureId:this._midPoints[e],coordinate:r[e]}])}},jn=class extends z{constructor(e,t){super(e),this.mutateFeature=void 0,this._selectionPoints=[],this.mutateFeature=t}get ids(){return this._selectionPoints.concat()}set ids(e){}create({featureId:e,featureCoordinates:t}){let n=rn(t);this._selectionPoints=this.mutateFeature.createGuidancePoints({coordinates:n,type:A.SELECTION_POINT,additionalProperties:t=>({[A.SELECTION_POINT_FEATURE_ID]:e,index:t})})}delete(){this.ids.length&&(this.mutateFeature.deleteFeaturesIfPresent(this.ids),this._selectionPoints=[])}updateAllInPlace({featureCoordinates:e}){if(this._selectionPoints.length===0)return;let t=rn(e);t.length===this._selectionPoints.length&&this.mutateFeature.updateGuidancePoints(this._selectionPoints.map((e,n)=>({featureId:e,coordinate:t[n]})))}updateOneAtIndex(e,t){this._selectionPoints[e]!==void 0&&this.mutateFeature.updateGuidancePoints([{featureId:this._selectionPoints[e],coordinate:t}])}};function Mn(e,t){let n=!1;for(let o=0,s=t.length;o<s;o++){let s=t[o];for(let t=0,o=s.length,c=o-1;t<o;c=t++)(i=s[t])[1]>(r=e)[1]!=(a=s[c])[1]>r[1]&&r[0]<(a[0]-i[0])*(r[1]-i[1])/(a[1]-i[1])+i[0]&&(n=!n)}var r,i,a;return n}var Nn=(e,t,n)=>{let r=e=>e*e,i=(e,t)=>r(e.x-t.x)+r(e.y-t.y);return Math.sqrt(((e,t,n)=>{let r=i(t,n);if(r===0)return i(e,t);let a=((e.x-t.x)*(n.x-t.x)+(e.y-t.y)*(n.y-t.y))/r;return a=Math.max(0,Math.min(1,a)),i(e,{x:t.x+a*(n.x-t.x),y:t.y+a*(n.y-t.y)})})(e,t,n))},Pn=class extends z{constructor(e,t,n){super(e),this.config=void 0,this.createClickBoundingBox=void 0,this.pixelDistance=void 0,this.config=e,this.createClickBoundingBox=t,this.pixelDistance=n}find(e,t){let n,r,i,a=1/0,o=1/0,s=this.createClickBoundingBox.create(e),c=this.store.search(s);for(let s=0;s<c.length;s++){let l=c[s],u=l.geometry;if(u.type===`Point`){if(l.properties.selectionPoint||l.properties.coordinatePoint||!t&&l.properties[A.MID_POINT])continue;let r=this.pixelDistance.measure(e,u.coordinates);!l.properties[A.MID_POINT]&&r<this.pointerDistance&&r<a&&(a=r,n=l)}else if(u.type===`LineString`){if(n)continue;for(let t=0;t<u.coordinates.length-1;t++){let n=u.coordinates[t],i=u.coordinates[t+1],a=Nn({x:e.containerX,y:e.containerY},this.project(n[0],n[1]),this.project(i[0],i[1]));a<this.pointerDistance&&a<o&&(o=a,r=l)}}else if(u.type===`Polygon`){if(n||r)continue;Mn([e.lng,e.lat],u.coordinates)&&(i=l)}}return{clickedFeature:n||r||i}}},Fn=class extends z{constructor(e,t,n,r,i,a,o){super(e),this.config=void 0,this.featuresAtCursorEvent=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.draggedFeatureId=null,this.dragPosition=void 0,this.config=e,this.featuresAtCursorEvent=t,this.selectionPoints=n,this.midPoints=r,this.coordinatePoints=i,this.readFeature=a,this.mutateFeature=o}startDragging(e,t){this.draggedFeatureId=t,this.dragPosition=[e.lng,e.lat]}stopDragging(){this.draggedFeatureId=null,this.dragPosition=void 0}isDragging(){return this.draggedFeatureId!==null}canDrag(e,t){let{clickedFeature:n}=this.featuresAtCursorEvent.find(e,!0);return!(!n||n.id!==t)}drag(e){if(!this.draggedFeatureId)return;let t=this.readFeature.getGeometry(this.draggedFeatureId),n=[e.lng,e.lat];if(t.type===`Polygon`||t.type===`LineString`){let r,i;if(t.type===`Polygon`?(r=t.coordinates[0],i=r.length-1):(r=t.coordinates,i=r.length),!this.dragPosition)return!1;for(let e=0;e<i;e++){let t=r[e],i,a;if(this.config.projection===`web-mercator`){let e=L(this.dragPosition[0],this.dragPosition[1]),r=L(n[0],n[1]),o=L(t[0],t[1]),s={x:e.x-r.x,y:e.y-r.y},{lng:c,lat:l}=R(o.x-s.x,o.y-s.y);i=c,a=l}else{let e=[this.dragPosition[0]-n[0],this.dragPosition[1]-n[1]];i=t[0]-e[0],a=t[1]-e[1]}if(i=I(i,this.config.coordinatePrecision),a=I(a,this.config.coordinatePrecision),i>180||i<-180||a>90||a<-90)return!1;r[e]=[i,a]}t.type===`Polygon`&&(r[r.length-1]=[r[0][0],r[0][1]]);let a=this.draggedFeatureId,o=null;if(t.type===`Polygon`)o=this.mutateFeature.updatePolygon({featureId:a,coordinateMutations:{type:H,coordinates:[r]},context:{updateType:k.Provisional}});else{if(t.type!==`LineString`)return;o=this.mutateFeature.updateLineString({featureId:a,coordinateMutations:{type:H,coordinates:r},context:{updateType:k.Provisional}})}if(!o)return!1;let s=o.geometry.coordinates;this.midPoints.updateAllInPlace({featureCoordinates:s}),this.selectionPoints.updateAllInPlace({featureCoordinates:s}),this.coordinatePoints.updateAllInPlace({featureId:a,featureCoordinates:s}),this.dragPosition=[e.lng,e.lat]}else t.type===`Point`&&(this.mutateFeature.updatePoint({featureId:this.draggedFeatureId,coordinateMutations:{type:H,coordinates:n},context:{updateType:k.Provisional}}),this.dragPosition=[e.lng,e.lat])}},In=class extends z{constructor(e,t,n,r,i,a,o,s,c){super(e),this.config=void 0,this.pixelDistance=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.coordinateSnapping=void 0,this.lineSnapping=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.draggedCoordinate={id:null,index:-1},this.config=e,this.pixelDistance=t,this.selectionPoints=n,this.midPoints=r,this.coordinatePoints=i,this.coordinateSnapping=a,this.lineSnapping=o,this.readFeature=s,this.mutateFeature=c}getClosestCoordinate(e,t){let n={dist:1/0,index:-1,isFirstOrLastPolygonCoord:!1},r;if(t.type===`LineString`)r=t.coordinates;else{if(t.type!==`Polygon`)return n;r=t.coordinates[0]}for(let i=0;i<r.length;i++){let a=this.pixelDistance.measure(e,r[i]);if(a<this.pointerDistance&&a<n.dist){let e=t.type===`Polygon`&&(i===r.length-1||i===0);n.dist=a,n.index=e?0:i,n.isFirstOrLastPolygonCoord=e}}return n}getDraggable(e,t){let n=this.readFeature.getGeometry(t);return this.getClosestCoordinate(e,n)}getDraggableIndex(e,t){let n=this.readFeature.getGeometry(t),r=this.getClosestCoordinate(e,n);return r.index===-1?-1:r.index}snapCoordinate(e,t,n){let r=[e.lng,e.lat],i=e=>!!(e.properties&&e.properties.mode===n.properties.mode&&e.id!==this.draggedCoordinate.id);if(t!=null&&t.toLine){let t;t=this.lineSnapping.getSnappable(e,i).coordinate,t&&(r=t)}if(t.toCoordinate){let t;t=this.coordinateSnapping.getSnappable(e,i).coordinate,t&&(r=t)}if(t!=null&&t.toCustom){let i;i=t.toCustom(e,{currentCoordinate:this.draggedCoordinate.index,currentId:n.id,getCurrentGeometrySnapshot:n.id?()=>this.readFeature.getGeometry(n.id):()=>null,project:this.project,unproject:this.unproject}),i&&(r=i)}return r}drag(e,t,n){let r=this.draggedCoordinate.id;if(r===null)return!1;let i=this.draggedCoordinate.index,a=this.readFeature.getGeometry(r),o=this.readFeature.getProperties(r),s=a.type===`LineString`?a.coordinates:a.coordinates[0],c=a.type===`Polygon`&&(i===s.length-1||i===0),l=this.snapCoordinate(e,n,{type:`Feature`,id:r,geometry:a,properties:o});if(e.lng>180||e.lng<-180||e.lat>90||e.lat<-90)return!1;if(c){let e=s.length-1;s[0]=l,s[e]=l}else s[i]=l;if(a.type!==`Point`&&!t&&ht({type:`Feature`,geometry:a,properties:{}}))return!1;let u=r,d=null;return a.type===`Polygon`?d=this.mutateFeature.updatePolygon({featureId:u,coordinateMutations:{type:H,coordinates:[s]},context:{updateType:k.Provisional}}):a.type===`LineString`&&(d=this.mutateFeature.updateLineString({featureId:u,coordinateMutations:{type:H,coordinates:s},context:{updateType:k.Provisional}})),!!d&&(this.midPoints.updateOneAtIndex(i>0?i-1:-1,s),this.midPoints.updateOneAtIndex(i,s),this.selectionPoints.updateOneAtIndex(i,l),this.coordinatePoints.updateOneAtIndex(u,i,l),!0)}isDragging(){return this.draggedCoordinate.id!==null}startDragging(e,t){this.draggedCoordinate={id:e,index:t}}stopDragging(){this.draggedCoordinate={id:null,index:-1}}};function Ln(e){let t=0,n=0,r=0;return(e.geometry.type===`Polygon`?e.geometry.coordinates[0].slice(0,-1):e.geometry.coordinates).forEach(e=>{t+=e[0],n+=e[1],r++},!0),[t/r,n/r]}var Rn=(e,t)=>{if(t===0||t===360||t===-360)return e;let n=.017453292519943295*t,r=(e.geometry.type===`Polygon`?e.geometry.coordinates[0]:e.geometry.coordinates).map(([e,t])=>L(e,t)),i=r.reduce((e,t)=>({x:e.x+t.x,y:e.y+t.y}),{x:0,y:0});i.x/=r.length,i.y/=r.length;let a=r.map(e=>({x:i.x+(e.x-i.x)*Math.cos(n)-(e.y-i.y)*Math.sin(n),y:i.y+(e.x-i.x)*Math.sin(n)+(e.y-i.y)*Math.cos(n)})).map(({x:e,y:t})=>[R(e,t).lng,R(e,t).lat]);return e.geometry.type===`Polygon`?e.geometry.coordinates[0]=a:e.geometry.coordinates=a,e};function zn(e){let t=(e.geometry.type===`Polygon`?e.geometry.coordinates[0]:e.geometry.coordinates).map(e=>{let{x:t,y:n}=L(e[0],e[1]);return[t,n]});return e.geometry.type===`Polygon`?function(e){let t=0,n=0,r=0,i=e.length;for(let a=0;a<i-1;a++){let[i,o]=e[a],[s,c]=e[a+1],l=i*c-s*o;t+=l,n+=(i+s)*l,r+=(o+c)*l}return t/=2,n/=6*t,r/=6*t,{x:n,y:r}}(t):function(e){let t=e.length,n=0,r=0;for(let i=0;i<t;i++){let[t,a]=e[i];n+=t,r+=a}return{x:n/t,y:r/t}}(t)}var Bn=class extends z{constructor(e,t,n,r,i,a){super(e),this.config=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.lastBearing=void 0,this.selectedGeometry=void 0,this.selectedGeometryCentroid=void 0,this.selectedGeometryWebMercatorCentroid=void 0,this.config=e,this.selectionPoints=t,this.midPoints=n,this.coordinatePoints=r,this.readFeature=i,this.mutateFeature=a}reset(){this.lastBearing=void 0,this.selectedGeometry=void 0,this.selectedGeometryWebMercatorCentroid=void 0,this.selectedGeometryCentroid=void 0}rotate(e,t){this.selectedGeometry||=this.readFeature.getGeometry(t);let n=this.selectedGeometry;if(n.type!==`Polygon`&&n.type!==`LineString`)return;let r=[e.lng,e.lat],i,a={type:`Feature`,geometry:n,properties:{}};if(this.config.projection===`web-mercator`){this.selectedGeometryWebMercatorCentroid||=zn(a);let t=L(e.lng,e.lat);if(i=K(this.selectedGeometryWebMercatorCentroid,t),i===0)return;if(!this.lastBearing)return void(this.lastBearing=i);Rn(a,-(this.lastBearing-i))}else{if(this.config.projection!==`globe`)throw Error(`Unsupported projection`);if(this.selectedGeometryCentroid||=Ln({type:`Feature`,geometry:n,properties:{}}),i=Tn(this.selectedGeometryCentroid,r),!this.lastBearing)return void(this.lastBearing=i+180);(function(e,t){if(t===0||t===360||t===-360)return e;let n=Ln(e);(e.geometry.type===`Polygon`?e.geometry.coordinates[0]:e.geometry.coordinates).forEach(e=>{let r=Tn(n,e)+t,i=En(n,function(e,t){e[0]+=e[0]-t[0]>180?-360:t[0]-e[0]>180?360:0;let n=st,r=t[1]*Math.PI/180,i=e[1]*Math.PI/180,a=i-r,o=Math.abs(e[0]-t[0])*Math.PI/180;o>Math.PI&&(o-=2*Math.PI);let s=Math.log(Math.tan(i/2+Math.PI/4)/Math.tan(r/2+Math.PI/4)),c=Math.abs(s)>1e-11?a/s:Math.cos(r);return Math.sqrt(a*a+c*c*o*o)*n}(n,e),r);e[0]=i[0],e[1]=i[1]})})(a,-(this.lastBearing-(i+180)))}let o=n.type===`Polygon`?n.coordinates[0]:n.coordinates;o.forEach(e=>{e[0]=I(e[0],this.coordinatePrecision),e[1]=I(e[1],this.coordinatePrecision)});let s={featureId:t,coordinateMutations:{type:H,coordinates:n.type===`Polygon`?[o]:o},context:{updateType:k.Provisional}},c=null;if(a.geometry.type===`Polygon`)c=this.mutateFeature.updatePolygon(s);else{if(a.geometry.type!==`LineString`)return;c=this.mutateFeature.updateLineString(s)}if(!c)return!1;let l=c.geometry.coordinates;this.midPoints.updateAllInPlace({featureCoordinates:l}),this.selectionPoints.updateAllInPlace({featureCoordinates:l}),this.coordinatePoints.updateAllInPlace({featureId:t,featureCoordinates:l}),this.projection===`web-mercator`?this.lastBearing=i:this.projection===`globe`&&(this.lastBearing=i+180)}},Vn=class extends z{constructor(e,t){super(e),this.config=void 0,this.dragCoordinateResizeBehavior=void 0,this.config=e,this.dragCoordinateResizeBehavior=t}scale(e,t){if(!this.dragCoordinateResizeBehavior.isDragging()){let n=this.dragCoordinateResizeBehavior.getDraggableIndex(e,t);this.dragCoordinateResizeBehavior.startDragging(t,n)}this.dragCoordinateResizeBehavior.drag(e,`center-fixed`)}reset(){this.dragCoordinateResizeBehavior.stopDragging()}};function Hn({coordinates:e,originX:t,originY:n,xScale:r,yScale:i}){r===1&&i===1||e.forEach(e=>{let{x:a,y:o}=L(e[0],e[1]),{lng:s,lat:c}=R(t+(a-t)*r,n+(o-n)*i);e[0]=s,e[1]=c})}var Un=class extends z{constructor(e,t,n,r,i,a,o){super(e),this.config=void 0,this.pixelDistance=void 0,this.selectionPoints=void 0,this.midPoints=void 0,this.coordinatePoints=void 0,this.readFeature=void 0,this.mutateFeature=void 0,this.minimumScale=1e-4,this.draggedCoordinate={id:null,index:-1},this.boundingBoxMaps={opposite:{0:4,1:5,2:6,3:7,4:0,5:1,6:2,7:3}},this.config=e,this.pixelDistance=t,this.selectionPoints=n,this.midPoints=r,this.coordinatePoints=i,this.readFeature=a,this.mutateFeature=o}getClosestCoordinate(e,t){let n={dist:1/0,index:-1,isFirstOrLastPolygonCoord:!1},r;if(t.type===`LineString`)r=t.coordinates;else{if(t.type!==`Polygon`)return n;r=t.coordinates[0]}for(let i=0;i<r.length;i++){let a=this.pixelDistance.measure(e,r[i]);if(a<this.pointerDistance&&a<n.dist){let e=t.type===`Polygon`&&(i===r.length-1||i===0);n.dist=a,n.index=e?0:i,n.isFirstOrLastPolygonCoord=e}}return n}isValidDragWebMercator(e,t,n){switch(e){case 0:if(t<=0||n>=0)return!1;break;case 1:if(n>=0)return!1;break;case 2:if(t>=0||n>=0)return!1;break;case 3:if(t>=0)return!1;break;case 4:if(t>=0||n<=0)return!1;break;case 5:if(n<=0)return!1;break;case 6:if(t<=0||n<=0)return!1;break;case 7:if(t<=0)return!1}return!0}getSelectedFeatureDataWebMercator(){if(!this.draggedCoordinate.id||this.draggedCoordinate.index===-1)return null;let e=this.getFeature(this.draggedCoordinate.id);if(!e)return null;let t=this.getNormalisedCoordinates(e.geometry);return{boundingBox:this.getBBoxWebMercator(t),feature:e,updatedCoords:t,selectedCoordinate:t[this.draggedCoordinate.index]}}centerWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{feature:n,boundingBox:r,updatedCoords:i,selectedCoordinate:a}=t,o=zn(n);if(!o)return null;let s=L(a[0],a[1]),{closestBBoxIndex:c}=this.getIndexesWebMercator(r,s),l=L(e.lng,e.lat);return this.scaleWebMercator({closestBBoxIndex:c,updatedCoords:i,webMercatorCursor:l,webMercatorSelected:s,webMercatorOrigin:o}),i}centerFixedWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{feature:n,boundingBox:r,updatedCoords:i,selectedCoordinate:a}=t,o=zn(n);if(!o)return null;let s=L(a[0],a[1]),{closestBBoxIndex:c}=this.getIndexesWebMercator(r,s),l=L(e.lng,e.lat);return this.scaleFixedWebMercator({closestBBoxIndex:c,updatedCoords:i,webMercatorCursor:l,webMercatorSelected:s,webMercatorOrigin:o}),i}scaleFixedWebMercator({closestBBoxIndex:e,webMercatorOrigin:t,webMercatorSelected:n,webMercatorCursor:r,updatedCoords:i}){if(!this.isValidDragWebMercator(e,t.x-r.x,t.y-r.y))return null;let a=W(t,r)/W(t,n);return a<0&&(a=this.minimumScale),Hn({coordinates:i,originX:t.x,originY:t.y,xScale:a,yScale:a}),i}oppositeFixedWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{boundingBox:n,updatedCoords:r,selectedCoordinate:i}=t,a=L(i[0],i[1]),{oppositeBboxIndex:o,closestBBoxIndex:s}=this.getIndexesWebMercator(n,a),c={x:n[o][0],y:n[o][1]},l=L(e.lng,e.lat);return this.scaleFixedWebMercator({closestBBoxIndex:s,updatedCoords:r,webMercatorCursor:l,webMercatorSelected:a,webMercatorOrigin:c}),r}oppositeWebMercatorDrag(e){let t=this.getSelectedFeatureDataWebMercator();if(!t)return null;let{boundingBox:n,updatedCoords:r,selectedCoordinate:i}=t,a=L(i[0],i[1]),{oppositeBboxIndex:o,closestBBoxIndex:s}=this.getIndexesWebMercator(n,a),c={x:n[o][0],y:n[o][1]},l=L(e.lng,e.lat);return this.scaleWebMercator({closestBBoxIndex:s,updatedCoords:r,webMercatorCursor:l,webMercatorSelected:a,webMercatorOrigin:c}),r}scaleWebMercator({closestBBoxIndex:e,webMercatorOrigin:t,webMercatorSelected:n,webMercatorCursor:r,updatedCoords:i}){let a=t.x-r.x,o=t.y-r.y;if(!this.isValidDragWebMercator(e,a,o))return null;let s=1;a!==0&&e!==1&&e!==5&&(s=1-(t.x-n.x-a)/a);let c=1;return o!==0&&e!==3&&e!==7&&(c=1-(t.y-n.y-o)/o),this.validateScale(s,c)?(s<0&&(s=this.minimumScale),c<0&&(c=this.minimumScale),this.performWebMercatorScale(i,t.x,t.y,s,c),i):null}getFeature(e){if(this.draggedCoordinate.id===null)return null;let t=this.readFeature.getGeometry(e);return t.type!==`Polygon`&&t.type!==`LineString`?null:{id:e,type:`Feature`,geometry:t,properties:{}}}getNormalisedCoordinates(e){return e.type===`Polygon`?e.coordinates[0]:e.coordinates}validateScale(e,t){return!isNaN(e)&&t<2**53-1&&!isNaN(t)&&t<2**53-1}performWebMercatorScale(e,t,n,r,i){e.forEach(e=>{let{x:a,y:o}=L(e[0],e[1]),{lng:s,lat:c}=R(t+(a-t)*r,n+(o-n)*i);e[0]=s,e[1]=c})}getBBoxWebMercator(e){let t=[1/0,1/0,-1/0,-1/0];(e=e.map(e=>{let{x:t,y:n}=L(e[0],e[1]);return[t,n]})).forEach(([e,n])=>{e<t[0]&&(t[0]=e),n<t[1]&&(t[1]=n),e>t[2]&&(t[2]=e),n>t[3]&&(t[3]=n)});let[n,r,i,a]=t;return[[n,a],[(n+i)/2,a],[i,a],[i,a+(r-a)/2],[i,r],[(n+i)/2,r],[n,r],[n,a+(r-a)/2]]}getIndexesWebMercator(e,t){let n,r=1/0;for(let i=0;i<e.length;i++){let a=W({x:t.x,y:t.y},{x:e[i][0],y:e[i][1]});a<r&&(n=i,r=a)}if(n===void 0)throw Error(`No closest coordinate found`);return{oppositeBboxIndex:this.boundingBoxMaps.opposite[n],closestBBoxIndex:n}}isDragging(){return this.draggedCoordinate.id!==null}startDragging(e,t){this.draggedCoordinate={id:e,index:t}}stopDragging(){this.draggedCoordinate={id:null,index:-1}}getDraggableIndex(e,t){let n=this.readFeature.getGeometry(t),r=this.getClosestCoordinate(e,n);return r.index===-1?-1:r.index}drag(e,t){if(!this.draggedCoordinate.id)return!1;let n=this.getFeature(this.draggedCoordinate.id);if(!n)return!1;let r=null;if(t===`center`?r=this.centerWebMercatorDrag(e):t===`opposite`?r=this.oppositeWebMercatorDrag(e):t===`center-fixed`?r=this.centerFixedWebMercatorDrag(e):t===`opposite-fixed`&&(r=this.oppositeFixedWebMercatorDrag(e)),!r)return!1;for(let e=0;e<r.length;e++){let t=r[e];if(t[0]=I(t[0],this.coordinatePrecision),t[1]=I(t[1],this.coordinatePrecision),!_t(t,this.coordinatePrecision))return!1}let i=n.id,a=null;if(n.geometry.type===`Polygon`?a=this.mutateFeature.updatePolygon({featureId:i,coordinateMutations:{type:H,coordinates:[r]},context:{updateType:k.Provisional}}):n.geometry.type===`LineString`&&(a=this.mutateFeature.updateLineString({featureId:i,coordinateMutations:{type:H,coordinates:r},context:{updateType:k.Provisional}})),!a)return!1;let o=a.geometry.coordinates;return this.midPoints.updateAllInPlace({featureCoordinates:o}),this.selectionPoints.updateAllInPlace({featureCoordinates:o}),this.coordinatePoints.updateAllInPlace({featureId:i,featureCoordinates:o}),!0}},Wn={deselect:`Escape`,delete:`Delete`,rotate:[`Control`,`r`],scale:[`Control`,`s`]},Gn={pointerOver:`move`,dragStart:`move`,dragEnd:`move`,insertMidpoint:`crosshair`},Kn=class extends ot{constructor(e){super(e,!0),this.mode=`select`,this.allowManualDeselection=!0,this.allowManualSelection=!0,this.dragEventThrottle=5,this.dragEventCount=0,this.selected=[],this.flags={},this.keyEvents=Wn,this.cursors=Gn,this.validations={},this.dragTarget={type:`none`},this.selectionPoints=void 0,this.midPoints=void 0,this.coordinateSnap=void 0,this.featuresAtMouseEvent=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.dragFeature=void 0,this.dragCoordinate=void 0,this.rotateFeature=void 0,this.scaleFeature=void 0,this.dragCoordinateResizeFeature=void 0,this.coordinatePoints=void 0,this.lineSnap=void 0,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){if(super.updateOptions(e),this.cursors=e&&e.cursors?D({},this.cursors,e.cursors):Gn,e?.keyEvents===null?this.keyEvents={deselect:null,delete:null,rotate:null,scale:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e?.dragEventThrottle!==void 0&&(this.dragEventThrottle=e.dragEventThrottle),e?.allowManualDeselection!==void 0&&(this.allowManualDeselection=e.allowManualDeselection),e?.allowManualSelection!==void 0&&(this.allowManualSelection=e.allowManualSelection),e!=null&&e.flags){this.flags=D({},this.flags,e.flags),this.validations={};for(let e in this.flags){let t=this.flags[e].feature;t&&t.validation&&(this.validations[e]=t.validation)}}}selectFeature(e){this.select(e,!1)}setSelecting(){if(this._state!==`started`)throw Error(`Mode must be started to move to selecting state`);this._state=`selecting`}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:(e,t)=>{let n=e.properties.mode;return this.validations&&this.validations[n]?this.validations[n](e,t):{valid:!0}}}),this.pixelDistance=new Rt(e),this.clickBoundingBox=new Lt(e),this.featuresAtMouseEvent=new Pn(e,this.clickBoundingBox,this.pixelDistance),this.selectionPoints=new jn(e,this.mutateFeature),this.coordinatePoints=new sn(e,this.readFeature,this.mutateFeature),this.midPoints=new An(e,this.selectionPoints,this.coordinatePoints,this.mutateFeature,this.readFeature,this.pixelDistance),this.coordinateSnap=new zt(e,this.pixelDistance,this.clickBoundingBox),this.lineSnap=new tn(e,this.pixelDistance,this.clickBoundingBox),this.rotateFeature=new Bn(e,this.selectionPoints,this.midPoints,this.coordinatePoints,this.readFeature,this.mutateFeature),this.dragFeature=new Fn(e,this.featuresAtMouseEvent,this.selectionPoints,this.midPoints,this.coordinatePoints,this.readFeature,this.mutateFeature),this.dragCoordinate=new In(e,this.pixelDistance,this.selectionPoints,this.midPoints,this.coordinatePoints,this.coordinateSnap,this.lineSnap,this.readFeature,this.mutateFeature),this.dragCoordinateResizeFeature=new Un(e,this.pixelDistance,this.selectionPoints,this.midPoints,this.coordinatePoints,this.readFeature,this.mutateFeature),this.scaleFeature=new Vn(e,this.dragCoordinateResizeFeature)}deselectFeature(e){this.deselect(e)}deselect(e){this.selected.includes(e)&&(this.mutateFeature.setDeselected(this.selected),this.onDeselect(this.selected[0]),this.selected=[],this.selectionPoints.delete(),this.midPoints.delete(),this.dragTarget={type:`none`})}deleteSelected(){this.selected.length&&this.mutateFeature.deleteFeaturesIfPresent(this.selected),this.selected=[],this.dragTarget={type:`none`}}clearDragTargetAndCursor(){this.dragTarget={type:`none`},this.setCursor(`unset`)}getSelectedFlags(e){let t=this.readFeature.getProperties(e),n=this.flags[t.mode]?.feature,r=n?.coordinates;return{featureFlags:n,coordinatesFlags:r,hasDraggableFlags:n&&(n.draggable||r?.draggable||r?.resizable||typeof r?.midpoints==`object`&&r.midpoints.draggable)}}onRightClick(e){if(!this.selectionPoints.ids.length)return;let t,n=1/0;if(this.selectionPoints.ids.forEach(r=>{let i=this.readFeature.getGeometry(r),a=this.pixelDistance.measure(e,i.coordinates);a<this.pointerDistance&&a<n&&(n=a,t=this.readFeature.getProperties(r))}),!t)return;let r=t.selectionPointFeatureId,i=t.index,a=this.readFeature.getProperties(r),o=this.flags[a.mode];if(!(o&&o.feature&&o.feature.coordinates&&o.feature.coordinates.deletable))return;let s=this.readFeature.getGeometry(r),c;if(s.type===`Polygon`){if(c=s.coordinates[0],c.length<=4)return}else if(s.type!==`LineString`||(c=s.coordinates,c.length<=2))return;s.type!==`Polygon`||i!==0&&i!==c.length-1?c.splice(i,1):(c.shift(),c.pop(),c.push([c[0][0],c[0][1]]));let l=null;if(s.type===`Polygon`?l=this.mutateFeature.updatePolygon({featureId:r,coordinateMutations:{type:H,coordinates:[c]},context:{updateType:k.Commit}}):s.type===`LineString`&&(l=this.mutateFeature.updateLineString({featureId:r,coordinateMutations:{type:H,coordinates:c},context:{updateType:k.Commit}})),!l)return;let u=l.geometry.coordinates;this.mutateFeature.deleteFeaturesIfPresent([...this.midPoints.ids,...this.selectionPoints.ids]),a.coordinatePointIds&&this.coordinatePoints.createOrUpdate({featureId:r,featureCoordinates:u}),this.selectionPoints.create({featureCoordinates:u,featureId:r}),o&&o.feature&&o.feature.coordinates&&o.feature.coordinates.midpoints&&this.midPoints.create({featureCoordinates:u,featureId:r}),this.onFinish(r,{action:Ze,mode:this.mode})}select(e,t=!0){if(this.selected[0]===e)return;let{mode:n}=this.readFeature.getProperties(e),r=this.flags[n];if(!r||!r.feature)return;let i=this.selected[0];if(i){if(i===e)return;this.deselect(i)}t&&this.setCursor(this.cursors.pointerOver),this.selected=[e],this.mutateFeature.setSelected(e),this.onSelect(e);let{type:a,coordinates:o}=this.readFeature.getGeometry(e);a!==`LineString`&&a!==`Polygon`||o&&r&&r.feature.coordinates&&(this.selectionPoints.create({featureCoordinates:o,featureId:e}),r.feature.coordinates.midpoints&&this.midPoints.create({featureCoordinates:o,featureId:e}))}onLeftClick(e){let{clickedFeature:t}=this.featuresAtMouseEvent.find(e,this.selected.length>0),n=this.midPoints.getNearestMidPoint(e),r=this.selected[0];if(r){var i;let{featureFlags:t}=this.getSelectedFlags(r);if(t!=null&&(i=t.coordinates)!=null&&i.midpoints&&n){if(t.coordinates.draggable){let t=this.pixelDistance.measure(e,this.readFeature.getGeometry(n).coordinates),{dist:i}=this.dragCoordinate.getDraggable(e,r);if(i!==void 0&&t>i)return}this.midPoints.insert({featureId:r,midPointId:n}),this.onFinish(this.selected[0],{action:Qe,mode:this.mode});return}}if(t!=null&&t.id)this.allowManualSelection&&this.select(t.id,!0);else if(this.selected.length&&this.allowManualDeselection)return void this.deselect(this.selected[0])}start(){this.setStarted(),this.setSelecting()}stop(){this.cleanUp(),this.setStarted(),this.setStopped()}onClick(e){e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}canScale(e){return this.keyEvents.scale&&this.keyEvents.scale.every(t=>e.heldKeys.includes(t))}canRotate(e){return this.keyEvents.rotate&&this.keyEvents.rotate.every(t=>e.heldKeys.includes(t))}preventDefaultKeyEvent(e){let t=this.canRotate(e),n=this.canScale(e);(t||n)&&e.preventDefault()}onKeyDown(e){this.preventDefaultKeyEvent(e)}onKeyUp(e){if(this.preventDefaultKeyEvent(e),this.keyEvents.delete&&e.key===this.keyEvents.delete){if(!this.selected.length)return;let e=this.selected[0];this.onDeselect(this.selected[0]),this.coordinatePoints.deletePointsByFeatureIds([e]),this.deleteSelected(),this.selectionPoints.delete(),this.midPoints.delete()}else this.keyEvents.deselect&&e.key===this.keyEvents.deselect&&this.cleanUp()}cleanUp(){this.selected.length&&this.deselect(this.selected[0])}onDragStart(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragStart,e))return;let n=this.selected[0];if(!n)return;let{featureFlags:r,coordinatesFlags:i,hasDraggableFlags:a}=this.getSelectedFlags(n);if(!a)return;this.dragEventCount=0;let o=this.dragTarget.type!==`none`&&this.dragTarget.featureId===n?this.dragTarget:{type:`none`},s=o.type===`coordinate`?o.coordinateIndex:this.dragCoordinate.getDraggableIndex(e,n),c=o.type===`resize`?o.coordinateIndex:this.dragCoordinateResizeFeature.getDraggableIndex(e,n),l=i?.resizable&&c!==-1,u=i?.draggable&&s!==-1,d=i&&typeof i.midpoints==`object`&&i.midpoints.draggable,f=r?.draggable&&(o.type===`feature`||this.dragFeature.canDrag(e,n));if(l)return this.setCursor(this.cursors.dragStart),this.dragCoordinateResizeFeature.startDragging(n,c),void t(!1);if(u)return this.setCursor(this.cursors.dragStart),this.dragCoordinate.startDragging(n,s),void t(!1);if(d){let r=o.type===`midpoint`?o.midPointId:this.midPoints.getNearestMidPoint(e);if(this.selected.length&&r){this.midPoints.insert({featureId:n,midPointId:r}),this.onFinish(this.selected[0],{action:Qe,mode:this.mode});let i=this.dragCoordinate.getDraggableIndex(e,n);this.dragCoordinate.startDragging(n,i),t(!1);return}}if(f)return this.setCursor(this.cursors.dragStart),this.dragFeature.startDragging(e,n),void t(!1);this.setCursor(`unset`)}onDrag(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDrag,e))return;let n=this.selected[0];if(!n)return;let r=this.readFeature.getProperties(n),i=this.flags[r.mode],a=!0===(i&&i.feature&&i.feature.selfIntersectable);if(this.dragEventCount++,this.dragEventCount%this.dragEventThrottle!=0){if(i&&i.feature&&i.feature.rotateable&&this.canRotate(e))return t(!1),void this.rotateFeature.rotate(e,n);if(i&&i.feature&&i.feature.scaleable&&this.canScale(e))return t(!1),void this.scaleFeature.scale(e,n);if(this.dragCoordinateResizeFeature.isDragging()&&i.feature&&i.feature.coordinates&&i.feature.coordinates.resizable){if(this.projection===`globe`)throw Error(`Globe is currently unsupported projection for resizable`);t(!1),this.dragCoordinateResizeFeature.drag(e,i.feature.coordinates.resizable);return}if(this.dragCoordinate.isDragging()){var o;let t=(o=i.feature)==null||(o=o.coordinates)==null?void 0:o.snappable,n={toCoordinate:!1};!0===t?n={toCoordinate:!0}:typeof t==`object`&&(n=t),this.dragCoordinate.drag(e,a,n);return}this.dragFeature.isDragging()?this.dragFeature.drag(e):t(!0)}}onDragEnd(e,t){this.allowPointerEvent(this.pointerEvents.onDragEnd,e)&&(this.setCursor(this.cursors.dragEnd),this.dragCoordinate.isDragging()?this.onFinish(this.selected[0],{mode:this.mode,action:`dragCoordinate`}):this.dragFeature.isDragging()?this.onFinish(this.selected[0],{mode:this.mode,action:`dragFeature`}):this.dragCoordinateResizeFeature.isDragging()&&this.onFinish(this.selected[0],{mode:this.mode,action:`dragCoordinateResize`}),this.dragCoordinate.stopDragging(),this.dragFeature.stopDragging(),this.dragCoordinateResizeFeature.stopDragging(),this.rotateFeature.reset(),this.scaleFeature.reset(),t(!0))}onMouseMove(e){let t=this.selected[0];if(!t)return void this.clearDragTargetAndCursor();if(this.dragFeature.isDragging()||this.dragCoordinate.isDragging()||this.dragCoordinateResizeFeature.isDragging())return;let{featureFlags:n}=this.getSelectedFlags(t);if(!n)return void this.clearDragTargetAndCursor();let r,i=n.coordinates;if(i!=null&&i.midpoints&&(r=this.midPoints.getNearestMidPoint(e),r&&(this.dragTarget={type:`midpoint`,featureId:t,midPointId:r},this.setCursor(this.cursors.insertMidpoint))),i&&i.draggable){let{index:n,dist:i}=this.dragCoordinate.getDraggable(e,t);if(n>-1){if(r&&this.pixelDistance.measure(e,this.readFeature.getGeometry(r).coordinates)<i)return;this.dragTarget={type:`coordinate`,featureId:t,coordinateIndex:n},this.setCursor(this.cursors.pointerOver);return}}if(i&&i.resizable){let n=this.dragCoordinateResizeFeature.getDraggableIndex(e,t);if(n>-1)return this.dragTarget={type:`resize`,featureId:t,coordinateIndex:n},void this.setCursor(this.cursors.pointerOver)}if(n.draggable&&this.dragFeature.canDrag(e,t)){if(r)return;this.dragTarget={type:`feature`,featureId:t},this.setCursor(this.cursors.pointerOver);return}r||this.clearDragTargetAndCursor()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});if(e.properties.mode===this.mode&&e.geometry.type===`Point`){if(e.properties[A.SELECTION_POINT])return t.pointColor=this.getHexColorStylingValue(this.styles.selectionPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.selectionPointOpacity,1,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.selectionPointOutlineColor,t.pointOutlineColor,e),t.pointWidth=this.getNumericStylingValue(this.styles.selectionPointWidth,t.pointWidth,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.selectionPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.selectionPointOutlineWidth,2,e),t.zIndex=30,t;if(e.properties[A.MID_POINT])return t.pointColor=this.getHexColorStylingValue(this.styles.midPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.midPointOpacity,1,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.midPointOutlineColor,t.pointOutlineColor,e),t.pointWidth=this.getNumericStylingValue(this.styles.midPointWidth,4,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.midPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.midPointOutlineWidth,2,e),t.zIndex=50,t}else if(e.properties[A.SELECTED]){if(e.geometry.type===`Point`&&e.properties[j.MARKER])return t.markerUrl=this.getUrlStylingValue(this.styles.selectedMarkerUrl,$e,e),t.markerHeight=this.getNumericStylingValue(this.styles.selectedMarkerHeight,40,e),t.markerWidth=this.getNumericStylingValue(this.styles.selectedMarkerWidth,32,e),t;if(e.geometry.type===`Polygon`)return t.polygonFillColor=this.getHexColorStylingValue(this.styles.selectedPolygonColor,t.polygonFillColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.selectedPolygonOutlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.selectedPolygonOutlineColor,t.polygonOutlineColor,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.selectedPolygonOutlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.selectedPolygonFillOpacity,t.polygonFillOpacity,e),t.zIndex=M,t;if(e.geometry.type===`LineString`)return t.lineStringColor=this.getHexColorStylingValue(this.styles.selectedLineStringColor,t.lineStringColor,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.selectedLineStringWidth,t.lineStringWidth,e),t.zIndex=M,t;if(e.geometry.type===`Point`)return t.pointWidth=this.getNumericStylingValue(this.styles.selectedPointWidth,t.pointWidth,e),t.pointColor=this.getHexColorStylingValue(this.styles.selectedPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.selectedPointOpacity,1,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.selectedPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.selectedPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.selectedPointOutlineWidth,t.pointOutlineWidth,e),t.zIndex=M,t}return t}afterFeatureUpdated(e){if(this.selected.length&&e.id===this.selected[0]){var t,n;let r=this.flags[e.properties.mode];if(r==null||(t=r.feature)==null||!t.coordinates)return;let i=e.geometry.type,a=e.id;if(this.selectionPoints.delete(),this.midPoints.delete(),i!==`LineString`&&i!==`Polygon`)return;let o=e.geometry.coordinates;this.selectionPoints.create({featureCoordinates:o,featureId:a}),r!=null&&(n=r.feature)!=null&&(n=n.coordinates)!=null&&n.midpoints&&this.midPoints.create({featureCoordinates:o,featureId:a})}}},qn=class extends N{constructor(...e){super(...e),this.type=it.Static,this.mode=`static`}start(){}stop(){}onKeyUp(){}onKeyDown(){}onClick(){}onDragStart(){}onDrag(){}onDragEnd(){}onMouseMove(){}cleanUp(){}styleFeature(){return D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0})}};function Jn(e,t,n,r,i){for(;r>n;){if(r-n>600){let a=r-n+1,o=t-n+1,s=Math.log(a),c=.5*Math.exp(2*s/3),l=.5*Math.sqrt(s*c*(a-c)/a)*(o-a/2<0?-1:1);Jn(e,t,Math.max(n,Math.floor(t-o*c/a+l)),Math.min(r,Math.floor(t+(a-o)*c/a+l)),i)}let a=e[t],o=n,s=r;for(Yn(e,n,t),i(e[r],a)>0&&Yn(e,n,r);o<s;){for(Yn(e,o,s),o++,s--;i(e[o],a)<0;)o++;for(;i(e[s],a)>0;)s--}i(e[n],a)===0?Yn(e,n,s):(s++,Yn(e,s,r)),s<=t&&(n=s+1),t<=s&&(r=s-1)}}function Yn(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function Xn(e,t){Zn(e,0,e.children.length,t,e)}function Zn(e,t,n,r,i){i||=or([]),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(let a=t;a<n;a++){let t=e.children[a];Qn(i,e.leaf?r(t):t)}return i}function Qn(e,t){return e.minX=Math.min(e.minX,t.minX),e.minY=Math.min(e.minY,t.minY),e.maxX=Math.max(e.maxX,t.maxX),e.maxY=Math.max(e.maxY,t.maxY),e}function $n(e,t){return e.minX-t.minX}function er(e,t){return e.minY-t.minY}function tr(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function nr(e){return e.maxX-e.minX+(e.maxY-e.minY)}function rr(e,t){let n=Math.max(e.minX,t.minX),r=Math.max(e.minY,t.minY),i=Math.min(e.maxX,t.maxX),a=Math.min(e.maxY,t.maxY);return Math.max(0,i-n)*Math.max(0,a-r)}function ir(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function ar(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function or(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function sr(e,t,n,r,i){let a=[t,n];for(;a.length;){if((n=a.pop())-(t=a.pop())<=r)continue;let o=t+Math.ceil((n-t)/r/2)*r;Jn(e,o,t,n,i),a.push(t,o,o,n)}}var cr=class{constructor(e){this._maxEntries=void 0,this._minEntries=void 0,this.data=void 0,this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()}search(e){let t=this.data,n=[];if(!ar(e,t))return n;let r=this.toBBox,i=[];for(;t;){for(let a=0;a<t.children.length;a++){let o=t.children[a],s=t.leaf?r(o):o;ar(e,s)&&(t.leaf?n.push(o):ir(e,s)?this._all(o,n):i.push(o))}t=i.pop()}return n}collides(e){let t=this.data;if(ar(e,t)){let n=[];for(;t;){for(let r=0;r<t.children.length;r++){let i=t.children[r],a=t.leaf?this.toBBox(i):i;if(ar(e,a)){if(t.leaf||ir(e,a))return!0;n.push(i)}}t=n.pop()}}return!1}load(e){if(e.length<this._minEntries){for(let t=0;t<e.length;t++)this.insert(e[t]);return}let t=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===t.height)this._splitRoot(this.data,t);else{if(this.data.height<t.height){let e=this.data;this.data=t,t=e}this._insert(t,this.data.height-t.height-1,!0)}else this.data=t}insert(e){this._insert(e,this.data.height-1)}clear(){this.data=or([])}remove(e){let t=this.data,n=this.toBBox(e),r=[],i=[],a,o,s=!1;for(;t||r.length;){if(t||(t=r.pop(),o=r[r.length-1],a=i.pop(),s=!0),t.leaf){let n=t.children.indexOf(e);n!==-1&&(t.children.splice(n,1),r.push(t),this._condense(r))}s||t.leaf||!ir(t,n)?o?(a++,t=o.children[a],s=!1):t=null:(r.push(t),i.push(a),a=0,o=t,t=t.children[0])}}toBBox(e){return e}compareMinX(e,t){return e.minX-t.minX}compareMinY(e,t){return e.minY-t.minY}_all(e,t){let n=[];for(;e;)e.leaf?t.push(...e.children):n.push(...e.children),e=n.pop();return t}_build(e,t,n,r){let i=n-t+1,a,o=this._maxEntries;if(i<=o)return a=or(e.slice(t,n+1)),Xn(a,this.toBBox),a;r||(r=Math.ceil(Math.log(i)/Math.log(o)),o=Math.ceil(i/o**(r-1))),a=or([]),a.leaf=!1,a.height=r;let s=Math.ceil(i/o),c=s*Math.ceil(Math.sqrt(o));sr(e,t,n,c,this.compareMinX);for(let i=t;i<=n;i+=c){let t=Math.min(i+c-1,n);sr(e,i,t,s,this.compareMinY);for(let n=i;n<=t;n+=s){let i=Math.min(n+s-1,t);a.children.push(this._build(e,n,i,r-1))}}return Xn(a,this.toBBox),a}_chooseSubtree(e,t,n,r){for(;r.push(t),!t.leaf&&r.length-1!==n;){let n,r=1/0,o=1/0;for(let s=0;s<t.children.length;s++){let c=t.children[s],l=tr(c),u=(i=e,a=c,(Math.max(a.maxX,i.maxX)-Math.min(a.minX,i.minX))*(Math.max(a.maxY,i.maxY)-Math.min(a.minY,i.minY))-l);u<o?(o=u,r=l<r?l:r,n=c):u===o&&l<r&&(r=l,n=c)}t=n||t.children[0]}var i,a;return t}_insert(e,t,n){let r=n?e:this.toBBox(e),i=[],a=this._chooseSubtree(r,this.data,t,i);for(a.children.push(e),Qn(a,r);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(r,i,t)}_split(e,t){let n=e[t],r=n.children.length,i=this._minEntries;this._chooseSplitAxis(n,i,r);let a=this._chooseSplitIndex(n,i,r),o=or(n.children.splice(a,n.children.length-a));o.height=n.height,o.leaf=n.leaf,Xn(n,this.toBBox),Xn(o,this.toBBox),t?e[t-1].children.push(o):this._splitRoot(n,o)}_splitRoot(e,t){this.data=or([e,t]),this.data.height=e.height+1,this.data.leaf=!1,Xn(this.data,this.toBBox)}_chooseSplitIndex(e,t,n){let r,i=1/0,a=1/0;for(let o=t;o<=n-t;o++){let t=Zn(e,0,o,this.toBBox),s=Zn(e,o,n,this.toBBox),c=rr(t,s),l=tr(t)+tr(s);c<i?(i=c,r=o,a=l<a?l:a):c===i&&l<a&&(a=l,r=o)}return r||n-t}_chooseSplitAxis(e,t,n){let r=e.leaf?this.compareMinX:$n,i=e.leaf?this.compareMinY:er;this._allDistMargin(e,t,n,r)<this._allDistMargin(e,t,n,i)&&e.children.sort(r)}_allDistMargin(e,t,n,r){e.children.sort(r);let i=this.toBBox,a=Zn(e,0,t,i),o=Zn(e,n-t,n,i),s=nr(a)+nr(o);for(let r=t;r<n-t;r++){let t=e.children[r];Qn(a,e.leaf?i(t):t),s+=nr(a)}for(let r=n-t-1;r>=t;r--){let t=e.children[r];Qn(o,e.leaf?i(t):t),s+=nr(o)}return s}_adjustParentBBoxes(e,t,n){for(let r=n;r>=0;r--)Qn(t[r],e)}_condense(e){for(let t,n=e.length-1;n>=0;n--)e[n].children.length===0?n>0?(t=e[n-1].children,t.splice(t.indexOf(e[n]),1)):this.clear():Xn(e[n],this.toBBox)}},lr=class{constructor(e){this.tree=void 0,this.idToNode=void 0,this.nodeToId=void 0,this.tree=new cr(e&&e.maxEntries?e.maxEntries:9),this.idToNode=new Map,this.nodeToId=new Map}setMaps(e,t){this.idToNode.set(e.id,t),this.nodeToId.set(t,e.id)}toBBox(e){let t=[],n=[],r;if(e.geometry.type===`Polygon`)r=e.geometry.coordinates[0];else if(e.geometry.type===`LineString`)r=e.geometry.coordinates;else{if(e.geometry.type!==`Point`)throw Error(`Not a valid feature to turn into a bounding box`);r=[e.geometry.coordinates]}for(let e=0;e<r.length;e++)n.push(r[e][1]),t.push(r[e][0]);let i=Math.min(...n),a=Math.max(...n);return{minX:Math.min(...t),minY:i,maxX:Math.max(...t),maxY:a}}insert(e){if(this.idToNode.get(String(e.id)))throw Error(`Feature already exists`);let t=this.toBBox(e);this.setMaps(e,t),this.tree.insert(t)}load(e){let t=[],n=new Set;e.forEach(e=>{let r=this.toBBox(e);if(this.setMaps(e,r),n.has(String(e.id)))throw Error(`Duplicate feature ID found ${e.id}`);n.add(String(e.id)),t.push(r)}),this.tree.load(t)}update(e){this.remove(e.id);let t=this.toBBox(e);this.setMaps(e,t),this.tree.insert(t)}remove(e){let t=this.idToNode.get(e);if(!t)throw Error(`${e} not inserted into the spatial index`);this.tree.remove(t)}clear(){this.tree.clear()}search(e){return this.tree.search(this.toBBox(e)).map(e=>this.nodeToId.get(e))}collides(e){return this.tree.collides(this.toBBox(e))}},ur={getId:()=>`xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx`.replace(/[xy]/g,function(e){let t=16*Math.random()|0;return(e==`x`?t:3&t|8).toString(16)}),isValidId:e=>typeof e==`string`&&e.length===36},dr={target:`geometry`},fr={target:`properties`},pr=class{constructor(e){this.idStrategy=void 0,this.tracked=void 0,this.spatialIndex=void 0,this.store=void 0,this._onChange=()=>{},this.store={},this.spatialIndex=new lr,this.tracked=!e||!1!==e.tracked,this.idStrategy=e&&e.idStrategy?e.idStrategy:ur}clone(e){return JSON.parse(JSON.stringify(e))}getId(){return this.idStrategy.getId()}has(e){return!!this.store[e]}load(e,t,n,r){if(e.length===0)return[];let i=this.clone(e),a=[],o=[];i=i.filter(e=>{e.id??=this.idStrategy.getId();let n=e.id;if(t){let r=t(e);if(!r.valid)return a.push({id:n,valid:!1,reason:r.reason}),!1}if(this.tracked){if(e.properties.createdAt){if(!nt(e.properties.createdAt))return a.push({id:e.id,valid:!1,reason:`createdAt is not a valid numeric timestamp`}),!1}else e.properties.createdAt=+new Date;if(e.properties.updatedAt){if(!nt(e.properties.updatedAt))return a.push({id:e.id,valid:!1,reason:`updatedAt is not a valid numeric timestamp`}),!1}else e.properties.updatedAt=+new Date}return this.has(n)?(a.push({id:n,valid:!1,reason:`Feature already exists with this id: ${n}`}),!1):(this.store[n]=e,o.push(e),a.push({id:n,valid:!0}),!0)}),this.spatialIndex.load(i);let s=o.map(({id:e})=>e);return s.length>0&&(this._onChange(s,`create`,r),n&&o.forEach(e=>{n(e)})),a}search(e,t){let n=this.spatialIndex.search(e).map(e=>this.store[e]);return this.clone(t?n.filter(t):n)}registerOnChange(e){this._onChange=(t,n,r)=>{e(t,n,r)}}getGeometryCopy(e){let t=this.store[e];if(!t)throw Error(`No feature with this id (${e}), can not get geometry copy`);return this.clone(t.geometry)}getPropertiesCopy(e){let t=this.store[e];if(!t)throw Error(`No feature with this id (${e}), can not get properties copy`);return this.clone(t.properties)}updateProperty(e,t){let n=new Set;e.forEach(({id:e,property:t,value:r})=>{let i=this.store[e];if(!i)throw Error(`No feature with this (${e}), can not update geometry`);i.properties[t]!==r&&(n.add(e),r===void 0?delete i.properties[t]:i.properties[t]=r,this.tracked&&(i.properties.updatedAt=+new Date))}),this._onChange&&n.size>0&&this._onChange(Array.from(n),`update`,t?D({},t,fr):fr)}updateGeometry(e,t){let n=new Set;e.forEach(({id:e,geometry:t})=>{n.add(e);let r=this.store[e];if(!r)throw Error(`No feature with this (${e}), can not update geometry`);r.geometry=this.clone(t),this.spatialIndex.update(r),this.tracked&&(r.properties.updatedAt=+new Date)}),this._onChange&&n.size>0&&this._onChange(Array.from(n),`update`,t?D({},t,dr):dr)}create(e,t){let n=[];return e.forEach(({geometry:e,properties:t})=>{let r,i=D({},t);this.tracked&&(r=+new Date,t?(i.createdAt=typeof t.createdAt==`number`?t.createdAt:r,i.updatedAt=typeof t.updatedAt==`number`?t.updatedAt:r):i={createdAt:r,updatedAt:r});let a=this.getId(),o={id:a,type:`Feature`,geometry:e,properties:i};this.store[a]=o,this.spatialIndex.insert(o),n.push(a)}),this._onChange&&this._onChange([...n],`create`,t),n}delete(e,t){e.forEach(e=>{if(!this.store[e])throw Error(`No feature with id ${e}, can not delete`);delete this.store[e],this.spatialIndex.remove(e)}),this._onChange&&this._onChange([...e],`delete`,t)}copy(e){return this.clone(this.store[e])}copyAll(){return this.clone(Object.keys(this.store).map(e=>this.store[e]))}copyAllWhere(e){return this.clone(Object.keys(this.store).map(e=>this.store[e]).filter(t=>t.properties&&e(t.properties)))}clear(e){let t=Object.keys(this.store);this.store={},this.spatialIndex.clear(),this._onChange(t,`delete`,e)}size(){return Object.keys(this.store).length}};Math.PI/180;var mr=`Feature is not a Polygon or LineString`,hr=`Feature intersects itself`,gr=e=>e.geometry.type!==`Polygon`&&e.geometry.type!==`LineString`?{valid:!1,reason:mr}:ht(e)?{valid:!1,reason:hr}:{valid:!0};function _r(e,t,n){let r=K(e,t),i=K(t,n)-r;return i<0&&(i+=360),180-Math.abs(i-90-90)}var vr={cancel:`Escape`,finish:`Enter`},yr={start:`crosshair`,close:`pointer`},br=class extends N{constructor(e){super(e,!0),this.mode=`angled-rectangle`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=vr,this.cursors=yr,this.mouseMove=!1,this.mutateFeature=void 0,this.readFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents))}close(){if(this.currentId===void 0||!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.currentId===void 0||this.currentCoordinate===0)return;let t=[];if(this.currentCoordinate===1)t=this.getUpdateForSecondCoordinate(e);else{if(this.currentCoordinate!==2)return;t=this.getNewSecondAndThirdCoordinates(e)}this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:t,context:{updateType:k.Provisional}})}getUpdateForSecondCoordinate(e){return[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:V,index:2,coordinate:[e.lng,e.lat]}]}getNewSecondAndThirdCoordinates(e){if(!this.currentId)throw Error(`No current feature being drawn`);let t=this.readFeature.getCoordinate(this.currentId,0),n=this.readFeature.getCoordinate(this.currentId,1),r=Dn(t,n,this.coordinatePrecision,this.project,this.unproject),i=L(t[0],t[1]),a=L(r[0],r[1]),o=L(n[0],n[1]),s=L(e.lng,e.lat),c=W(s,i)<W(s,o),l=_r(i,a,s),u=c?90-l:_r(i,a,s)-90,d=W(a,s),f=Math.cos(F(u))*d,p=K(i,o)+(function(e,t,n){let r=(n.x-t.x)*(e.y-t.y)-(n.y-t.y)*(e.x-t.x);return r>1e-10?`left`:r<-1e-10?`right`:`left`}(i,o,s)===`right`?-90:90),m=Vt(i,f,p),h=Vt(o,f,p),g=R(m.x,m.y),_=R(h.x,h.y);return[{type:V,index:2,coordinate:[I(_.lng,this.coordinatePrecision),I(_.lat,this.coordinatePrecision)]},{type:V,index:3,coordinate:[I(g.lng,this.coordinatePrecision),I(g.lat,this.coordinatePrecision)]}]}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))if(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,this.currentCoordinate===0){let{id:t}=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.currentId=t,this.currentCoordinate++,this.setDrawing()}else if(this.currentCoordinate===1&&this.currentId){let t=this.readFeature.getCoordinate(this.currentId,0);if(Mt([e.lng,e.lat],t)||!this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:B,index:1,coordinate:[e.lng,e.lat]}],context:{updateType:k.Commit}}))return;this.currentCoordinate++}else this.currentCoordinate===2&&this.currentId&&this.close()}onKeyUp(e){if(e.key===this.keyEvents.cancel)this.cleanUp();else if(e.key===this.keyEvents.finish){if(this.currentCoordinate<2)return void this.cleanUp();this.close()}}onKeyDown(){}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){let e=this.currentId;this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.properties.mode===this.mode&&e.geometry.type===`Polygon`&&(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M),t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}};function xr(e,t,n){return(t.x-e.x)*(n.y-e.y)-(t.y-e.y)*(n.x-e.x)<=0}var Sr={cancel:`Escape`,finish:`Enter`},Cr={start:`crosshair`,close:`pointer`},wr=class extends N{constructor(e){super(e,!0),this.mode=`sector`,this.currentCoordinate=0,this.currentId=void 0,this.keyEvents=Sr,this.direction=void 0,this.arcPoints=64,this.cursors=Cr,this.mouseMove=!1,this.readFeature=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.arcPoints&&(this.arcPoints=e.arcPoints)}close(){if(this.currentId===void 0||!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},coordinateMutations:{coordinates:this.readFeature.getGeometry(this.currentId).coordinates,type:H},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.currentCoordinate=0,this.currentId=void 0,this.direction=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}getSectorCoordinates(e){let t=this.readFeature.getCoordinates(this.currentId),n=t[0],r=t[1],i=[e.lng,e.lat],a=L(n[0],n[1]),o=L(r[0],r[1]),s=L(i[0],i[1]);this.direction===void 0&&(this.direction=xr(a,o,s)?`clockwise`:`anticlockwise`);let c=W(a,o),l=K(a,o),u=K(a,s),d=this.arcPoints,f=[n],p=Ut(l),m=Ut(u),h;this.direction===`anticlockwise`?(h=m-p,h<0&&(h+=360)):(h=p-m,h<0&&(h+=360));let g=(this.direction===`anticlockwise`?1:-1)*h/d;f.push(r);for(let e=0;e<=d;e++){let t=Vt(a,c,p+e*g),{lng:n,lat:r}=R(t.x,t.y),i=[I(n,this.coordinatePrecision),I(r,this.coordinatePrecision)];i[0]!==f[f.length-1][0]&&i[1]!==f[f.length-1][1]&&f.push(i)}return f.push(n),f}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.currentId===void 0||this.currentCoordinate===0)return;let t;if(this.currentCoordinate===1)t=[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:V,index:2,coordinate:[e.lng,e.lat]}];else{if(this.currentCoordinate!==2)return;{let n=this.getSectorCoordinates(e);if(!n)return;t={type:H,coordinates:[n]}}}this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:t,context:{updateType:k.Provisional}})}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))if(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,this.currentCoordinate===0)this.currentId=this.mutateFeature.createPolygon({coordinates:[[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}})?.id,this.currentCoordinate++,this.setDrawing();else if(this.currentCoordinate===1&&this.currentId){if(this.readFeature.coordinateAtIndexIsIdentical({featureId:this.currentId,index:0,newCoordinate:[e.lng,e.lat]})||!this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:[{type:V,index:1,coordinate:[e.lng,e.lat]},{type:V,index:2,coordinate:[e.lng,e.lat]}],context:{updateType:k.Provisional}}))return;this.currentCoordinate++}else this.currentCoordinate===2&&this.currentId&&this.close()}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onKeyDown(){}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){let e=this.currentId;this.currentId=void 0,this.direction=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e)}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.properties.mode===this.mode&&e.geometry.type===`Polygon`&&(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M),t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.currentId=void 0,this.direction=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}},Tr={cancel:`Escape`,finish:`Enter`},Er={start:`crosshair`,close:`pointer`},Dr=class extends N{constructor(e){super(e,!0),this.mode=`sensor`,this.currentCoordinate=0,this.currentId=void 0,this.currentInitialArcId=void 0,this.currentStartingPointId=void 0,this.keyEvents=Tr,this.direction=void 0,this.arcPoints=64,this.cursors=Er,this.mouseMove=!1,this.readFeature=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.arcPoints&&(this.arcPoints=e.arcPoints)}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.mouseMove=!0,this.setCursor(this.cursors.start),this.currentInitialArcId!==void 0&&this.currentStartingPointId!==void 0&&this.currentCoordinate!==0){if(this.currentCoordinate===2){let t=this.getUpdatedLineStringCoordinates(e);if(!t)return;this.mutateFeature.updateLineString({featureId:this.currentInitialArcId,coordinateMutations:{type:H,coordinates:t},context:{updateType:k.Provisional}})}else if(this.currentCoordinate===3){let t=this.getUpdatedPolygonCoordinates(e);if(!t)return;if(this.currentId)this.mutateFeature.updatePolygon({featureId:this.currentId,coordinateMutations:{type:H,coordinates:[t]},context:{updateType:k.Provisional}});else{let e=this.mutateFeature.createPolygon({coordinates:t,properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});if(!e)return;this.currentId=e.id}}}}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e))if(this.currentCoordinate>0&&!this.mouseMove&&this.onMouseMove(e),this.mouseMove=!1,this.currentCoordinate===0){let t=this.mutateFeature.createPoint({coordinates:[e.lng,e.lat],properties:{mode:this.mode}});if(!t)return;this.currentStartingPointId=t.id,this.currentCoordinate++,this.setDrawing()}else if(this.currentCoordinate===1&&this.currentStartingPointId){let t=this.mutateFeature.createLineString({coordinates:[[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode}});if(!t)return;this.currentInitialArcId=t.id,this.currentCoordinate++}else this.currentCoordinate===2&&this.currentStartingPointId?this.currentCoordinate++:this.currentCoordinate===3&&this.currentStartingPointId&&this.close()}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&this.close()}onKeyDown(){}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){this.mutateFeature.deleteFeatureIfPresent(this.currentStartingPointId),this.mutateFeature.deleteFeatureIfPresent(this.currentInitialArcId),this.mutateFeature.deleteFeatureIfPresent(this.currentId),this.currentStartingPointId=void 0,this.direction=void 0,this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.properties.mode===this.mode&&(e.geometry.type===`Polygon`?(t.polygonFillColor=this.getHexColorStylingValue(this.styles.fillColor,t.polygonFillColor,e),t.polygonOutlineColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.polygonOutlineWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.polygonOutlineOpacity=this.getNumericStylingValue(this.styles.outlineOpacity,1,e),t.polygonFillOpacity=this.getNumericStylingValue(this.styles.fillOpacity,t.polygonFillOpacity,e),t.zIndex=M):e.geometry.type===`LineString`?(t.lineStringColor=this.getHexColorStylingValue(this.styles.outlineColor,t.polygonOutlineColor,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.outlineWidth,t.polygonOutlineWidth,e),t.zIndex=M):e.geometry.type===`Point`&&(t.pointColor=this.getHexColorStylingValue(this.styles.centerPointColor,t.pointColor,e),t.pointOpacity=this.getNumericStylingValue(this.styles.centerPointOpacity,1,e),t.pointWidth=this.getNumericStylingValue(this.styles.centerPointWidth,t.pointWidth,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.centerPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.centerPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.centerPointOutlineWidth,t.pointOutlineWidth,e),t.zIndex=20)),t}validateFeature(e){return this.validateModeFeature(e,e=>Tt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.mutateFeature.deleteFeatureIfPresent(this.currentStartingPointId),this.mutateFeature.deleteFeatureIfPresent(this.currentInitialArcId),this.currentStartingPointId=void 0,this.direction=void 0,this.currentId=void 0,this.currentCoordinate=0,this.state===`drawing`&&this.setStarted())}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate})}close(){if(this.currentStartingPointId===void 0)return;let e=this.currentStartingPointId,t=this.currentInitialArcId;if(this.currentId&&!this.mutateFeature.updatePolygon({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},coordinateMutations:{coordinates:this.readFeature.getGeometry(this.currentId).coordinates,type:H},context:{updateType:k.Finish,action:O}}))return;let n=this.currentId;this.mutateFeature.deleteFeatureIfPresent(e),this.mutateFeature.deleteFeatureIfPresent(t),this.currentCoordinate=0,this.currentStartingPointId=void 0,this.currentInitialArcId=void 0,this.currentId=void 0,this.direction=void 0,this.state===`drawing`&&this.setStarted(),n&&this.onFinish(n,{mode:this.mode,action:O})}getUpdatedPolygonCoordinates(e){if(this.currentInitialArcId===void 0||this.currentStartingPointId===void 0||this.currentCoordinate<3)return;let t=this.readFeature.getCoordinates(this.currentInitialArcId);if(t.length<2||!this.direction)return;let n=this.readFeature.getGeometry(this.currentStartingPointId).coordinates,r=t[0],i=t[t.length-1],a=L(e.lng,e.lat),o=L(r[0],r[1]),s=L(i[0],i[1]),c=L(n[0],n[1]),l=W(c,o),u=W(c,a)<l?o:a,d=K(c,a),f=K(c,o),p=K(c,s),m=Ut(f),h=Ut(p),g=Ut(d);if(this.notInSector({normalizedCursor:g,normalizedStart:m,normalizedEnd:h,direction:this.direction}))return;let _=this.getDeltaBearing(this.direction,m,h),v=this.arcPoints,y=(this.direction===`anticlockwise`?1:-1)*_/v,ee=W(c,u),b=[];for(let e=0;e<=v;e++){let n=Vt(c,ee,m+e*y),{lng:r,lat:i}=R(n.x,n.y),a=[I(r,this.coordinatePrecision),I(i,this.coordinatePrecision)];a[0]!==t[t.length-1][0]&&a[1]!==t[t.length-1][1]&&b.unshift(a)}return t.push(...b),t.push(t[0]),t}getUpdatedLineStringCoordinates(e){if(this.currentInitialArcId===void 0||this.currentStartingPointId===void 0||this.currentCoordinate<2)return;let t=this.readFeature.getGeometry(this.currentInitialArcId).coordinates,n=this.readFeature.getGeometry(this.currentStartingPointId).coordinates,r=t[0],i=[e.lng,e.lat],a=L(r[0],r[1]),o=L(i[0],i[1]),s=L(n[0],n[1]),c=W(s,a);this.direction===void 0&&(this.direction=xr(s,a,o)?`clockwise`:`anticlockwise`);let l=K(s,a),u=K(s,o),d=this.arcPoints,f=[r],p=Ut(l),m=Ut(u),h;this.direction===`anticlockwise`?(h=m-p,h<0&&(h+=360)):(h=p-m,h<0&&(h+=360));let g=(this.direction===`anticlockwise`?1:-1)*h/d;for(let e=0;e<=d;e++){let t=Vt(s,c,p+e*g),{lng:n,lat:r}=R(t.x,t.y),i=[I(n,this.coordinatePrecision),I(r,this.coordinatePrecision)];i[0]!==f[f.length-1][0]&&i[1]!==f[f.length-1][1]&&f.push(i)}return f}getDeltaBearing(e,t,n){let r;return e===`anticlockwise`?(r=n-t,r<0&&(r+=360)):(r=t-n,r<0&&(r+=360)),r}notInSector({normalizedCursor:e,normalizedStart:t,normalizedEnd:n,direction:r}){return r===`clockwise`?t<=n?e>=t&&e<=n:e>=t||e<=n:t>=n?e<=t&&e>=n:e<=t||e>=n}},Or=class{constructor({name:e,callback:t,unregister:n,register:r}){this.name=void 0,this.callback=void 0,this.registered=!1,this.register=void 0,this.unregister=void 0,this.name=e,this.register=()=>{this.registered||(this.registered=!0,r(t))},this.unregister=()=>{this.register&&(this.registered=!1,n(t))},this.callback=t}},kr={__proto__:null,GeoJSONStore:pr,TerraDrawBaseDrawMode:N,TerraDrawBaseSelectMode:ot,TerraDrawBaseAdapter:class{constructor(e){this._nextKeyUpIsContextMenu=!1,this._lastPointerDownEventTarget=void 0,this._ignoreMismatchedPointerEvents=!1,this._minPixelDragDistance=void 0,this._minPixelDragDistanceDrawing=void 0,this._minPixelDragDistanceSelecting=void 0,this._lastDrawEvent=void 0,this._coordinatePrecision=void 0,this._heldKeys=new Set,this._listeners=[],this._dragState=`not-dragging`,this._currentModeCallbacks=void 0,this._ignoreMismatchedPointerEvents=typeof e.ignoreMismatchedPointerEvents==`boolean`&&e.ignoreMismatchedPointerEvents,this._minPixelDragDistance=typeof e.minPixelDragDistance==`number`?e.minPixelDragDistance:1,this._minPixelDragDistanceSelecting=typeof e.minPixelDragDistanceSelecting==`number`?e.minPixelDragDistanceSelecting:1,this._minPixelDragDistanceDrawing=typeof e.minPixelDragDistanceDrawing==`number`?e.minPixelDragDistanceDrawing:8,this._coordinatePrecision=typeof e.coordinatePrecision==`number`?e.coordinatePrecision:9}getButton(e){return e.button===-1?`neither`:e.button===0?`left`:e.button===1?`middle`:e.button===2?`right`:`neither`}getMapElementXYPosition(e){let{left:t,top:n}=this.getMapEventElement(e.type).getBoundingClientRect();return{containerX:e.clientX-t,containerY:e.clientY-n}}getDrawEventFromEvent(e,t=!1){let n=this.getLngLatFromEvent(e);if(!n)return null;let{lng:r,lat:i}=n,{containerX:a,containerY:o}=this.getMapElementXYPosition(e),s=this.getButton(e),c=Array.from(this._heldKeys);return{lng:I(r,this._coordinatePrecision),lat:I(i,this._coordinatePrecision),containerX:a,containerY:o,button:s,heldKeys:c,isContextMenu:t}}register(e){this._currentModeCallbacks=e,this._listeners=this.getAdapterListeners(),this._listeners.forEach(e=>{e.register()})}getCoordinatePrecision(){return this._coordinatePrecision}getAdapterListeners(){return[new Or({name:`pointerdown`,callback:e=>{if(!this._currentModeCallbacks||!e.isPrimary)return;let t=this.getDrawEventFromEvent(e);t&&(this._dragState=`pre-dragging`,this._lastDrawEvent=t,this._lastPointerDownEventTarget=e.target?e.target:void 0)},register:e=>{this.getMapEventElement(`pointerdown`).addEventListener(`pointerdown`,e)},unregister:e=>{this.getMapEventElement(`pointerdown`).removeEventListener(`pointerdown`,e)}}),new Or({name:`pointermove`,callback:e=>{if(!this._currentModeCallbacks||!e.isPrimary)return;e.preventDefault();let t=this.getDrawEventFromEvent(e);if(t)if(this._dragState===`not-dragging`)this._currentModeCallbacks.onMouseMove(t),this._lastDrawEvent=t;else if(this._dragState===`pre-dragging`){if(!this._lastDrawEvent)return;let e={x:this._lastDrawEvent.containerX,y:this._lastDrawEvent.containerY},n={x:t.containerX,y:t.containerY},r=this._currentModeCallbacks.getState(),i=W(e,n),a=!1;if(a=r===`drawing`?i<this._minPixelDragDistanceDrawing:r===`selecting`?i<this._minPixelDragDistanceSelecting:i<this._minPixelDragDistance,a)return;this._nextKeyUpIsContextMenu=!1,this._dragState=`dragging`,this._currentModeCallbacks.onDragStart(t,e=>{this.setDraggability.bind(this)(e)})}else this._dragState===`dragging`&&this._currentModeCallbacks.onDrag(t,e=>{this.setDraggability.bind(this)(e)})},register:e=>{this.getMapEventElement(`pointermove`).addEventListener(`pointermove`,e)},unregister:e=>{this.getMapEventElement(`pointermove`).removeEventListener(`pointermove`,e)}}),new Or({name:`contextmenu`,callback:e=>{this._currentModeCallbacks&&(e.preventDefault(),this._nextKeyUpIsContextMenu=!0)},register:e=>{this.getMapEventElement(`contextmenu`).addEventListener(`contextmenu`,e)},unregister:e=>{this.getMapEventElement(`contextmenu`).removeEventListener(`contextmenu`,e)}}),new Or({name:`pointerup`,callback:e=>{if(!this._currentModeCallbacks||e.target!==this.getMapEventElement(`pointerup`)||this._ignoreMismatchedPointerEvents&&this._lastPointerDownEventTarget!==e.target||(this._lastPointerDownEventTarget=void 0,!e.isPrimary))return;let t=this.getDrawEventFromEvent(e);t&&(this._dragState===`dragging`?this._currentModeCallbacks.onDragEnd(t,e=>{this.setDraggability.bind(this)(e)}):this._dragState!==`not-dragging`&&this._dragState!==`pre-dragging`||(this._nextKeyUpIsContextMenu&&=(t.isContextMenu=!0,!1),this._currentModeCallbacks.onClick(t)),this._dragState=`not-dragging`,this.setDraggability(!0))},register:e=>{this.getMapEventElement(`pointerup`).addEventListener(`pointerup`,e)},unregister:e=>{this.getMapEventElement(`pointerup`).removeEventListener(`pointerup`,e)}}),new Or({name:`keyup`,callback:e=>{this._currentModeCallbacks&&(this._heldKeys.delete(e.key),this._currentModeCallbacks.onKeyUp({key:e.key,heldKeys:Array.from(this._heldKeys),preventDefault:()=>e.preventDefault()}))},register:e=>{this.getMapEventElement(`keyup`).addEventListener(`keyup`,e)},unregister:e=>{this.getMapEventElement(`keyup`).removeEventListener(`keyup`,e)}}),new Or({name:`keydown`,callback:e=>{this._currentModeCallbacks&&(this._heldKeys.add(e.key),this._currentModeCallbacks.onKeyDown({key:e.key,heldKeys:Array.from(this._heldKeys),preventDefault:()=>e.preventDefault()}))},register:e=>{this.getMapEventElement(`keydown`).addEventListener(`keydown`,e)},unregister:e=>{this.getMapEventElement(`keydown`).removeEventListener(`keydown`,e)}})]}unregister(){this._listeners.forEach(e=>{e.unregister()}),this.clear(),this._currentModeCallbacks=void 0,this._lastDrawEvent=void 0,this._lastPointerDownEventTarget=void 0,this._nextKeyUpIsContextMenu=!1}},getDefaultStyling:()=>({polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0}),SELECT_PROPERTIES:A},Ar={cancel:`Escape`,finish:`Enter`},jr={start:`crosshair`,close:`pointer`},Mr=class extends N{constructor(e){super(e,!0),this.mode=`freehand-linestring`,this.canClose=!1,this.currentId=void 0,this.minDistance=20,this.keyEvents=Ar,this.cursors=jr,this.preventNewFeature=!1,this.mutateFeature=void 0,this.readFeature=void 0,this.pixelDistance=void 0,this.closingPoints=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.minDistance&&(this.minDistance=e.minDistance),e?.keyEvents===null?this.keyEvents={cancel:null,finish:null}:e!=null&&e.keyEvents&&(this.keyEvents=D({},this.keyEvents,e.keyEvents)),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors))}close(){if(this.currentId===void 0||!this.mutateFeature.updateLineString({featureId:this.currentId,propertyMutations:{[j.CURRENTLY_DRAWING]:void 0},context:{updateType:k.Finish,action:O}}))return;let e=this.currentId;this.closingPoints.delete(),this.canClose=!1,this.currentId=void 0,this.state===`drawing`&&this.setStarted(),this.onFinish(e,{mode:this.mode,action:O})}start(){this.setStarted(),this.setCursor(this.cursors.start)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onMouseMove(e){if(this.currentId===void 0||!1===this.canClose)return void this.setCursor(this.cursors.start);let[t,n]=this.readFeature.getCoordinate(this.currentId,-2),{x:r,y:i}=this.project(t,n),a=W({x:r,y:i},{x:e.containerX,y:e.containerY}),[o,s]=this.readFeature.getCoordinate(this.currentId,-1),{x:c,y:l}=this.project(o,s),u=W({x:c,y:l},{x:e.containerX,y:e.containerY});if(this.setCursor(u<this.pointerDistance?this.cursors.close:this.cursors.start),a<this.minDistance)return;let d=this.mutateFeature.updateLineString({featureId:this.currentId,coordinateMutations:[{type:B,index:-1,coordinate:[e.lng,e.lat]}],context:{updateType:k.Provisional}});d&&this.closingPoints.update(d.geometry.coordinates)}onClick(e){if(e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)){if(this.preventNewFeature)return;if(!1===this.canClose){let{id:t,geometry:n}=this.mutateFeature.createLineString({coordinates:[[e.lng,e.lat],[e.lng,e.lat]],properties:{mode:this.mode,[j.CURRENTLY_DRAWING]:!0}});this.closingPoints.create(n.coordinates),this.currentId=t,this.canClose=!0,this.state!==`drawing`&&this.setDrawing();return}this.close()}}onKeyDown(){}onKeyUp(e){e.key===this.keyEvents.cancel?this.cleanUp():e.key===this.keyEvents.finish&&!0===this.canClose&&this.close()}onDragStart(){}onDrag(){}onDragEnd(){}cleanUp(){let e=this.currentId;this.currentId=void 0,this.canClose=!1,this.state===`drawing`&&this.setStarted(),this.mutateFeature.deleteFeatureIfPresent(e),this.closingPoints.delete()}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`LineString`&&e.properties.mode===this.mode?(t.lineStringColor=this.getHexColorStylingValue(this.styles.lineStringColor,t.lineStringColor,e),t.lineStringOpacity=this.getNumericStylingValue(this.styles.lineStringOpacity,t.lineStringOpacity===void 0?1:t.lineStringOpacity,e),t.lineStringWidth=this.getNumericStylingValue(this.styles.lineStringWidth,t.lineStringWidth,e),t.zIndex=M,t):e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode?(t.pointWidth=this.getNumericStylingValue(this.styles.closingPointWidth,t.pointWidth,e),t.pointOpacity=this.getNumericStylingValue(this.styles.closingPointOpacity,1,e),t.pointColor=this.getHexColorStylingValue(this.styles.closingPointColor,t.pointColor,e),t.pointOutlineColor=this.getHexColorStylingValue(this.styles.closingPointOutlineColor,t.pointOutlineColor,e),t.pointOutlineOpacity=this.getNumericStylingValue(this.styles.closingPointOutlineOpacity,1,e),t.pointOutlineWidth=this.getNumericStylingValue(this.styles.closingPointOutlineWidth,2,e),t.zIndex=50,t):t}validateFeature(e){return this.validateModeFeature(e,e=>Jt(e,this.coordinatePrecision))}afterFeatureUpdated(e){this.currentId===e.id&&(this.closingPoints.delete(),this.canClose=!1,this.currentId=void 0)}registerBehaviors(e){this.readFeature=new G(e),this.mutateFeature=new U(e,{validate:this.validate}),this.pixelDistance=new Rt(e),this.closingPoints=new on(e,this.pixelDistance,this.mutateFeature,this.readFeature)}};function Nr(e){if(e===null||typeof e==`boolean`||typeof e==`string`)return!0;if(e===void 0)return!1;if(typeof e==`number`)return Number.isFinite(e);if(typeof e==`bigint`||typeof e==`symbol`||typeof e==`function`||e instanceof RegExp||e instanceof Map||e instanceof Set||e instanceof Date)return!1;if(typeof e==`object`&&e&&!Array.isArray(e)){let t=Object.getPrototypeOf(e);if(t!==Object.prototype&&t!==null)return!1}if(ArrayBuffer.isView(e)&&!(e instanceof DataView))return!1;if(Array.isArray(e)){for(let t of e)if(!Nr(t))return!1}return typeof e==`object`&&Object.keys(e).every(t=>typeof t==`string`&&Nr(e[t]))}var Pr={create:`crosshair`,dragStart:`grabbing`,dragEnd:`crosshair`},Fr=class extends N{constructor(e){super(e,!0),this.mode=`marker`,this.cursors=Pr,this.editable=!1,this.editedFeatureId=void 0,this.pixelDistance=void 0,this.clickBoundingBox=void 0,this.pointSearch=void 0,this.mutateFeature=void 0,this.updateOptions(e)}updateOptions(e){super.updateOptions(e),e!=null&&e.cursors&&(this.cursors=D({},this.cursors,e.cursors)),e!=null&&e.editable&&(this.editable=e.editable)}start(){this.setStarted(),this.setCursor(this.cursors.create)}stop(){this.cleanUp(),this.setStopped(),this.setCursor(`unset`)}onClick(e){e.button===`right`&&this.allowPointerEvent(this.pointerEvents.rightClick,e)||e.isContextMenu&&this.allowPointerEvent(this.pointerEvents.contextMenu,e)?this.onRightClick(e):e.button===`left`&&this.allowPointerEvent(this.pointerEvents.leftClick,e)&&this.onLeftClick(e)}onMouseMove(){}onKeyDown(){}onKeyUp(){}cleanUp(){this.editedFeatureId=void 0}onDragStart(e,t){this.allowPointerEvent(this.pointerEvents.onDragStart,e)&&(this.editable&&(this.editedFeatureId=this.pointSearch.getNearestPointFeature(e)?.id),this.editedFeatureId&&(this.setCursor(this.cursors.dragStart),t(!1)))}onDrag(e,t){this.allowPointerEvent(this.pointerEvents.onDrag,e)&&this.editedFeatureId!==void 0&&this.mutateFeature.updatePoint({featureId:this.editedFeatureId,coordinateMutations:{type:H,coordinates:[e.lng,e.lat]},propertyMutations:{[j.EDITED]:!0},context:{updateType:k.Provisional}})}onDragEnd(e,t){if(!this.allowPointerEvent(this.pointerEvents.onDragEnd,e)||this.editedFeatureId===void 0||!this.mutateFeature.updatePoint({featureId:this.editedFeatureId,propertyMutations:{mode:this.mode,[j.EDITED]:!1},context:{updateType:k.Finish,action:`edit`}}))return;let n=this.editedFeatureId;this.setCursor(this.cursors.dragEnd),this.editedFeatureId=void 0,t(!0),this.onFinish(n,{mode:this.mode,action:O})}registerBehaviors(e){this.pixelDistance=new Rt(e),this.clickBoundingBox=new Lt(e),this.pointSearch=new gn(e,this.pixelDistance,this.clickBoundingBox),this.mutateFeature=new U(e,{validate:this.validate})}styleFeature(e){let t=D({},{polygonFillColor:`#3f97e0`,polygonOutlineColor:`#3f97e0`,polygonOutlineWidth:4,polygonOutlineOpacity:1,polygonFillOpacity:.3,pointColor:`#3f97e0`,pointOpacity:1,pointOutlineColor:`#ffffff`,pointOutlineOpacity:1,pointOutlineWidth:0,pointWidth:6,lineStringColor:`#3f97e0`,lineStringWidth:4,lineStringOpacity:1,zIndex:0,markerUrl:void 0,markerHeight:void 0,markerWidth:void 0});return e.type===`Feature`&&e.geometry.type===`Point`&&e.properties.mode===this.mode&&(t.zIndex=30,t.markerHeight=this.getNumericStylingValue(this.styles?.markerHeight,40,e),t.markerWidth=this.getNumericStylingValue(this.styles?.markerWidth,32,e),t.markerUrl=this.getUrlStylingValue(this.styles?.markerUrl,$e,e)),t}validateFeature(e){return this.validateModeFeature(e,e=>hn(e,this.coordinatePrecision))}onLeftClick(e){let t=this.mutateFeature.createPoint({coordinates:[e.lng,e.lat],properties:{mode:this.mode,[j.MARKER]:!0},context:{updateType:k.Finish,action:O}});t&&this.onFinish(t.id,{mode:this.mode,action:O})}onRightClick(e){if(!this.editable)return;let t=this.pointSearch.getNearestPointFeature(e);t&&this.mutateFeature.deleteFeatureIfPresent(t.id)}afterFeatureUpdated(e){this.editedFeatureId===e.id&&(this.editedFeatureId=void 0,this.setCursor(this.cursors.create))}},Ir=[{key:`z`,heldKeys:[`meta`]},{key:`z`,heldKeys:[`control`]}],Lr=[{key:`z`,heldKeys:[`meta`,`shift`]},{key:`z`,heldKeys:[`control`,`shift`]},{key:`y`,heldKeys:[`control`]}],Rr=(e,t)=>{let n=e.key.toLowerCase(),r=new Set(e.heldKeys.map(e=>e.toLowerCase()).filter(e=>e!==n));if(t.key.toLowerCase()!==n)return!1;let i=new Set(t.heldKeys.map(e=>e.toLowerCase()));if(r.size!==i.size)return!1;for(let e of i)if(!r.has(e))return!1;return!0},zr=class{constructor(e){this.undoKeyboardShortcuts=void 0,this.redoKeyboardShortcuts=void 0,this.undoKeyboardShortcuts=e?.undo??Ir,this.redoKeyboardShortcuts=e?.redo??Lr}isUndoKeyboardShortcut(e){return this.undoKeyboardShortcuts.some(t=>Rr(e,t))}isRedoKeyboardShortcut(e){return this.redoKeyboardShortcuts.some(t=>Rr(e,t))}};function Br(e){return e!==void 0&&Number.isFinite(e)?Math.max(0,Math.floor(e)):1/0}var J=`undo`,Y=`redo`,Vr=`push`,X=`mode`,Hr=`session`,Ur=class{constructor(e){this.getModeState=void 0,this.getModeHistorySizes=void 0,this.undoMode=void 0,this.redoMode=void 0,this.clearModeHistory=void 0,this.onHistoryChange=void 0,this.maxStackSize=void 0,this.lastHistorySizes={undoSize:0,redoSize:0},this.maxStackSize=Br(e?.maxStackSize)}getMaxStackSize(){return this.maxStackSize}register(e){this.getModeState=e.getModeState,this.getModeHistorySizes=e.getModeHistorySizes,this.undoMode=e.undoMode,this.redoMode=e.redoMode,this.clearModeHistory=e.clearModeHistory,this.onHistoryChange=e.onHistoryChange}inDrawingState(){return!!this.getModeState&&this.getModeState()===`drawing`}canUndo(){if(!this.inDrawingState())return!1;let{undoSize:e}=this.getHistorySizes();return e>0}canRedo(){if(!this.inDrawingState())return!1;let{redoSize:e}=this.getHistorySizes();return e>0}undo(){return!(!this.canUndo()||!this.undoMode||(this.undoMode(),this.emitHistoryChange(J),0))}redo(){return!(!this.canRedo()||!this.redoMode||(this.redoMode(),this.emitHistoryChange(Y),0))}clearHistory(){this.clearModeHistory&&this.clearModeHistory(),this.lastHistorySizes={undoSize:0,redoSize:0}}getHistorySizes(){return this.getModeHistorySizes?this.getModeHistorySizes():{undoSize:0,redoSize:0}}undoSize(){return this.getHistorySizes().undoSize}redoSize(){return this.getHistorySizes().redoSize}emitPushIfHistoryChangedFromLastSnapshot(){if(!this.inDrawingState())return;let e=this.getHistorySizes();e.undoSize===this.lastHistorySizes.undoSize&&e.redoSize===this.lastHistorySizes.redoSize||this.emitHistoryChange(Vr)}emitPushIfHistoryChanged(e){if(!this.inDrawingState())return;let t=this.getHistorySizes();t.undoSize===e.undoSize&&t.redoSize===e.redoSize||this.emitHistoryChange(Vr)}emitHistoryChange(e){if(!this.onHistoryChange)return;let{undoSize:t,redoSize:n}=this.getHistorySizes();this.lastHistorySizes={undoSize:t,redoSize:n},this.onHistoryChange({cause:e,stack:X,undoStackSize:t,redoStackSize:n})}},Wr=class{constructor(e){this.draw=void 0,this.onHistoryChange=void 0,this.maxStackSize=void 0,this.historyById={},this.undoStack=[],this.ignoreProgrammaticCreate={},this.ignoreProgrammaticDelete={},this.deletedFeatureIds={},this.redoStack=[],this.emitStackChange=e=>{this.onHistoryChange&&this.onHistoryChange({cause:e,stack:Hr,undoStackSize:this.undoStack.length,redoStackSize:this.redoStack.length})},this.handleChange=(e,t,n)=>{if(!this.draw||this.isDrawing()||this.maxStackSize===0||t!==`delete`&&t!==`create`)return;if(t===`create`){if(n===void 0||!(`origin`in n)||n.origin!==`api`)return;let t=!1,r=Array.isArray(e)?e:[e],i=[];for(let e of r){if(this.ignoreProgrammaticCreate[e]){delete this.ignoreProgrammaticCreate[e],delete this.deletedFeatureIds[e];continue}let n=String(e),r=this.draw.getSnapshotFeature(e);r&&(this.deletedFeatureIds[e]&&(this.historyById[n]=[],delete this.deletedFeatureIds[e]),this.historyById[n]||(this.historyById[n]=[]),this.historyById[n].push(r),i.push({id:e,toIndex:this.historyById[n].length-1,snapshot:r}),t=!0)}if(i.length>1)this.pushUndoStackEntry({id:i[0].id,toIndex:i[0].toIndex,action:`batch-create`,metadata:{entries:i}});else if(i.length===1){let e=i[0];this.pushUndoStackEntry({id:e.id,toIndex:e.toIndex,action:`single`})}t&&(this.redoStack.length=0,this.emitStackChange(Vr));return}let r=!1,i=Array.isArray(e)?e:[e],a=[];for(let e of i){let t=String(e);if(this.ignoreProgrammaticDelete[e]){delete this.ignoreProgrammaticDelete[e];continue}if(!this.historyById[t])continue;let n=this.historyById[t].length-1;if(n>=0){let i=this.historyById[t][n];if(!i)continue;a.push({id:e,toIndex:n,snapshot:i}),this.deletedFeatureIds[e]=!0,r=!0}}if(a.length>1)this.pushUndoStackEntry({id:a[0].id,toIndex:a[0].toIndex,action:`batch-delete`,metadata:{entries:a}});else if(a.length===1){let e=a[0];this.pushUndoStackEntry({id:e.id,toIndex:e.toIndex,action:`single`})}r&&(this.redoStack.length=0,this.emitStackChange(Vr))},this.handleFinish=e=>{if(!this.draw||this.maxStackSize===0)return;let t=Array.isArray(e)?e:[e],n=!1;for(let e of t){if(e==null)continue;let t=String(e),r=this.draw.getSnapshotFeature(e);r&&(this.historyById[t]||(this.historyById[t]=[]),this.historyById[t].push(r),n||=(this.redoStack.length=0,!0),this.pushUndoStackEntry({id:e,toIndex:this.historyById[t].length-1,action:`single`}),this.emitStackChange(Vr))}},this.maxStackSize=Br(e?.maxStackSize)}register(e){this.draw===e.draw?this.onHistoryChange=e.onHistoryChange:(this.draw&&(this.draw.off(`change`,this.handleChange),this.draw.off(`finish`,this.handleFinish)),this.draw=e.draw,this.draw.on(`change`,this.handleChange),this.draw.on(`finish`,this.handleFinish),this.onHistoryChange=e.onHistoryChange)}pushUndoStackEntry(e){this.maxStackSize!==0&&(this.undoStack.push(e),this.undoStack.length>this.maxStackSize&&this.undoStack.shift())}pushRedoStackEntry(e){this.maxStackSize!==0&&(this.redoStack.push(e),this.redoStack.length>this.maxStackSize&&this.redoStack.shift())}isDrawing(){return!!this.draw&&this.draw.getModeState()===`drawing`}canUndo(){return!(!this.draw||this.isDrawing())&&this.undoStack.length>0}canRedo(){return!(!this.draw||this.isDrawing())&&this.redoStack.length>0}undo(){if(!this.canUndo()||!this.draw)return!1;let e=this.undoStack.pop();if(!e)return this.emitStackChange(J),!1;if(e.action===`batch-create`){let t=e.metadata?.entries||[];if(t.length===0)return this.emitStackChange(J),!1;let n=t.map(e=>e.id);return n.forEach(e=>{this.ignoreProgrammaticDelete[e]=!0,this.deletedFeatureIds[e]=!0}),this.draw.removeFeatures(n),this.pushRedoStackEntry({id:t[0].id,toIndex:t[0].toIndex,action:`batch-create`,metadata:{entries:t}}),this.emitStackChange(J),!0}if(e.action===`batch-delete`){let t=e.metadata?.entries||[];if(t.length===0)return this.emitStackChange(J),!1;let n=t.map(e=>e.snapshot).filter(e=>e!==void 0);return n.length>0&&(t.forEach(e=>{this.ignoreProgrammaticCreate[e.id]=!0,delete this.deletedFeatureIds[e.id]}),this.draw.addFeatures(n)),this.pushRedoStackEntry({id:t[0].id,toIndex:t[0].toIndex,action:`batch-delete`,metadata:{entries:t}}),this.emitStackChange(J),!0}let t=e.id,n=e.toIndex,r=String(t),i=this.historyById[r];if(!i||i.length===0)return this.emitStackChange(J),!1;let a=Math.min(n,i.length-1);if(!this.draw.hasFeature(t)){let e=i[a];return e?(this.ignoreProgrammaticCreate[t]=!0,delete this.deletedFeatureIds[t],this.draw.addFeatures([e]),this.pushRedoStackEntry({id:t,toIndex:a,action:`delete`,snapshot:e}),this.emitStackChange(J),!0):(this.emitStackChange(J),!1)}if(a<=0)return this.pushRedoStackEntry({id:t,toIndex:0,action:`create`}),this.ignoreProgrammaticDelete[t]=!0,this.deletedFeatureIds[t]=!0,this.draw.removeFeatures([t]),this.undoStack=this.undoStack.filter(e=>e.id!==t),this.emitStackChange(J),!0;let o=i[a],s=i[a-1];return o&&this.pushRedoStackEntry({id:t,toIndex:a,snapshot:o,action:`update`}),this.draw.updateFeatureGeometry(t,s.geometry),i.length=a,this.emitStackChange(J),!0}redo(){if(!this.canRedo()||!this.draw)return!1;let{id:e,toIndex:t,snapshot:n,action:r,metadata:i}=this.redoStack.pop();if(r===`batch-create`){let e=i?.entries||[];if(e.length===0)return this.emitStackChange(Y),!1;let t=e.map(e=>e.snapshot).filter(e=>e!==void 0);return t.length>0&&(e.forEach(e=>{this.ignoreProgrammaticCreate[e.id]=!0}),this.draw.addFeatures(t)),this.pushUndoStackEntry({id:e[0].id,toIndex:e[0].toIndex,action:`batch-create`,metadata:{entries:e}}),this.emitStackChange(Y),!0}if(r===`batch-delete`){let e=i?.entries||[];if(e.length===0)return this.emitStackChange(Y),!1;let t=e.map(e=>e.id);return t.forEach(e=>{this.ignoreProgrammaticDelete[e]=!0,this.deletedFeatureIds[e]=!0}),this.draw.removeFeatures(t),this.pushUndoStackEntry({id:e[0].id,toIndex:e[0].toIndex,action:`batch-delete`,metadata:{entries:e}}),this.emitStackChange(Y),!0}let a=String(e),o=this.historyById[a]||(this.historyById[a]=[]);if(r===`delete`)return this.ignoreProgrammaticDelete[e]=!0,this.deletedFeatureIds[e]=!0,this.draw.removeFeatures([e]),this.pushUndoStackEntry({id:e,toIndex:t,action:`single`}),this.emitStackChange(Y),!0;if(t<=0){let t=o[0];return!!t&&(this.ignoreProgrammaticCreate[e]=!0,this.draw.addFeatures([t]),this.pushUndoStackEntry({id:e,toIndex:0,action:`single`}),this.emitStackChange(Y),!0)}let s=n||o[t];return!!s&&(o.length===t?o.push(s):(o[t]=s,o.length=t+1),this.draw.updateFeatureGeometry(e,s.geometry),this.pushUndoStackEntry({id:e,toIndex:t,action:`single`}),this.emitStackChange(Y),!0)}clearHistory(){let e={};if(this.draw&&!this.isDrawing()){let t=this.draw.getSnapshot();for(let n of t)e[String(n.id)]=[n]}this.historyById=e,this.undoStack=[],this.ignoreProgrammaticCreate={},this.ignoreProgrammaticDelete={},this.deletedFeatureIds={},this.redoStack=[]}undoSize(){return this.undoStack.length}redoSize(){return this.redoStack.length}},Gr=class{constructor(e){this.modeLevel=void 0,this.sessionLevel=void 0,this.shouldPreferMode=void 0,this.onHistoryChange=void 0,this.shouldEmitHistoryChange=void 0,this.modeLevel=e.modeLevel,this.sessionLevel=e.sessionLevel,this.shouldPreferMode=e.shouldPreferMode,this.onHistoryChange=e.onHistoryChange,this.shouldEmitHistoryChange=e.shouldEmitHistoryChange??(()=>!0)}emitStackHistoryChange(e){this.shouldEmitHistoryChange()&&this.onHistoryChange&&this.onHistoryChange({cause:e.cause,stack:e.stack,undoSize:e.undoStackSize,redoSize:e.redoStackSize})}hasSessionUndo(){return!!(this.sessionLevel&&this.sessionLevel.canUndo())}hasSessionRedo(){return!!(this.sessionLevel&&this.sessionLevel.canRedo())}activeStackForUndo(){var e,t;return this.shouldPreferMode()&&(e=this.modeLevel)!=null&&e.canUndo()?X:this.hasSessionUndo()?Hr:(t=this.modeLevel)!=null&&t.canUndo()?X:void 0}activeStackForRedo(){var e,t;return this.shouldPreferMode()&&(e=this.modeLevel)!=null&&e.canRedo()?X:this.hasSessionRedo()?Hr:(t=this.modeLevel)!=null&&t.canRedo()?X:void 0}canUndo(){return this.activeStackForUndo()!==void 0}canRedo(){return this.activeStackForRedo()!==void 0}undo(){let e=this.activeStackForUndo();return!!e&&(e===X?!!this.modeLevel&&this.modeLevel.undo():!(!this.sessionLevel||!this.sessionLevel.canUndo())&&this.sessionLevel.undo())}redo(){let e=this.activeStackForRedo();return!!e&&(e===X?!!this.modeLevel&&this.modeLevel.redo():!(!this.sessionLevel||!this.sessionLevel.canRedo())&&this.sessionLevel.redo())}clearHistory(){this.modeLevel&&this.modeLevel.clearHistory(),this.sessionLevel&&this.sessionLevel.clearHistory()}emitPushAfterFinish(){this.sessionLevel?this.emitStackHistoryChange({cause:Vr,undoStackSize:this.sessionLevel.undoSize(),redoStackSize:this.sessionLevel.redoSize(),stack:Hr}):this.modeLevel&&this.emitStackHistoryChange({cause:Vr,undoStackSize:this.modeLevel.undoSize(),redoStackSize:this.modeLevel.redoSize(),stack:X})}},Kr=class{constructor(e){var t,n,r,i;this._modes=void 0,this._mode=void 0,this._adapter=void 0,this._enabled=!1,this._store=void 0,this._eventListeners=void 0,this._instanceSelectModes=void 0,this.sessionUndoRedoEnabled=!1,this.keyboardShortcutsMatcher=void 0,this.drawingUndoRedo=void 0,this.sessionUndoRedo=void 0,this.undoRedoCoordinator=void 0,this._adapter=e.adapter,this._instanceSelectModes=[];let a=e==null||(t=e.undoRedo)==null?void 0:t.modeLevel;a&&(this.drawingUndoRedo=a);let o=e==null||(n=e.undoRedo)==null?void 0:n.keyboardShortcuts;o&&(this.keyboardShortcutsMatcher=o),this.sessionUndoRedoEnabled=!!(!(e==null||(r=e.undoRedo)==null)&&r.sessionLevel);let s=e==null||(i=e.undoRedo)==null?void 0:i.sessionLevel;this._mode=new qn;let c=new Set,l=e.modes.reduce((e,t)=>{if(c.has(t.mode))throw Error(`There is already a ${t.mode} mode provided`);return c.add(t.mode),e[t.mode]=t,e},{}),u=Object.keys(l);if(u.length===0)throw Error(`No modes provided`);u.forEach(e=>{l[e].type===it.Select&&this._instanceSelectModes.push(e)}),this._modes=D({},l,{static:this._mode}),this._eventListeners={change:[],select:[],deselect:[],finish:[],ready:[],history:[]},this._store=new pr({tracked:!!e.tracked,idStrategy:e.idStrategy?e.idStrategy:void 0});let d=e=>{let t=[];return{changed:t,unchanged:this._store.copyAll().filter(n=>!e.includes(n.id)||(t.push(n),!1))}},f=(e,t)=>{this._enabled&&(this._eventListeners.finish.forEach(n=>{n(e,t)}),this.emitHistoryChangeAfterFinish())},p=(e,t,n)=>{if(!this._enabled)return;this._eventListeners.change.forEach(r=>{r(e,t,n)}),this.emitDrawingPushIfHistoryChangedFromLastSnapshot();let{changed:r,unchanged:i}=d(e);t===`create`?this._adapter.render({created:r,deletedIds:[],unchanged:i,updated:[]},this.getModeStyles()):t===`update`?this._adapter.render({created:[],deletedIds:[],unchanged:i,updated:r},this.getModeStyles()):t===`delete`?this._adapter.render({created:[],deletedIds:e,unchanged:i,updated:[]},this.getModeStyles()):t===`styling`&&this._adapter.render({created:[],deletedIds:[],unchanged:i,updated:[]},this.getModeStyles())},m=e=>{if(!this._enabled)return;this._eventListeners.select.forEach(t=>{t(e)});let{changed:t,unchanged:n}=d([e]);this._adapter.render({created:[],deletedIds:[],unchanged:n,updated:t},this.getModeStyles())},h=e=>{if(!this._enabled)return;this._eventListeners.deselect.forEach(t=>{t(e)});let{changed:t,unchanged:n}=d([e]);t&&this._adapter.render({created:[],deletedIds:[],unchanged:n,updated:t},this.getModeStyles())};Object.keys(this._modes).forEach(e=>{var t;this._modes[e].register({mode:e,store:this._store,setCursor:this._adapter.setCursor.bind(this._adapter),project:this._adapter.project.bind(this._adapter),unproject:this._adapter.unproject.bind(this._adapter),setDoubleClickToZoom:this._adapter.setDoubleClickToZoom.bind(this._adapter),onChange:p,onSelect:m,onDeselect:h,onFinish:f,coordinatePrecision:this._adapter.getCoordinatePrecision(),undoRedoMaxStackSize:(t=this.drawingUndoRedo)==null||t.getMaxStackSize==null?void 0:t.getMaxStackSize()})}),this.sessionUndoRedoEnabled&&s&&(this.sessionUndoRedo=s,s.register({draw:this,onHistoryChange:e=>{var t;(t=this.undoRedoCoordinator)==null||t.emitStackHistoryChange(e)}})),this.drawingUndoRedo&&this.drawingUndoRedo.register({getModeState:()=>this.getModeState(),getModeHistorySizes:()=>this.getDrawingHistorySizes(),undoMode:()=>{this._mode.undo&&this._mode.undo()},redoMode:()=>{this._mode.redo&&this._mode.redo()},clearModeHistory:()=>{let e=this._mode;e.clearHistory&&e.clearHistory()},onHistoryChange:e=>{var t;(t=this.undoRedoCoordinator)==null||t.emitStackHistoryChange(e)}}),this.undoRedoCoordinator=new Gr({modeLevel:this.drawingUndoRedo,sessionLevel:this.sessionUndoRedo,shouldPreferMode:()=>this.getModeState()===`drawing`,onHistoryChange:e=>{this._eventListeners.history.forEach(t=>{t(e)})},shouldEmitHistoryChange:()=>this._enabled})}checkEnabled(){if(!this._enabled)throw Error(`Terra Draw is not enabled`)}handleUndoRedoKeyboardShortcut(e){if(!this.drawingUndoRedo&&!this.sessionUndoRedoEnabled||!this.keyboardShortcutsMatcher)return!1;let t=this.keyboardShortcutsMatcher.isUndoKeyboardShortcut(e),n=this.keyboardShortcutsMatcher.isRedoKeyboardShortcut(e);if(t){if(!this.canUndo())return!1;let t=this.undo();return t&&e.preventDefault(),t}if(n){if(!this.canRedo())return!1;let t=this.redo();return t&&e.preventDefault(),t}return!1}getDrawingHistorySizes(){return{undoSize:this._mode.undoSize&&typeof this._mode.undoSize==`function`?this._mode.undoSize():0,redoSize:this._mode.redoSize&&typeof this._mode.redoSize==`function`?this._mode.redoSize():0}}emitDrawingPushIfHistoryChangedFromLastSnapshot(){this.drawingUndoRedo&&this.drawingUndoRedo.emitPushIfHistoryChangedFromLastSnapshot()}emitDrawingPushIfHistoryChanged(e){this.drawingUndoRedo&&this.drawingUndoRedo.emitPushIfHistoryChanged(e)}emitHistoryChangeAfterFinish(){var e;(e=this.undoRedoCoordinator)==null||e.emitPushAfterFinish()}getModeStyles(){let e={},t=this._instanceSelectModes.includes(this._mode.mode)?this._mode.mode:void 0;return Object.keys(this._modes).forEach(n=>{e[n]=e=>t&&e.properties[A.SELECTED]?this._modes[t].styleFeature.bind(this._modes[t])(e):this._modes[n].styleFeature.bind(this._modes[n])(e)}),e}featuresAtLocation({lng:e,lat:t},n){let r=n&&n.pointerDistance!==void 0?n.pointerDistance:30,i=!n||n.ignoreSelectFeatures===void 0||n.ignoreSelectFeatures,a=!(!n||n.ignoreCoordinatePoints===void 0)&&n.ignoreCoordinatePoints,o=!(!n||n.ignoreCurrentlyDrawing===void 0)&&n.ignoreCurrentlyDrawing,s=!(!n||n.ignoreClosingPoints===void 0)&&n.ignoreClosingPoints,c=!(!n||n.ignoreSnappingPoints===void 0)&&n.ignoreSnappingPoints,l=this._adapter.unproject.bind(this._adapter),u=this._adapter.project.bind(this._adapter),d=u(e,t),f=It({unproject:l,point:d,pointerDistance:r});return this._store.search(f).filter(l=>{if(i&&(l.properties[A.MID_POINT]||l.properties[A.SELECTION_POINT])||a&&l.properties[j.COORDINATE_POINT]||s&&l.properties[j.CLOSING_POINT]||o&&l.properties[j.CURRENTLY_DRAWING]||c&&l.properties[j.SNAPPING_POINT])return!1;if(l.geometry.type===`Point`){let e=l.geometry.coordinates;return W(d,u(e[0],e[1]))<r}if(l.geometry.type===`LineString`){let e=l.geometry.coordinates;for(let t=0;t<e.length-1;t++){let n=e[t],i=e[t+1];if(Nn(d,u(n[0],n[1]),u(i[0],i[1]))<r)return!0}return!1}if(Mn([e,t],l.geometry.coordinates))return!0;if(n!=null&&n.includePolygonsWithinPointerDistance){let e=l.geometry.coordinates;for(let t of e)for(let e=0;e<t.length-1;e++){let n=t[e],i=t[e+1];if(Nn(d,u(n[0],n[1]),u(i[0],i[1]))<r)return!0}}return!1}).map(r=>{if(n==null||!n.addClosestCoordinateInfoToProperties)return r;let i;if(r.geometry.type===`Polygon`)i=r.geometry.coordinates[0].slice(0,-1);else{if(r.geometry.type!==`LineString`)return r;i=r.geometry.coordinates}let a,o=-1,s=1/0;for(let e=0;e<i.length;e++){let t=i[e],n=W(u(t[0],t[1]),d);n<s&&(o=e,s=n,a=t)}return r.properties.closestCoordinateIndexToEvent=o,r.properties.closestCoordinatePixelDistanceToEvent=s,r.properties.closestCoordinateDistanceKmToEvent=P(a,[e,t]),r})}getSelectModeOrThrow(e=void 0){let t=this.getSelectMode({switchToSelectMode:!0,selectMode:e});if(!t)throw Error(`No select mode defined in instance`);return t}getSelectMode({switchToSelectMode:e,selectMode:t}){this.checkEnabled();let n=this.getMode();if(this._instanceSelectModes.length===0)return null;if(t!==void 0&&!this._instanceSelectModes.includes(t))throw Error(`No select mode with this name present: ${t}`);let r;return r=t===void 0?this._instanceSelectModes.includes(n)?n:this._instanceSelectModes[0]:t,e&&n!==r&&this.setMode(r),this._modes[r]}isGuidanceFeature(e){return!!(e.properties[A.MID_POINT]||e.properties[A.SELECTION_POINT]||e.properties[j.COORDINATE_POINT]||e.properties[j.SNAPPING_POINT])}setModeStyles(e,t){if(this.checkEnabled(),!this._modes[e])throw Error(`No mode with this name present`);this._modes[e].styles=t}updateModeOptions(e,t){if(this.checkEnabled(),!this._modes[e])throw Error(`No mode with this name present`);this._modes[e].updateOptions(t)}getSnapshot(){return this._store.copyAll()}getSnapshotFeature(e){if(this._store.has(e))return this._store.copy(e)}clear(){this.checkEnabled(),this._adapter.clear()}get enabled(){return this._enabled}set enabled(e){throw Error(`Enabled is read only`)}getMode(){return this._mode.mode}getModeState(){return this._mode.state}setMode(e){if(this.checkEnabled(),!this._modes[e])throw Error(`No mode with this name present`);this._mode.stop(),this._mode=this._modes[e],this._mode.start()}removeFeatures(e){this.checkEnabled();let t=[],n=[],r;e.forEach(e=>{if(!this._store.has(e))throw Error(`No feature with id ${e}, can not delete`);let i=this._store.getPropertiesCopy(e);i[A.SELECTED]&&this.deselectFeature(e),i[j.CURRENTLY_DRAWING]&&this._modes[i.mode]?r=i.mode:(i[j.COORDINATE_POINT_IDS]&&t.push(...i[j.COORDINATE_POINT_IDS]),n.push(e))}),this._store.delete([...n,...t],{origin:`api`}),r&&this._modes[r]&&this._modes[r].cleanUp()&&this._modes[r].cleanUp()}selectFeature(e,t){this.getSelectModeOrThrow(t).selectFeature(e)}deselectFeature(e){this.getSelectModeOrThrow().deselectFeature(e)}getFeatureId(){return this._store.getId()}hasFeature(e){return this._store.has(e)}checkIsReservedProperty(e){return![...Object.values(A),...Object.values(j)].includes(e)}updateFeatureProperties(e,t){if(!this._store.has(e))throw Error(`No feature with id ${e} present in store`);let n=this._store.copy(e);if(this.isGuidanceFeature(n))throw Error(`Guidance features are not allowed to be updated directly.`);let r=n.properties.mode;if(!this._modes[r])throw Error(`No mode with name ${r} present in instance`);let i=Object.entries(t);i.forEach(([e,t])=>{if(!this.checkIsReservedProperty(e))throw Error(`You are trying to update a reserved property name: ${e}. Please choose another name.`);if(t!==void 0&&!Nr(t))throw Error(`Invalid JSON value provided for property ${e}`)}),this._store.updateProperty(i.map(([e,t])=>({id:n.id,property:e,value:t})),{origin:`api`})}updateFeatureGeometry(e,t){if(!this._store.has(e))throw Error(`No feature with id ${e} present in store`);let n=this._store.copy(e);if(this.isGuidanceFeature(n))throw Error(`Guidance features are not allowed to be updated directly.`);if(!(n&&t&&t.type&&t.coordinates))throw Error(`Invalid geometry provided`);if(t.type!==n.geometry.type)throw Error(`Geometry type mismatch: expected ${n.geometry.type}, got ${t.type}`);let r=n.properties.mode,i=this._modes[r];if(!i)throw Error(`No mode with name ${r} present in instance`);let a=D({},n,{geometry:t}),o=i.validateFeature(a);if(!o.valid)throw Error(`Feature validation failed: ${o.reason||`Unknown reason`}`);if(this._store.updateGeometry([{id:n.id,geometry:t}],{origin:`api`}),i.afterFeatureUpdated){i.afterFeatureUpdated(a);let e=a.properties[A.SELECTED],t=this.getSelectMode({switchToSelectMode:!1});t&&e&&t.afterFeatureUpdated(a)}}transformFeatureGeometry(e,t){if(!this._store.has(e))throw Error(`No feature with id ${e} present in store`);let n=this._store.copy(e);if(this.isGuidanceFeature(n))throw Error(`Guidance features are not allowed to be updated directly.`);let r=n.properties.mode,i=this._modes[r];if(!i)throw Error(`No mode with name ${r} present in instance`);let a;if(n.geometry.type===`Polygon`)a=n.geometry.coordinates[0];else{if(n.geometry.type!==`LineString`)throw Error(`Feature geometry type ${n.geometry.type} is not supported for transformation`);a=n.geometry.coordinates}if(t.projection!=`web-mercator`)throw Error(`Projection ${t.projection} is not currently supported for transformation`);if(t.type===`scale`){let{x:e,y:n}=L(t.origin[0],t.origin[1]);Hn({coordinates:a,originX:e,originY:n,xScale:t.options.xScale||1,yScale:t.options.yScale||1})}else t.type===`rotate`&&(n=Rn(n,t.options.angle||0),a=n.geometry.type===`Polygon`?n.geometry.coordinates[0]:n.geometry.coordinates);if(a=a.map(e=>[I(e[0],this._adapter.getCoordinatePrecision()),I(e[1],this._adapter.getCoordinatePrecision())]),n.geometry.coordinates=n.geometry.type===`Polygon`?[a]:a,this._store.updateGeometry([{id:n.id,geometry:n.geometry}],{origin:`api`}),i.afterFeatureUpdated){i.afterFeatureUpdated(n);let e=n.properties[A.SELECTED],t=this.getSelectMode({switchToSelectMode:!1});t&&e&&t.afterFeatureUpdated(n)}}undo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.undo()}canUndo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.canUndo()}canRedo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.canRedo()}redo(){return this.checkEnabled(),!!this.undoRedoCoordinator&&this.undoRedoCoordinator.redo()}clearUndoRedoHistory(){this.checkEnabled(),this.undoRedoCoordinator&&this.undoRedoCoordinator.clearHistory()}addFeatures(e){return this.checkEnabled(),e.length===0?[]:this._store.load(e,e=>{if(tt(e)){let t=e.properties.mode,n=this._modes[t];if(!n)return{id:e.id,valid:!1,reason:`${t} mode is not in the list of instantiated modes`};let r=n.validateFeature.bind(n)(e);return{id:e.id,valid:r.valid,reason:r.reason?r.reason:r.valid?void 0:`Feature is invalid`}}return{id:e.id,valid:!1,reason:`Mode property does not exist`}},e=>{if(tt(e)){let t=this._modes[e.properties.mode];t&&t.afterFeatureAdded&&t.afterFeatureAdded(e)}},{origin:`api`})}start(){this._enabled||(this._enabled=!0,this._adapter.register({onReady:()=>{this._eventListeners.ready.forEach(e=>{e()})},getState:()=>this._mode.state,onClick:e=>{let t=this.drawingUndoRedo?this.drawingUndoRedo.getHistorySizes():{undoSize:0,redoSize:0};this._mode.onClick(e),this.emitDrawingPushIfHistoryChanged(t)},onMouseMove:e=>{this._mode.onMouseMove(e)},onKeyDown:e=>{this.handleUndoRedoKeyboardShortcut(e)||this._mode.onKeyDown(e)},onKeyUp:e=>{let t=this.drawingUndoRedo?this.drawingUndoRedo.getHistorySizes():{undoSize:0,redoSize:0};this._mode.onKeyUp(e),this.emitDrawingPushIfHistoryChanged(t)},onDragStart:(e,t)=>{this._mode.onDragStart(e,t)},onDrag:(e,t)=>{this._mode.onDrag(e,t)},onDragEnd:(e,t)=>{this._mode.onDragEnd(e,t)},onClear:()=>{this._mode.cleanUp(),this._store.clear({origin:`api`})}}))}getFeaturesAtLngLat(e,t){let{lng:n,lat:r}=e;return this.featuresAtLocation({lng:n,lat:r},t)}getFeaturesAtPointerEvent(e,t){let n=this._adapter.getLngLatFromEvent.bind(this._adapter)(e);return n===null?[]:this.featuresAtLocation(n,t)}stop(){this._enabled&&(this._enabled=!1,this._adapter.unregister())}on(e,t){let n=this._eventListeners[e];n.includes(t)||n.push(t)}off(e,t){let n=this._eventListeners[e];n.includes(t)&&n.splice(n.indexOf(t),1)}},qr=class extends kr.TerraDrawBaseAdapter{constructor(e){super(e),this._renderBeforeLayerId=void 0,this._prefixId=void 0,this._initialDragPan=void 0,this._initialDragRotate=void 0,this._nextRender=void 0,this._map=void 0,this._container=void 0,this.changedIds={deletion:!1,points:!1,linestrings:!1,polygons:!1,styling:!1},this._map=e.map,this._container=this._map.getContainer(),this._initialDragRotate=this._map.dragRotate.isEnabled(),this._initialDragPan=this._map.dragPan.isEnabled(),this._renderBeforeLayerId=e.renderBelowLayerId,this._prefixId=e.prefixId||`td`}hashCode(e){let t=0;for(let n=0;n<e.length;n++)t=(t<<5)-t+e.charCodeAt(n),t|=0;return Math.abs(t)}resizeImage(e,t,n,r){let i=new Image;i.crossOrigin=`anonymous`,i.onload=()=>{let e=document.createElement(`canvas`);e.width=t,e.height=n;let a=e.getContext(`2d`);if(!a)throw Error(`Could not get canvas context`);a.drawImage(i,0,0,t,n),r(e.toDataURL())},i.src=e}_addGeoJSONSource(e,t){this._map.addSource(e,{type:`geojson`,data:{type:`FeatureCollection`,features:t},tolerance:0})}_addFillLayer(e){return this._map.addLayer({id:e,source:e,type:`fill`,layout:{"fill-sort-key":[`get`,`zIndex`]},paint:{"fill-color":[`get`,`polygonFillColor`],"fill-opacity":[`get`,`polygonFillOpacity`]}})}_addFillOutlineLayer(e){return this._map.addLayer({id:e+`-outline`,source:e,type:`line`,layout:{"line-sort-key":[`get`,`zIndex`]},paint:{"line-width":[`get`,`polygonOutlineWidth`],"line-color":[`get`,`polygonOutlineColor`],"line-opacity":[`get`,`polygonOutlineOpacity`]}})}_addLineLayer(e){return this._map.addLayer({id:e,source:e,type:`line`,layout:{"line-sort-key":[`get`,`zIndex`]},paint:{"line-width":[`get`,`lineStringWidth`],"line-color":[`get`,`lineStringColor`],"line-opacity":[`get`,`lineStringOpacity`]}})}_addPointLayer(e){return this._map.addLayer({id:e,source:e,type:`circle`,layout:{"circle-sort-key":[`get`,`zIndex`]},paint:{"circle-stroke-color":[`get`,`pointOutlineColor`],"circle-stroke-width":[`get`,`pointOutlineWidth`],"circle-stroke-opacity":[`get`,`pointOutlineOpacity`],"circle-radius":[`get`,`pointWidth`],"circle-color":[`get`,`pointColor`],"circle-opacity":[`get`,`pointOpacity`]}})}_addMarkerLayer(e){return this._map.addLayer({id:e+`-marker`,source:e,type:`symbol`,filter:[`has`,`markerId`],layout:{"icon-image":[`image`,[`get`,`markerId`]],"icon-anchor":`bottom`,"icon-allow-overlap":!0}})}_addLayer(e,t){t===`Point`&&(this._addPointLayer(e),this._addMarkerLayer(e)),t===`LineString`&&this._addLineLayer(e),t===`Polygon`&&(this._addFillLayer(e),this._addFillOutlineLayer(e))}_addGeoJSONLayer(e,t){let n=`${this._prefixId}-${e.toLowerCase()}`;return this._addGeoJSONSource(n,t),this._addLayer(n,e),n}_setGeoJSONLayerData(e,t){let n=`${this._prefixId}-${e.toLowerCase()}`;return this._map.getSource(n).setData({type:`FeatureCollection`,features:t}),n}updateChangedIds(e){[...e.updated,...e.created].forEach(e=>{e.geometry.type===`Point`?this.changedIds.points=!0:e.geometry.type===`LineString`?this.changedIds.linestrings=!0:e.geometry.type===`Polygon`&&(this.changedIds.polygons=!0)}),e.deletedIds.length>0&&(this.changedIds.deletion=!0),e.created.length===0&&e.updated.length===0&&e.deletedIds.length===0&&(this.changedIds.styling=!0)}getLngLatFromEvent(e){let{left:t,top:n}=this._container.getBoundingClientRect();return this.unproject(e.clientX-t,e.clientY-n)}getMapEventElement(){return this._map.getCanvas()}setDraggability(e){e?(this._initialDragRotate&&this._map.dragRotate.enable(),this._initialDragPan&&this._map.dragPan.enable()):(this._initialDragRotate&&this._map.dragRotate.disable(),this._initialDragPan&&this._map.dragPan.disable())}project(e,t){let{x:n,y:r}=this._map.project({lng:e,lat:t});return{x:n,y:r}}unproject(e,t){let{lng:n,lat:r}=this._map.unproject({x:e,y:t});return{lng:n,lat:r}}setCursor(e){let t=this._map.getCanvas();e===`unset`?t.style.removeProperty(`cursor`):t.style.cursor=e}setDoubleClickToZoom(e){e?this._map.doubleClickZoom.enable():this._map.doubleClickZoom.disable()}render(e,t){this.updateChangedIds(e),this._nextRender&&cancelAnimationFrame(this._nextRender),this._nextRender=requestAnimationFrame(()=>{if(!this._currentModeCallbacks)return;let n=[...e.created,...e.updated,...e.unchanged],r=[],i=[],a=[];for(let e=0;e<n.length;e++){let o=n[e],{properties:s}=o,c=t[s.mode](o);if(s.zIndex=c.zIndex,s.zIndex=c.zIndex,o.geometry.type===`Point`){s.pointColor=c.pointColor,s.pointOutlineColor=c.pointOutlineColor,s.pointOutlineWidth=c.pointOutlineWidth;let e=c.pointOutlineOpacity;s.pointOutlineOpacity=e===void 0?1:e,s.pointWidth=c.pointWidth;let t=c.pointOpacity;if(s.pointOpacity=t===void 0?1:t,c.markerUrl&&c.markerWidth&&c.markerHeight){let e=`marker-${this.hashCode(c.markerUrl)}`;this._map.hasImage(e)||this.resizeImage(c.markerUrl,c.markerWidth,c.markerHeight,t=>{this._map.loadImage(t).then(t=>{this._map.hasImage(e)||this._map.addImage(e,t.data)})}),s.markerId=e,s.pointWidth=0}r.push(o)}else if(o.geometry.type===`LineString`){s.lineStringColor=c.lineStringColor,s.lineStringWidth=c.lineStringWidth;let e=c.lineStringOpacity;s.lineStringOpacity=e===void 0?1:e,i.push(o)}else if(o.geometry.type===`Polygon`){let e=c.polygonOutlineOpacity;s.polygonFillColor=c.polygonFillColor,s.polygonFillOpacity=c.polygonFillOpacity,s.polygonOutlineOpacity=e===void 0?1:e,s.polygonOutlineColor=c.polygonOutlineColor,s.polygonOutlineWidth=c.polygonOutlineWidth,a.push(o)}}let o=this.changedIds.deletion||this.changedIds.styling,s=o||this.changedIds.linestrings,c=o||this.changedIds.polygons;(o||this.changedIds.points)&&this._setGeoJSONLayerData(`Point`,r),s&&this._setGeoJSONLayerData(`LineString`,i),c&&this._setGeoJSONLayerData(`Polygon`,a),this.changedIds={points:!1,linestrings:!1,polygons:!1,deletion:!1,styling:!1}})}clear(){this._currentModeCallbacks&&(this._currentModeCallbacks.onClear(),this._nextRender&&=(cancelAnimationFrame(this._nextRender),void 0),this._setGeoJSONLayerData(`Point`,[]),this._setGeoJSONLayerData(`LineString`,[]),this._setGeoJSONLayerData(`Polygon`,[]))}getCoordinatePrecision(){return super.getCoordinatePrecision()}unregister(){super.unregister(),this.changedIds={points:!1,linestrings:!1,polygons:!1,deletion:!1,styling:!1},this._map.removeLayer(`${this._prefixId}-point`),this._map.removeLayer(`${this._prefixId}-point-marker`),this._map.removeSource(`${this._prefixId}-point`),this._map.removeLayer(`${this._prefixId}-linestring`),this._map.removeSource(`${this._prefixId}-linestring`),this._map.removeLayer(`${this._prefixId}-polygon`),this._map.removeLayer(`${this._prefixId}-polygon-outline`),this._map.removeSource(`${this._prefixId}-polygon`)}register(e){var t;super.register(e);let n=this._addGeoJSONLayer(`Polygon`,[]),r=this._addGeoJSONLayer(`LineString`,[]),i=this._addGeoJSONLayer(`Point`,[]);var a;this._renderBeforeLayerId&&(this._map.moveLayer(i,this._renderBeforeLayerId),this._map.moveLayer(r,i),this._map.moveLayer(`${n}-outline`,r),this._map.moveLayer(n,`${n}-outline`)),(t=this._currentModeCallbacks)!=null&&t.onReady&&((a=this._currentModeCallbacks)==null||a.onReady())}},Jr={modes:[`render`,`point`,`marker`,`linestring`,`polygon`,`rectangle`,`angled-rectangle`,`sensor`,`sector`,`circle`,`freehand`,`freehand-linestring`,`select`,`delete-selection`,`delete`,`undo`,`redo`,`download`],open:!1},Yr={modes:[`render`,`point`,`marker`,`linestring`,`polygon`,`rectangle`,`angled-rectangle`,`sensor`,`sector`,`circle`,`freehand`,`freehand-linestring`,`select`,`delete-selection`,`delete`,`undo`,`redo`,`download`],open:!1,modeOptions:{point:new vn({editable:!0,styles:{pointColor:`#FFFFFF`,pointWidth:5,pointOutlineColor:`#666666`,pointOutlineWidth:1}}),marker:new Fr({editable:!0,styles:{markerUrl:`data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'%20standalone='no'?%3e%3csvg%20xmlns:dc='http://purl.org/dc/elements/1.1/'%20xmlns:cc='http://creativecommons.org/ns%23'%20xmlns:rdf='http://www.w3.org/1999/02/22-rdf-syntax-ns%23'%20xmlns:svg='http://www.w3.org/2000/svg'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:sodipodi='http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd'%20xmlns:inkscape='http://www.inkscape.org/namespaces/inkscape'%20inkscape:version='1.0%20(4035a4fb49,%202020-05-01)'%20sodipodi:docname='poi.svg'%20id='svg4460'%20height='100'%20width='100'%20version='1.1'%3e%3csodipodi:namedview%20inkscape:document-rotation='0'%20inkscape:current-layer='svg4460'%20inkscape:window-maximized='1'%20inkscape:window-y='-8'%20inkscape:window-x='-8'%20inkscape:cy='70.031285'%20inkscape:cx='-78.460726'%20inkscape:zoom='2.02'%20showgrid='false'%20id='namedview11'%20inkscape:window-height='1017'%20inkscape:window-width='1920'%20inkscape:pageshadow='2'%20inkscape:pageopacity='0'%20guidetolerance='10'%20gridtolerance='10'%20objecttolerance='10'%20borderopacity='1'%20bordercolor='%23666666'%20pagecolor='%23ffffff'%20/%3e%3cdefs%20id='defs4462'%20/%3e%3cmetadata%20id='metadata4465'%3e%3crdf:RDF%3e%3ccc:Work%20rdf:about=''%3e%3cdc:format%3eimage/svg+xml%3c/dc:format%3e%3cdc:type%20rdf:resource='http://purl.org/dc/dcmitype/StillImage'%20/%3e%3cdc:title%3e%3c/dc:title%3e%3c/cc:Work%3e%3c/rdf:RDF%3e%3c/metadata%3e%3cpath%20d='M%2050.001528,3.3861402e-7%20C%2030.763177,3.3861402e-7%2015,15.718144%2015,34.901534%20c%200,7.432782%202.373565,14.339962%206.391689,20.019029%20l%2024.338528,42.073163%20c%203.40849,4.452814%205.674917,3.607154%208.509014,-0.23458%20L%2081.083105,51.075788%20C%2081.625418,50.0948%2082.050328,49.050173%2082.421327,47.983517%2084.078241,43.936622%2085.000002,39.521943%2085,34.901534%2085,15.718144%2069.23988,3.3861402e-7%2050.001528,3.3861402e-7%20Z%20m%200,16.35400066138598%20c%2010.359296,0%2018.597616,8.21783%2018.597618,18.547533%200,10.329703%20-8.238322,18.544487%20-18.597618,18.544487%20-10.359299,0%20-18.600672,-8.214784%20-18.600672,-18.544487%200,-10.329703%208.241373,-18.547533%2018.600672,-18.547533%20z'%20style='fill:rgb(95,%2099,%20104);stroke-width:4.26019'%20id='path4135'%20/%3e%3c/svg%3e`,markerWidth:27,markerHeight:27}}),linestring:new dn({editable:!0,styles:{lineStringColor:`#666666`,lineStringWidth:2,closingPointColor:`#FFFFFF`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),polygon:new xn({editable:!0,styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2,closingPointColor:`#FAFAFA`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),rectangle:new wn({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),"angled-rectangle":new br({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),circle:new jt({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),freehand:new Ft({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2,closingPointColor:`#FAFAFA`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),"freehand-linestring":new Mr({styles:{lineStringColor:`#666666`,lineStringWidth:2,closingPointColor:`#FFFFFF`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),sensor:new Dr({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2,centerPointColor:`#FAFAFA`,centerPointWidth:3,centerPointOutlineColor:`#666666`,centerPointOutlineWidth:1}}),sector:new wr({styles:{fillColor:`#EDEFF0`,fillOpacity:.7,outlineColor:`#666666`,outlineWidth:2}}),select:new Kn({flags:{point:{feature:{draggable:!1}},marker:{feature:{draggable:!1}},polygon:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},linestring:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},freehand:{feature:{draggable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},"freehand-linestring":{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},circle:{feature:{draggable:!0,coordinates:{resizable:`center`,deletable:!1,midpoints:!1}}},rectangle:{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},"angled-rectangle":{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},sensor:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},sector:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}}}})},pointLayerLabelSpec:{id:`{prefix}-point-label`,type:`symbol`,source:`{prefix}-point`,filter:[`all`,[`==`,`$type`,`Point`],[`any`,[`==`,`mode`,`point`],[`==`,`mode`,`marker`]]],layout:{"text-field":[`case`,[`all`,[`has`,`elevation`],[`>`,[`get`,`elevation`],0]],[`concat`,`Alt. `,[`to-string`,[`floor`,[`get`,`elevation`]]],` `,[`get`,`elevationUnit`]],``],"symbol-placement":`point`,"text-size":[`interpolate`,[`linear`],[`zoom`],5,10,10,12,13,14,14,16,18,18],"text-overlap":`always`,"text-variable-anchor":[`left`,`right`,`top`,`bottom`],"text-radial-offset":.5,"text-justify":`center`,"text-letter-spacing":.05},paint:{"text-halo-color":`#F7F7F7`,"text-halo-width":2,"text-color":`#232E3D`}},lineLayerLabelSpec:{id:`{prefix}-line-label`,type:`symbol`,source:`{prefix}-line-source`,filter:[`==`,`$type`,`Point`],layout:{"text-field":[`concat`,[`to-string`,[`get`,`distance`]],` `,[`get`,`unit`],[`case`,[`==`,[`get`,`total`],0],``,[`concat`,`
|
|
2
2
|
(`,[`to-string`,[`get`,`total`]],` `,[`get`,`totalUnit`],`)`]],[`case`,[`all`,[`has`,`elevation`],[`>`,[`get`,`elevation`],0]],[`concat`,`
|
|
3
3
|
Alt. `,[`to-string`,[`floor`,[`get`,`elevation`]]],` `,[`get`,`elevationUnit`]],``]],"symbol-placement":`point`,"text-size":[`interpolate`,[`linear`],[`zoom`],5,10,10,12,13,14,14,16,18,18],"text-overlap":`always`,"text-variable-anchor":[`left`,`right`,`top`,`bottom`],"text-radial-offset":.5,"text-justify":`center`,"text-letter-spacing":.05},paint:{"text-halo-color":`#F7F7F7`,"text-halo-width":2,"text-color":`#232E3D`}},routingLineLayerNodeSpec:{id:`{prefix}-line-node`,type:`circle`,source:`{prefix}-line-source`,filter:[`==`,`$type`,`Point`],layout:{},paint:{"circle-radius":3,"circle-color":`#FFFFFF`,"circle-stroke-color":`#000000`,"circle-stroke-width":1}},polygonLayerSpec:{id:`{prefix}-polygon-label`,type:`symbol`,source:`{prefix}-polygon-source`,filter:[`==`,`$type`,`Point`],layout:{"text-field":[`concat`,[`to-string`,[`get`,`area`]],` `,[`get`,`unit`]],"symbol-placement":`point`,"text-size":[`interpolate`,[`linear`],[`zoom`],5,10,10,12,13,14,14,16,18,18],"text-overlap":`always`,"text-letter-spacing":.05},paint:{"text-halo-color":`#F7F7F7`,"text-halo-width":2,"text-color":`#232E3D`}},computeElevation:!1,terrainSource:{url:`https://tiles.mapterhorn.com/{z}/{x}/{y}.webp`,encoding:`terrarium`,tileSize:512,minzoom:0,maxzoom:12,tms:!1},measureUnitType:`metric`,distancePrecision:2,distanceUnit:void 0,areaPrecision:2,areaUnit:void 0,measureUnitSymbols:JSON.parse(JSON.stringify({kilometer:`km`,meter:`m`,centimeter:`cm`,mile:`mi`,foot:`ft`,inch:`in`,"square meters":`m²`,"square kilometers":`km²`,ares:`a`,hectares:`ha`,"square feet":`ft²`,"square yards":`yd²`,acres:`acres`,"square miles":`mi²`})),elevationCacheConfig:{enabled:!0,maxSize:1e3,ttl:3600*1e3,precision:9},adapterOptions:{prefixId:`td-measure`}},Z={modes:[`render`,`routing`,`time-isochrone`,`distance-isochrone`,`select`,`delete-selection`,`delete`,`download`,`settings`],open:!1,modeOptions:{"time-isochrone":new vn({modeName:`time-isochrone`,editable:!1,styles:{pointColor:`#FFFFFF`,pointWidth:5,pointOutlineColor:`#666666`,pointOutlineWidth:1}}),"distance-isochrone":new vn({modeName:`distance-isochrone`,editable:!1,styles:{pointColor:`#FFFFFF`,pointWidth:5,pointOutlineColor:`#666666`,pointOutlineWidth:1}}),routing:new dn({modeName:`routing`,editable:!1,styles:{lineStringColor:`#FF0000`,lineStringWidth:2,closingPointColor:`#FF0000`,closingPointWidth:3,closingPointOutlineColor:`#666666`,closingPointOutlineWidth:1}}),select:new Kn({flags:{"time-isochrone":{feature:{draggable:!1}},"distance-isochrone":{feature:{draggable:!1}},routing:{feature:{draggable:!1,rotateable:!1,scaleable:!1,coordinates:{midpoints:!1,draggable:!1,deletable:!1}}}}}),settings:new q({modeName:`settings`,styles:{}})},valhallaOptions:{url:``,routingOptions:{costingModel:`auto`,distanceUnit:`kilometers`},isochroneOptions:{timeCostingModel:`auto`,distanceCostingModel:`auto`,contours:[{time:3,distance:1,color:`#ff0000`},{time:5,distance:2,color:`#ffff00`},{time:10,distance:3,color:`#0000ff`},{time:15,distance:4,color:`#ff00ff`}]}},adapterOptions:{prefixId:`td-valhalla`},routingLineLayerNodeLabelSpec:{id:`{prefix}-routing-node-label`,type:`symbol`,source:`{prefix}-routing-source`,filter:[`==`,`$type`,`Point`],layout:{"text-field":[`case`,[`all`,[`has`,`distance`],[`has`,`distance_unit`],[`has`,`time`]],[`concat`,[`to-string`,[`get`,`text`]],`
|
|
4
4
|
`,[`to-string`,[`/`,[`round`,[`*`,[`get`,`distance`],10]],10]],[`to-string`,[`get`,`distance_unit`]],`
|
|
5
5
|
`,[`to-string`,[`get`,`time`]],`min`],[`all`,[`has`,`costingModel`]],[`concat`,[`to-string`,[`get`,`text`]],`
|
|
6
|
-
(`,[`to-string`,[`get`,`costingModel`]],`)`],[`concat`,[`to-string`,[`get`,`text`]]]],"symbol-placement":`point`,"text-size":[`interpolate`,[`linear`],[`zoom`],5,10,10,12,13,14,14,16,18,18],"text-overlap":`always`,"text-variable-anchor":[`left`,`right`,`top`,`bottom`],"text-radial-offset":.5,"text-justify":`left`,"text-letter-spacing":.05},paint:{"text-halo-color":`#F7F7F7`,"text-halo-width":2,"text-color":`#232E3D`}},routingLineLayerNodeSpec:{id:`{prefix}-routing-node`,type:`circle`,source:`{prefix}-routing-source`,filter:[`==`,`$type`,`Point`],layout:{},paint:{"circle-radius":3,"circle-color":[`case`,[`==`,[`get`,`text`],`Start`],`#0000FF`,[`==`,[`get`,`text`],`Goal`],`#FFFF00`,`#FFFFFF`],"circle-stroke-color":`#000000`,"circle-stroke-width":1}},timeIsochronePolygonLayerSpec:{id:`{prefix}-time-isochrone-polygon`,type:`fill`,source:`{prefix}-time-isochrone-source`,layout:{},paint:{"fill-color":[`get`,`fillColor`],"fill-opacity":[`get`,`fillOpacity`]}},timeIsochroneLineLayerSpec:{id:`{prefix}-time-isochrone-line`,type:`line`,source:`{prefix}-time-isochrone-source`,layout:{"line-join":`round`,"line-cap":`round`},paint:{"line-color":[`get`,`fillColor`],"line-width":3}},timeIsochroneLabelLayerSpec:{id:`{prefix}-time-isochrone-label`,type:`symbol`,source:`{prefix}-time-isochrone-source`,layout:{"symbol-placement":`line`,"text-pitch-alignment":`viewport`,"text-field":[`concat`,[`get`,`contour`],` `,`min`],"text-size":12,"symbol-spacing":100,"text-max-angle":45},paint:{"text-color":`rgb(0, 0, 0)`,"text-halo-width":1,"text-halo-color":`rgb(255, 255, 255)`}},distanceIsochronePolygonLayerSpec:{id:`{prefix}-distance-isochrone-polygon`,type:`fill`,source:`{prefix}-distance-isochrone-source`,layout:{},paint:{"fill-color":[`get`,`fillColor`],"fill-opacity":[`get`,`fillOpacity`]}},distanceIsochroneLineLayerSpec:{id:`{prefix}-distance-isochrone-line`,type:`line`,source:`{prefix}-distance-isochrone-source`,layout:{"line-join":`round`,"line-cap":`round`},paint:{"line-color":[`get`,`fillColor`],"line-width":3}},distanceIsochroneLabelLayerSpec:{id:`{prefix}-distance-isochrone-label`,type:`symbol`,source:`{prefix}-distance-isochrone-source`,layout:{"symbol-placement":`line`,"text-pitch-alignment":`viewport`,"text-field":[`concat`,[`get`,`contour`],` `,`km`],"text-size":12,"symbol-spacing":100,"text-max-angle":45},paint:{"text-color":`rgb(0, 0, 0)`,"text-halo-width":1,"text-halo-color":`rgb(255, 255, 255)`}}},Xr=`data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'%20standalone='no'?%3e%3csvg%20xmlns:dc='http://purl.org/dc/elements/1.1/'%20xmlns:cc='http://creativecommons.org/ns%23'%20xmlns:rdf='http://www.w3.org/1999/02/22-rdf-syntax-ns%23'%20xmlns:svg='http://www.w3.org/2000/svg'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:sodipodi='http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd'%20xmlns:inkscape='http://www.inkscape.org/namespaces/inkscape'%20inkscape:version='1.0%20(4035a4fb49,%202020-05-01)'%20sodipodi:docname='poi.svg'%20id='svg4460'%20height='100'%20width='100'%20version='1.1'%3e%3csodipodi:namedview%20inkscape:document-rotation='0'%20inkscape:current-layer='svg4460'%20inkscape:window-maximized='1'%20inkscape:window-y='-8'%20inkscape:window-x='-8'%20inkscape:cy='70.031285'%20inkscape:cx='-78.460726'%20inkscape:zoom='2.02'%20showgrid='false'%20id='namedview11'%20inkscape:window-height='1017'%20inkscape:window-width='1920'%20inkscape:pageshadow='2'%20inkscape:pageopacity='0'%20guidetolerance='10'%20gridtolerance='10'%20objecttolerance='10'%20borderopacity='1'%20bordercolor='%23666666'%20pagecolor='%23ffffff'%20/%3e%3cdefs%20id='defs4462'%20/%3e%3cmetadata%20id='metadata4465'%3e%3crdf:RDF%3e%3ccc:Work%20rdf:about=''%3e%3cdc:format%3eimage/svg+xml%3c/dc:format%3e%3cdc:type%20rdf:resource='http://purl.org/dc/dcmitype/StillImage'%20/%3e%3cdc:title%3e%3c/dc:title%3e%3c/cc:Work%3e%3c/rdf:RDF%3e%3c/metadata%3e%3cpath%20d='M%2050.001528,3.3861402e-7%20C%2030.763177,3.3861402e-7%2015,15.718144%2015,34.901534%20c%200,7.432782%202.373565,14.339962%206.391689,20.019029%20l%2024.338528,42.073163%20c%203.40849,4.452814%205.674917,3.607154%208.509014,-0.23458%20L%2081.083105,51.075788%20C%2081.625418,50.0948%2082.050328,49.050173%2082.421327,47.983517%2084.078241,43.936622%2085.000002,39.521943%2085,34.901534%2085,15.718144%2069.23988,3.3861402e-7%2050.001528,3.3861402e-7%20Z%20m%200,16.35400066138598%20c%2010.359296,0%2018.597616,8.21783%2018.597618,18.547533%200,10.329703%20-8.238322,18.544487%20-18.597618,18.544487%20-10.359299,0%20-18.600672,-8.214784%20-18.600672,-18.544487%200,-10.329703%208.241373,-18.547533%2018.600672,-18.547533%20z'%20style='fill:%233FB1CE;stroke-width:4.26019'%20id='path4135'%20/%3e%3c/svg%3e`,Zr=(e,t)=>{let n=t.updateType;return n===`finish`||n===`commit`?gr(e):{valid:!0}},Qr=()=>({render:new q({modeName:`render`,styles:{}}),point:new vn({editable:!0}),marker:new Fr({editable:!0,styles:{markerUrl:Xr,markerWidth:27,markerHeight:27}}),linestring:new dn({editable:!0}),polygon:new xn({editable:!0,validation:Zr}),rectangle:new wn,"angled-rectangle":new br,circle:new jt,freehand:new Ft,"freehand-linestring":new Mr,sensor:new Dr,sector:new wr,select:new Kn({flags:{point:{feature:{draggable:!0}},marker:{feature:{draggable:!0}},polygon:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},linestring:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},freehand:{feature:{draggable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},"freehand-linestring":{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},circle:{feature:{draggable:!0,coordinates:{resizable:`center`,deletable:!1,midpoints:!1}}},rectangle:{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},"angled-rectangle":{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},sensor:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},sector:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}}}}),delete:new q({modeName:`delete`,styles:{}}),"delete-selection":new q({modeName:`delete-selection`,styles:{}}),download:new q({modeName:`download`,styles:{}}),undo:new q({modeName:`undo`,styles:{}}),redo:new q({modeName:`redo`,styles:{}})}),Q=6371008.8;Q*100,Q*100,360/(2*Math.PI),Q*3.28084,Q*39.37,Q/1e3,Q/1e3,Q/1609.344,Q*1e3,Q*1e3,Q/1852,Q*1.0936,Q*Q/2,Math.PI/180;var $r=e=>e.charAt(0).toUpperCase()+e.slice(1),ei=[`{prefix}-point`,`{prefix}-point-lower`,`{prefix}-linestring`,`{prefix}-polygon`,`{prefix}-polygon-outline`];[...ei,Yr.polygonLayerSpec?.source,Yr.lineLayerLabelSpec?.source],[...ei,Z.routingLineLayerNodeLabelSpec?.source,Z.routingLineLayerNodeSpec?.source,Z.timeIsochronePolygonLayerSpec?.source,Z.timeIsochroneLineLayerSpec?.source,Z.timeIsochroneLabelLayerSpec?.source,Z.distanceIsochronePolygonLayerSpec?.source,Z.distanceIsochroneLineLayerSpec?.source,Z.distanceIsochroneLabelLayerSpec?.source];var ti=(e,t,n=ei,r=`td`)=>{n=n.map(e=>e.replace(`{prefix}`,r));let i=JSON.parse(JSON.stringify(e));return t&&(t.onlyTerraDrawLayers===!0?(i.layers=i.layers.filter(e=>`source`in e&&n.includes(e.source)),Object.keys(i.sources).forEach(e=>{n.includes(e)||delete i.sources[e]})):t.excludeTerraDrawLayers===!0&&(i.layers=i.layers.filter(e=>`source`in e&&!n.includes(e.source)||e.type===`background`),Object.keys(i.sources).forEach(e=>{n.includes(e)&&delete i.sources[e]}))),i},ni=class{className;dialog;title;constructor(e,t){this.className=e,this.title=t}create(e,t){let n=document.getElementsByClassName(this.className);n.length>0&&Array.from(n).forEach(e=>{e.remove()}),this.dialog=document.createElement(`dialog`),this.dialog.classList.add(this.className);let r=document.createElement(`div`);r.classList.add(`dialog-header`);let i=document.createElement(`h3`);i.textContent=this.title,i.classList.add(`dialog-title`),r.appendChild(i);let a=document.createElement(`button`);a.type=`button`,a.classList.add(`close-button`),a.innerHTML=`×`,a.setAttribute(`aria-label`,`Close dialog`),a.addEventListener(`click`,()=>{this.close()}),r.appendChild(a),this.dialog.appendChild(r);let o=document.createElement(`div`);o.classList.add(`content`),this.dialog.appendChild(t(o)),this.dialog.addEventListener(`click`,e=>{let t=e.target?.getBoundingClientRect();t&&(t.left>e.clientX||t.right<e.clientX||t.top>e.clientY||t.bottom<e.clientY)&&this.close()}),e.appendChild(this.dialog)}open(){this.dialog?.showModal()}close(){this.dialog?.close()}createSegmentButtons(e,t,n=()=>{}){let r=document.createElement(`div`);return r.classList.add(`segment-buttons`),e.forEach(e=>{let i=document.createElement(`button`);i.type=`button`,i.classList.add(`segment-button`),i.value=e.value,i.textContent=e.label,e.value===t&&i.classList.add(`active`),i.addEventListener(`click`,()=>{r.querySelectorAll(`.segment-button`).forEach(e=>e.classList.remove(`active`)),i.classList.add(`active`),n(i.value)}),r.appendChild(i)}),r}};2*Math.PI*6378137/2;var ri=class{controlContainer;map;modeButtons={};_isExpanded=!1;_cssPrefix=``;get isExpanded(){return this._isExpanded}get cssPrefix(){return this._cssPrefix}set isExpanded(e){this._isExpanded=e;let t=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-control`);for(let e=0;e<t.length;e++){let n=t.item(e);n&&(this.isExpanded?n.classList.remove(`hidden`):n.classList.add(`hidden`))}let n=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}render-button`);n&&n.length>0&&(this.isExpanded?n.item(0)?.classList.add(`enabled`):(n.item(0)?.classList.remove(`enabled`),this.resetActiveMode())),this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature(),this.isExpanded?this.dispatchEvent(`expanded`):this.dispatchEvent(`collapsed`)}get showDeleteConfirmation(){return this.options.showDeleteConfirmation===!0}set showDeleteConfirmation(e){this.options.showDeleteConfirmation=e}terradraw;options;events={};defaultMode=`render`;constructor(e){this.modeButtons={},this.options={...Jr,modes:[...Jr.modes??[]],...e};let t=this.options.adapterOptions?.prefixId??`td`;this.options.adapterOptions||(this.options.adapterOptions={}),this.options.adapterOptions?.prefixId||(this.options.adapterOptions.prefixId=t),this.options.undoRedo||(this.options.undoRedo={modeLevel:new Ur({maxStackSize:100}),sessionLevel:new Wr({maxStackSize:100}),keyboardShortcuts:new zr})}getDefaultPosition(){return`top-right`}onAdd(e){if(this.options&&this.options.modes&&this.options.modes.length===0)throw Error(`At least a mode must be enabled.`);this.map=e;let t=Qr(),n=[];return this.options?.modes?.forEach(e=>{if(this.options.modeOptions&&this.options.modeOptions[e]){let r=this.options.modeOptions[e];if(e===`select`){let n=t[e];if(n){let e=n.flags;Object.keys(e).forEach(t=>{r.flags[t]||(r.flags[t]=e[t])})}}n.push(r)}else t[e]&&n.push(t[e])}),n.forEach(e=>{e.state!==`unregistered`&&(e._state=`unregistered`)}),this.options?.modes?.includes(`render`)||(n.push(new q({modeName:`default`,styles:{}})),this.defaultMode=`default`),this.isExpanded=this.options.open===!0,this.terradraw=new Kr({adapter:new qr({map:e,...this.options.adapterOptions}),modes:n,undoRedo:this.options.undoRedo}),this.map?.loaded()?this.terradraw.start():this.map?.once(`load`,()=>{this.terradraw?.start()}),this.controlContainer=document.createElement(`div`),this.controlContainer.classList.add(`maplibregl-ctrl`),this.controlContainer.classList.add(`maplibregl-ctrl-group`),n.forEach(e=>{e.mode!==`default`&&this.addTerradrawButton(e.mode)}),Object.values(this.modeButtons).forEach(e=>{this.controlContainer?.appendChild(e)}),this.toggleButtonsWhenNoFeature(),this.terradraw?.on(`finish`,this.toggleButtonsWhenNoFeature.bind(this)),this.terradraw?.on(`history`,this.handleHistoryChange.bind(this)),this.map.once(`idle`,()=>{this.toggleButtonsWhenNoFeature()}),this.controlContainer}onRemove(){!this.controlContainer||!this.controlContainer.parentNode||!this.map||(this.deactivate(),this.modeButtons={},this.terradraw=void 0,this.map=void 0,this.controlContainer.parentNode.removeChild(this.controlContainer))}on(e,t){this.events[e]?this.events[e].push(t):this.events[e]=[t]}off(e,t){if(!this.events[e])return;let n=this.events[e].findIndex(e=>e===t);n!==-1&&this.events[e].splice(n,1)}dispatchEvent(e,t){this.events[e]&&this.events[e].forEach(e=>{let n=(this.terradraw?.getSnapshot())?.filter(e=>e.properties.selected===!0);e({feature:n,mode:this.terradraw?.getMode(),...t})})}activate(){this.terradraw&&(this.terradraw.enabled||this.terradraw.start())}deactivate(){this.terradraw&&this.terradraw.enabled&&(this.resetActiveMode(),this.dispatchEvent(`mode-changed`),this.terradraw.stop())}handleModeChange(e,t){let n=t.setMode(e);return this.syncButtonStates(e),e!==this.defaultMode&&this.activate(),this.dispatchEvent(`mode-changed`),n}syncButtonStates(e){if(!this.controlContainer)return;let t=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-control`);for(let e=0;e<t.length;e++){let n=t.item(e);n&&n.classList.remove(`active`)}if(e!==this.defaultMode&&e!==`render`){let t=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-${e}-button`);t&&t.length>0&&t[0].classList.add(`active`)}this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature()}getTerraDrawInstance(){return this.terradraw?new Proxy(this.terradraw,{get:(e,t,n)=>t===`setMode`?t=>this.handleModeChange(t,e):t===`clearUndoRedoHistory`?()=>{e.clearUndoRedoHistory(),this.handleHistoryChange({undoSize:0,redoSize:0})}:Reflect.get(e,t,n)}):this.terradraw}handleHistoryChange(e){if(!this.controlContainer)return;let t=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}undo-button`);for(let n=0;n<t.length;n++){let r=t.item(n);r&&(r.disabled=e.undoSize===0)}let n=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}redo-button`);for(let t=0;t<n.length;t++){let r=n.item(t);r&&(r.disabled=e.redoSize===0)}}toggleEditor(){this.terradraw&&(this.isExpanded=!this.isExpanded)}resetActiveMode(){this.terradraw&&(this.terradraw.enabled||this.terradraw.start(),this.terradraw?.setMode(this.defaultMode),this.syncButtonStates(this.defaultMode))}addTerradrawButton(e){let t=document.createElement(`button`);t.type=`button`,this.modeButtons[e]=t,e===`render`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),this.isExpanded&&t.classList.add(`enabled`),t.type=`button`,t.title=$r(`expand or collapse drawing tool`),t.addEventListener(`click`,this.toggleEditor.bind(this))):(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}add-control`),this.isExpanded||t.classList.add(`hidden`),t.title=$r(e.replace(/-/g,` `)),e===`delete`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.addEventListener(`click`,this.handleDeleteAllFeatures.bind(this))):e===`delete-selection`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.classList.add(`hidden-delete-selection`),t.addEventListener(`click`,this.handleDeleteSelectedFeatures.bind(this))):e===`download`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.addEventListener(`click`,this.handleDownload.bind(this))):[`undo`,`redo`].includes(e)?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.disabled=!0,t.addEventListener(`click`,()=>{this.terradraw&&(e===`undo`?this.terradraw.undo():this.terradraw.redo())})):(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}add-${e}-button`),t.addEventListener(`click`,()=>{if(!this.terradraw)return;let n=t.classList.contains(`active`);this.activate(),this.resetActiveMode(),n||(this.terradraw.setMode(e),this.syncButtonStates(e)),this.dispatchEvent(`mode-changed`)})))}getFeatures(e=!1){if(!this.terradraw)return;let t={type:`FeatureCollection`,features:(this.terradraw?.getSnapshot()).filter(e=>e.properties.mode!==`select`)};return e===!0&&(t.features=t.features.filter(e=>e.properties.selected===!0)),t}cleanStyle(e,t){return ti(e,t,ei,this.options.adapterOptions?.prefixId)}showDeleteConfirmationDialog(e){let t=new ni(`maplibre-terradraw-delete-confirmation-dialog`,`Delete All Features`);t.create(document.body,n=>{let r=document.createElement(`p`);r.textContent=`Are you sure you want to delete all features?`,n.appendChild(r);let i=document.createElement(`div`);i.classList.add(`dialog-buttons`);let a=document.createElement(`button`);a.type=`button`,a.textContent=`Cancel`,a.classList.add(`dialog-button-cancel`),a.addEventListener(`click`,()=>{t.close()});let o=document.createElement(`button`);return o.type=`button`,o.textContent=`Delete`,o.classList.add(`dialog-button-delete`),o.addEventListener(`click`,()=>{e(),t.close()}),i.appendChild(a),i.appendChild(o),n.appendChild(i),n}),t.open()}handleDeleteAllFeatures(){if(!this.terradraw||!this.terradraw.enabled)return;let e=()=>{this.terradraw?.clear(),this.resetActiveMode(),this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature(),this.dispatchEvent(`feature-deleted`)};this.options.showDeleteConfirmation===!0?this.showDeleteConfirmationDialog(e):e()}handleDeleteSelectedFeatures(){if(!this.terradraw||!this.terradraw.enabled)return;let e=(this.terradraw?.getSnapshot()).filter(e=>e.properties.selected===!0);if(e.length>0){let t=e.map(e=>e.id);this.terradraw.removeFeatures(t);for(let e of t)this.terradraw.deselectFeature(e);this.dispatchEvent(`feature-deleted`,{deletedIds:t})}this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature()}handleDownload(){let e=this.getFeatures(!1),t=`data:application/json;charset=utf-8,`+encodeURIComponent(JSON.stringify(e)),n=document.createElement(`a`);n.setAttribute(`href`,t),n.setAttribute(`download`,`data.geojson`),document.body.appendChild(n),n.click(),n.remove()}toggleButtonsWhenNoFeature(){if(!this.controlContainer)return;let e=(this.terradraw?.getSnapshot())?.filter(e=>e.properties.mode!==`select`),t=!!(e&&e.length>0),n=[`maplibregl-terradraw-${this.cssPrefix}add-select-button`,`maplibregl-terradraw-${this.cssPrefix}download-button`,`maplibregl-terradraw-${this.cssPrefix}delete-button`];for(let e of n){let n=this.controlContainer.getElementsByClassName(e);for(let e=0;e<n.length;e++){let r=n.item(e);r&&(r.disabled=!t)}}}toggleDeleteSelectionButton(){let e=this.terradraw?.enabled||!1,t=this.terradraw?.getMode(),n=this.getFeatures(!1),r=n&&n.features.length>0,i=r&&e&&t===`select`,a=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}delete-selection-button`);for(let e=0;e<a.length;e++){let t=a.item(e);t&&(i?t.classList.remove(`hidden-delete-selection`):t.classList.add(`hidden-delete-selection`))}if(!r){let e=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-select-button`);for(let t=0;t<e.length;t++){let n=e.item(t);n&&n.classList.remove(`active`)}}}clearExtendedFeatures(e,t=void 0){if(this.map)for(let n of e){let e=this.map.getStyle().sources[n];e&&typeof e.data!=`string`&&e.data.type===`FeatureCollection`&&(t===void 0?e.data.features=[]:e.data.features=e.data.features.filter(e=>e.properties?.originalId?!t.includes(e.properties.originalId):!t.includes(e.id)),this.map.getSource(n)?.setData(e.data))}}},ii={base:Fe,ctc:we,graph:Ge,geojson:Ye,draw:class{drawControl=null;mapInstance;onFinishCallback;onChangeCallback;onDeleteCallback;onSelectCallback;changeTimer=null;lastFeatureCount=0;forcedCoordinate=null;constructor(e){this.mapInstance=e.map}async addToMap(e=!0){this.drawControl||(this.drawControl=new ri({open:e}),this.mapInstance.addControl(this.drawControl,`top-right`),await new Promise(e=>{this.mapInstance.isStyleLoaded()?e():this.mapInstance.once(`idle`,()=>e())}),this.bindEvents())}bindEvents(){if(!this.drawControl)return;let e=this.drawControl.getTerraDrawInstance();e.on(`change`,()=>{let t=e.getSnapshot(),n=this.toGeoJSON(t);t.length<this.lastFeatureCount?this.onDeleteCallback?.(n):t.length>this.lastFeatureCount&&this.onFinishCallback?.(n),this.lastFeatureCount=t.length,this.changeTimer&&clearTimeout(this.changeTimer),this.changeTimer=setTimeout(()=>{this.onChangeCallback?.(n)},50)}),e.on(`select`,e=>this.onSelectCallback?.(e)),e.on(`deselect`,()=>this.onSelectCallback?.(null))}toGeoJSON(e){return{type:`FeatureCollection`,features:e.map(e=>({type:`Feature`,geometry:e.geometry,properties:{...e.properties||{},id:e.id}}))}}changeMode(e){if(!this.drawControl)return;let t=this.drawControl.getTerraDrawInstance();if(e===`undo`){t?.undo();return}if(e===`redo`){t?.redo();return}if(e===`download`){this.downloadGeoJSON();return}t.setMode(e)}setEnabled(e){if(!this.drawControl)return;let t=this.drawControl.getTerraDrawInstance();e?t.setMode(`select`):t.setMode(`render`)}getFeatureById(e){if(this.drawControl)return this.drawControl.getTerraDrawInstance().getSnapshot().find(t=>t.id===e)}deleteFeatureById(e){if(!this.drawControl)return;let t=this.drawControl.getTerraDrawInstance(),n=Array.isArray(e)?e:[e];t.removeFeatures(n)}updateModeStyles(e,t){this.drawControl&&this.drawControl.getTerraDrawInstance().updateModeOptions(e,{styles:t})}drawWithForcedCoordinates(e,t){if(!this.drawControl)return;let n=this.drawControl.getTerraDrawInstance(),r;e===`point`?r={type:`Point`,coordinates:t[0]}:e===`linestring`?r={type:`LineString`,coordinates:t}:e===`polygon`&&(r={type:`Polygon`,coordinates:[[...t,t[0]]]}),r&&n.addFeatures([{type:`Feature`,geometry:r,properties:{}}])}addFeatures(e){if(!this.drawControl||!e.features.length)return;let t=this.drawControl.getTerraDrawInstance();t&&(t.addFeatures(e.features),this.lastFeatureCount=t.getSnapshot().length)}clear(){this.drawControl&&(this.drawControl.getTerraDrawInstance().clear(),this.lastFeatureCount=0)}downloadGeoJSON(){let e=this.toGeoJSON(this.drawControl?.getTerraDrawInstance().getSnapshot()||[]),t=new Blob([JSON.stringify(e,null,2)],{type:`application/json`}),n=URL.createObjectURL(t),r=document.createElement(`a`);r.href=n,r.download=`draw_data_${Date.now()}.geojson`,r.click(),URL.revokeObjectURL(n)}destroy(){this.drawControl&&(this.changeTimer&&clearTimeout(this.changeTimer),this.mapInstance.removeControl(this.drawControl),this.drawControl=null,this.onFinishCallback=void 0,this.onChangeCallback=void 0,this.onDeleteCallback=void 0,this.onSelectCallback=void 0)}setOnFinish(e){this.onFinishCallback=e}setOnChange(e){this.onChangeCallback=e}setOnDelete(e){this.onDeleteCallback=e}setOnSelect(e){this.onSelectCallback=e}}},$={ctc:(e,t,n)=>({id:`ctc`,sourceUrl:t,layers:n,sourceLayers:n.map(t=>t===`switch_loc`?`${e}_SG_t_${t}`:`${e}_SG_t_${t}_graph`)}),raster:e=>({id:`raster`,sourceUrl:e,zoom:20}),geom:(e,t,n)=>({id:`geom`,sourceUrl:t,layers:n,sourceLayers:n.map(t=>t===`switch_loc`?`${e}_t_${t}`:`${e}_t_${t}_geom`)}),graph:(e,t,n)=>({id:`graph`,sourceUrl:t,layers:n,sourceLayers:n.map(t=>t===`switch_loc`?`${e}_t_${t}`:`${e}_t_${t}_graph`)}),geojson:e=>({id:e}),rswp:e=>({id:`rswp`,sourceUrl:e}),mbtiles:(e,t)=>({id:`mbtiles`,sourceUrl:e,layers:t,sourceLayers:t.map(e=>`t_${e}_graph`)}),rage:(e,t,n,r)=>({id:`geom`,subSourceId:`raster`,sourceUrl:e,subSourceUrl:t,layers:r,sourceLayers:r.map(e=>e===`switch_loc`?`${n}_t_${e}`:`${n}_t_${e}_geom`)})};function ai(e,t,n){let r=BigInt(e),i=BigInt(t),a=BigInt(n),o=r*r*i^a;o===0n&&(o=3735928559n);let s=o;s^=s<<11n,s^=s>>5n,s^=s<<13n,s===0n&&(s=3405691582n);let c=s,l=s^s<<16n,u=s^s>>16n;return{z:r^c,x:i^l,y:a^u}}function oi(e){e.map.setTransformRequest((e,t)=>{if(String(t)!==`Tile`)return{url:e};let n=/^https?:\/\//i.test(e)?e:`${window.location.origin}${e}`,r=new URL(n),i=r.pathname.split(`/`).filter(e=>e);if(i.length>=3){let e=Number(i[i.length-3]),t=Number(i[i.length-2]),n=i[i.length-1],a=n.includes(`.`)?n.split(`.`).pop():`pbf`,o=Number(n.replace(/\.(pbf|png)$/i,``));if(Number.isInteger(e)&&e>=0&&Number.isInteger(t)&&t>=0&&Number.isInteger(o)&&o>=0){let n=ai(e,t,o),s=i.slice(0,i.length-3).join(`/`);return{url:`${r.protocol}//${r.host}/${s}/${n.z}/${n.x}/${n.y}.${a}`}}}return{url:e}})}var si=20037508.34,ci=(e,t)=>[e/si*180,Math.atan(Math.exp(t/si*Math.PI))*360/Math.PI-90],li=e=>`coordinates`in e,ui=e=>typeof e[0]==`number`?ci(e[0],e[1]):e.map(ui),di=e=>e?.features?{...e,features:e.features.map(e=>({...e,geometry:li(e.geometry)?{...e.geometry,coordinates:ui(e.geometry.coordinates)}:e.geometry}))}:e,fi=(e,t)=>{if(e===`signal`){if(!t?.features)return;t.features.forEach(({properties:e})=>{e&&(!e.positionSide&&e.posi_side&&(e.positionSide=e.posi_side,delete e.posi_side),!e.installType&&e.install_type&&(e.installType=e.install_type,delete e.install_type),!e.functionType&&e.function_type&&(e.functionType=e.function_type,delete e.function_type))})}if(e===`track_circuit`){if(!t?.features)return;t.features.forEach(({properties:e})=>{e&&(!e.fromCode&&e.from_code&&(e.fromCode=e.from_code,delete e.from_code),!e.toCode&&e.to_code&&(e.toCode=e.to_code,delete e.to_code))})}if(e===`insulation`){if(!t?.features)return;t.features.forEach(({properties:e})=>{e&&(!e.downSignal&&e.downsignal&&(e.downSignal=e.downsignal,delete e.downsignal),!e.upSignal&&e.upsignal&&(e.upSignal=e.upsignal,delete e.upsignal))})}},pi=class{map;mapConfigs;stashFeatures=new Map;constructor(e){let n={version:8,sources:{},layers:[]};this.map=new t.default.Map({container:e,style:n,center:[0,0],zoom:14}),ii.base(this),this.map.on(`load`,()=>{this.drawTool=new ii.draw(this)})}initMap(e){let t=async()=>{try{console.log(`开始构建业务地图: ${e.id}`),Array.isArray(e.source)?e.source.forEach((e,t)=>{this.map.addSource(this.mapConfigs.sourceLayers[t],e)}):this.map.getSource(e.id)?console.warn(`地图源已存在,跳过添加: ${e.id}`):this.map.addSource(e.id,e.source),e.subSourceId&&(this.map.getSource(e.subSourceId)?console.warn(`地图源已存在,跳过添加: ${e.subSourceId}`):this.map.addSource(e.subSourceId,e.subSource)),(await re()).forEach(e=>{this.map.hasImage(e.id)?console.warn(`图标已存在,跳过添加: ${e.id}`):this.map.addImage(e.id,e.image)}),e.layers&&e.layers.forEach(e=>{this.map.getLayer(e.id)?console.debug(`图层已存在: ${e.id}`):this.map.addLayer(e)});let t=this.map.getStyle().sources,n=Object.keys(t);console.log(`源列表 (${n.length}):`,n,t);let r=this.map.getStyle().layers,i=r.map(e=>e.id);console.log(`图层列表 (${i.length}):`,r);let a=this.map.listImages();console.log(`图标列表 (${a.length}):`,a),console.groupEnd(),console.log(`地图构建全部完成: ${e.id}`)}catch(t){console.error(`地图初始化失败: ${e.id}`,t),t instanceof Error&&console.error(`错误详情: ${t.message}`)}};this.map.loaded()?t():this.map.on(`load`,()=>{t()}),this.map.once(`idle`,()=>{setTimeout(()=>{this.stashAllFeature()},800)})}createCTCMap(e,t,n){this.mapConfigs=$.ctc(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.ctc(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.ctc(this)}createCTCEncryptedMap(e,t,n){oi(this),this.mapConfigs=$.ctc(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.ctc(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.ctc(this)}createRSWPMap(e){let t=$.rswp(e),n=w.raster(t.sourceUrl),r=E.raster(t.id),i=$.geojson(`rswp-geojson`),a=w.geojson(),o={id:t.id,source:n,subSourceId:i.id,subSource:a,layers:r};this.mapConfigs=t,this.mapConfigs.subSourceId=i.id,this.initMap(o)}createGraphMap(e,t,n){this.mapConfigs=$.graph(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.graph(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.graph(this)}createGraphEncryptedMap(e,t,n){oi(this),this.mapConfigs=$.graph(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.ctc(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.ctc(this)}createGeomMap(e,t,n){this.mapConfigs=$.geom(e,t,n);let r=w.geom(this.mapConfigs.sourceUrl),i=E.geom(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a)}createGeomEncryptedMap(e,t,n){oi(this),this.mapConfigs=$.geom(e,t,n);let r=w.geom(this.mapConfigs.sourceUrl),i=E.geom(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a)}async createGeoJsonStationMap(e){let t=e.map(e=>e.name),r=t.map(e=>`geojson_${e}`);this.mapConfigs=$.geojson(`geojson`),this.mapConfigs.layers=t,this.mapConfigs.sourceLayers=r;let i=await Promise.all(e.map(async(e,t)=>{let n=r[t],i=e.name;if(this.map.getSource(n))return;let a=e.data,o;return typeof a==`string`?(o=di(await(await fetch(a)).json()),fi(i,o)):(o=di(a),fi(i,o)),w.geojson(o)})),a={id:this.mapConfigs.id,source:i,layers:E.geojson(t,r)};this.initMap(a);let o=e.find(e=>e.name===`track`)?.data;if(o){let e=(0,n.default)(di(o));this.map.fitBounds([[e[0],e[1]],[e[2],e[3]]],{padding:100,maxZoom:15})}ii.geojson(this)}createRasterMap(e){this.mapConfigs=$.raster(e);let t=w.raster(this.mapConfigs.sourceUrl),n=E.raster(this.mapConfigs.id),r={id:this.mapConfigs.id,source:t,layers:n};this.initMap(r)}createEncryptedRasterMap(e){oi(this),this.mapConfigs=$.raster(e);let t=w.raster(this.mapConfigs.sourceUrl),n=E.raster(this.mapConfigs.id),r={id:this.mapConfigs.id,source:t,layers:n};this.initMap(r)}createRAGEMap(e,t,n){let r=[`track`,`signal`,`bumper`,`prevention`];oi(this),this.mapConfigs=$.rage(e,t,n,r);let i=w.geom(this.mapConfigs.sourceUrl),a=w.raster(this.mapConfigs.subSourceUrl),o=E.geom(this.mapConfigs),s=[...E.raster(this.mapConfigs.subSourceId),...o],c={id:this.mapConfigs.id,source:i,subSourceId:this.mapConfigs.subSourceId,subSource:a,layers:s};this.initMap(c)}getMap(){return this.map}getMapConfigs(){return this.mapConfigs}async stashAllFeature(){if(!this.mapConfigs)return;let e=this.mapConfigs.sourceLayers,t=this.mapConfigs.id;this.stashFeatures.clear(),e?.forEach(e=>{e.includes(`prevention`)||this.map.querySourceFeatures(t,{sourceLayer:e}).forEach(t=>{t.properties.code&&this.stashFeatures.set(t.properties.code,{sourceLayer:e})})});let n=this.mapConfigs.layers??[];await Promise.all(n.map(async e=>{if(e===`prevention`)return;let t=`geojson_${e}`,n=this.map.getSource(t);n&&(await n.getData()).features?.forEach(e=>{let n=e.properties?.code;n&&!this.stashFeatures.get(n)&&this.stashFeatures.set(n,{sourceLayer:t,properties:e.properties})})}))}updateFeatureState(e,t){if(!this.stashFeatures.get(e))return;Object.assign(this.stashFeatures.get(e),t);let n=this.stashFeatures.get(e);if(n.sourceLayer?.startsWith(`geojson_`))this.map.setFeatureState({source:n.sourceLayer,id:e},n);else{if(!this.mapConfigs)return;this.map.setFeatureState({source:this.mapConfigs.id,sourceLayer:n.sourceLayer,id:e},n)}}getFeatureState(e){if(this.stashFeatures.get(e))return this.stashFeatures.get(e)}locateGeojsonFeature(e){let t=(0,n.default)(di(e));this.map.fitBounds([[t[0],t[1]],[t[2],t[3]]],{padding:50,maxZoom:18})}},mi=document.createElement(`style`);mi.textContent=`
|
|
6
|
+
(`,[`to-string`,[`get`,`costingModel`]],`)`],[`concat`,[`to-string`,[`get`,`text`]]]],"symbol-placement":`point`,"text-size":[`interpolate`,[`linear`],[`zoom`],5,10,10,12,13,14,14,16,18,18],"text-overlap":`always`,"text-variable-anchor":[`left`,`right`,`top`,`bottom`],"text-radial-offset":.5,"text-justify":`left`,"text-letter-spacing":.05},paint:{"text-halo-color":`#F7F7F7`,"text-halo-width":2,"text-color":`#232E3D`}},routingLineLayerNodeSpec:{id:`{prefix}-routing-node`,type:`circle`,source:`{prefix}-routing-source`,filter:[`==`,`$type`,`Point`],layout:{},paint:{"circle-radius":3,"circle-color":[`case`,[`==`,[`get`,`text`],`Start`],`#0000FF`,[`==`,[`get`,`text`],`Goal`],`#FFFF00`,`#FFFFFF`],"circle-stroke-color":`#000000`,"circle-stroke-width":1}},timeIsochronePolygonLayerSpec:{id:`{prefix}-time-isochrone-polygon`,type:`fill`,source:`{prefix}-time-isochrone-source`,layout:{},paint:{"fill-color":[`get`,`fillColor`],"fill-opacity":[`get`,`fillOpacity`]}},timeIsochroneLineLayerSpec:{id:`{prefix}-time-isochrone-line`,type:`line`,source:`{prefix}-time-isochrone-source`,layout:{"line-join":`round`,"line-cap":`round`},paint:{"line-color":[`get`,`fillColor`],"line-width":3}},timeIsochroneLabelLayerSpec:{id:`{prefix}-time-isochrone-label`,type:`symbol`,source:`{prefix}-time-isochrone-source`,layout:{"symbol-placement":`line`,"text-pitch-alignment":`viewport`,"text-field":[`concat`,[`get`,`contour`],` `,`min`],"text-size":12,"symbol-spacing":100,"text-max-angle":45},paint:{"text-color":`rgb(0, 0, 0)`,"text-halo-width":1,"text-halo-color":`rgb(255, 255, 255)`}},distanceIsochronePolygonLayerSpec:{id:`{prefix}-distance-isochrone-polygon`,type:`fill`,source:`{prefix}-distance-isochrone-source`,layout:{},paint:{"fill-color":[`get`,`fillColor`],"fill-opacity":[`get`,`fillOpacity`]}},distanceIsochroneLineLayerSpec:{id:`{prefix}-distance-isochrone-line`,type:`line`,source:`{prefix}-distance-isochrone-source`,layout:{"line-join":`round`,"line-cap":`round`},paint:{"line-color":[`get`,`fillColor`],"line-width":3}},distanceIsochroneLabelLayerSpec:{id:`{prefix}-distance-isochrone-label`,type:`symbol`,source:`{prefix}-distance-isochrone-source`,layout:{"symbol-placement":`line`,"text-pitch-alignment":`viewport`,"text-field":[`concat`,[`get`,`contour`],` `,`km`],"text-size":12,"symbol-spacing":100,"text-max-angle":45},paint:{"text-color":`rgb(0, 0, 0)`,"text-halo-width":1,"text-halo-color":`rgb(255, 255, 255)`}}},Xr=`data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'%20standalone='no'?%3e%3csvg%20xmlns:dc='http://purl.org/dc/elements/1.1/'%20xmlns:cc='http://creativecommons.org/ns%23'%20xmlns:rdf='http://www.w3.org/1999/02/22-rdf-syntax-ns%23'%20xmlns:svg='http://www.w3.org/2000/svg'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:sodipodi='http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd'%20xmlns:inkscape='http://www.inkscape.org/namespaces/inkscape'%20inkscape:version='1.0%20(4035a4fb49,%202020-05-01)'%20sodipodi:docname='poi.svg'%20id='svg4460'%20height='100'%20width='100'%20version='1.1'%3e%3csodipodi:namedview%20inkscape:document-rotation='0'%20inkscape:current-layer='svg4460'%20inkscape:window-maximized='1'%20inkscape:window-y='-8'%20inkscape:window-x='-8'%20inkscape:cy='70.031285'%20inkscape:cx='-78.460726'%20inkscape:zoom='2.02'%20showgrid='false'%20id='namedview11'%20inkscape:window-height='1017'%20inkscape:window-width='1920'%20inkscape:pageshadow='2'%20inkscape:pageopacity='0'%20guidetolerance='10'%20gridtolerance='10'%20objecttolerance='10'%20borderopacity='1'%20bordercolor='%23666666'%20pagecolor='%23ffffff'%20/%3e%3cdefs%20id='defs4462'%20/%3e%3cmetadata%20id='metadata4465'%3e%3crdf:RDF%3e%3ccc:Work%20rdf:about=''%3e%3cdc:format%3eimage/svg+xml%3c/dc:format%3e%3cdc:type%20rdf:resource='http://purl.org/dc/dcmitype/StillImage'%20/%3e%3cdc:title%3e%3c/dc:title%3e%3c/cc:Work%3e%3c/rdf:RDF%3e%3c/metadata%3e%3cpath%20d='M%2050.001528,3.3861402e-7%20C%2030.763177,3.3861402e-7%2015,15.718144%2015,34.901534%20c%200,7.432782%202.373565,14.339962%206.391689,20.019029%20l%2024.338528,42.073163%20c%203.40849,4.452814%205.674917,3.607154%208.509014,-0.23458%20L%2081.083105,51.075788%20C%2081.625418,50.0948%2082.050328,49.050173%2082.421327,47.983517%2084.078241,43.936622%2085.000002,39.521943%2085,34.901534%2085,15.718144%2069.23988,3.3861402e-7%2050.001528,3.3861402e-7%20Z%20m%200,16.35400066138598%20c%2010.359296,0%2018.597616,8.21783%2018.597618,18.547533%200,10.329703%20-8.238322,18.544487%20-18.597618,18.544487%20-10.359299,0%20-18.600672,-8.214784%20-18.600672,-18.544487%200,-10.329703%208.241373,-18.547533%2018.600672,-18.547533%20z'%20style='fill:%233FB1CE;stroke-width:4.26019'%20id='path4135'%20/%3e%3c/svg%3e`,Zr=(e,t)=>{let n=t.updateType;return n===`finish`||n===`commit`?gr(e):{valid:!0}},Qr=()=>({render:new q({modeName:`render`,styles:{}}),point:new vn({editable:!0}),marker:new Fr({editable:!0,styles:{markerUrl:Xr,markerWidth:27,markerHeight:27}}),linestring:new dn({editable:!0}),polygon:new xn({editable:!0,validation:Zr}),rectangle:new wn,"angled-rectangle":new br,circle:new jt,freehand:new Ft,"freehand-linestring":new Mr,sensor:new Dr,sector:new wr,select:new Kn({flags:{point:{feature:{draggable:!0}},marker:{feature:{draggable:!0}},polygon:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},linestring:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},freehand:{feature:{draggable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},"freehand-linestring":{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},circle:{feature:{draggable:!0,coordinates:{resizable:`center`,deletable:!1,midpoints:!1}}},rectangle:{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},"angled-rectangle":{feature:{draggable:!0,rotateable:!0,coordinates:{resizable:`opposite`,deletable:!1,midpoints:!1}}},sensor:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}},sector:{feature:{draggable:!0,rotateable:!0,scaleable:!0,coordinates:{midpoints:!0,draggable:!0,deletable:!0}}}}}),delete:new q({modeName:`delete`,styles:{}}),"delete-selection":new q({modeName:`delete-selection`,styles:{}}),download:new q({modeName:`download`,styles:{}}),undo:new q({modeName:`undo`,styles:{}}),redo:new q({modeName:`redo`,styles:{}})}),Q=6371008.8;Q*100,Q*100,360/(2*Math.PI),Q*3.28084,Q*39.37,Q/1e3,Q/1e3,Q/1609.344,Q*1e3,Q*1e3,Q/1852,Q*1.0936,Q*Q/2,Math.PI/180;var $r=e=>e.charAt(0).toUpperCase()+e.slice(1),ei=[`{prefix}-point`,`{prefix}-point-lower`,`{prefix}-linestring`,`{prefix}-polygon`,`{prefix}-polygon-outline`];[...ei,Yr.polygonLayerSpec?.source,Yr.lineLayerLabelSpec?.source],[...ei,Z.routingLineLayerNodeLabelSpec?.source,Z.routingLineLayerNodeSpec?.source,Z.timeIsochronePolygonLayerSpec?.source,Z.timeIsochroneLineLayerSpec?.source,Z.timeIsochroneLabelLayerSpec?.source,Z.distanceIsochronePolygonLayerSpec?.source,Z.distanceIsochroneLineLayerSpec?.source,Z.distanceIsochroneLabelLayerSpec?.source];var ti=(e,t,n=ei,r=`td`)=>{n=n.map(e=>e.replace(`{prefix}`,r));let i=JSON.parse(JSON.stringify(e));return t&&(t.onlyTerraDrawLayers===!0?(i.layers=i.layers.filter(e=>`source`in e&&n.includes(e.source)),Object.keys(i.sources).forEach(e=>{n.includes(e)||delete i.sources[e]})):t.excludeTerraDrawLayers===!0&&(i.layers=i.layers.filter(e=>`source`in e&&!n.includes(e.source)||e.type===`background`),Object.keys(i.sources).forEach(e=>{n.includes(e)&&delete i.sources[e]}))),i},ni=class{className;dialog;title;constructor(e,t){this.className=e,this.title=t}create(e,t){let n=document.getElementsByClassName(this.className);n.length>0&&Array.from(n).forEach(e=>{e.remove()}),this.dialog=document.createElement(`dialog`),this.dialog.classList.add(this.className);let r=document.createElement(`div`);r.classList.add(`dialog-header`);let i=document.createElement(`h3`);i.textContent=this.title,i.classList.add(`dialog-title`),r.appendChild(i);let a=document.createElement(`button`);a.type=`button`,a.classList.add(`close-button`),a.innerHTML=`×`,a.setAttribute(`aria-label`,`Close dialog`),a.addEventListener(`click`,()=>{this.close()}),r.appendChild(a),this.dialog.appendChild(r);let o=document.createElement(`div`);o.classList.add(`content`),this.dialog.appendChild(t(o)),this.dialog.addEventListener(`click`,e=>{let t=e.target?.getBoundingClientRect();t&&(t.left>e.clientX||t.right<e.clientX||t.top>e.clientY||t.bottom<e.clientY)&&this.close()}),e.appendChild(this.dialog)}open(){this.dialog?.showModal()}close(){this.dialog?.close()}createSegmentButtons(e,t,n=()=>{}){let r=document.createElement(`div`);return r.classList.add(`segment-buttons`),e.forEach(e=>{let i=document.createElement(`button`);i.type=`button`,i.classList.add(`segment-button`),i.value=e.value,i.textContent=e.label,e.value===t&&i.classList.add(`active`),i.addEventListener(`click`,()=>{r.querySelectorAll(`.segment-button`).forEach(e=>e.classList.remove(`active`)),i.classList.add(`active`),n(i.value)}),r.appendChild(i)}),r}};2*Math.PI*6378137/2;var ri=class{controlContainer;map;modeButtons={};_isExpanded=!1;_cssPrefix=``;get isExpanded(){return this._isExpanded}get cssPrefix(){return this._cssPrefix}set isExpanded(e){this._isExpanded=e;let t=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-control`);for(let e=0;e<t.length;e++){let n=t.item(e);n&&(this.isExpanded?n.classList.remove(`hidden`):n.classList.add(`hidden`))}let n=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}render-button`);n&&n.length>0&&(this.isExpanded?n.item(0)?.classList.add(`enabled`):(n.item(0)?.classList.remove(`enabled`),this.resetActiveMode())),this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature(),this.isExpanded?this.dispatchEvent(`expanded`):this.dispatchEvent(`collapsed`)}get showDeleteConfirmation(){return this.options.showDeleteConfirmation===!0}set showDeleteConfirmation(e){this.options.showDeleteConfirmation=e}terradraw;options;events={};defaultMode=`render`;constructor(e){this.modeButtons={},this.options={...Jr,modes:[...Jr.modes??[]],...e};let t=this.options.adapterOptions?.prefixId??`td`;this.options.adapterOptions||(this.options.adapterOptions={}),this.options.adapterOptions?.prefixId||(this.options.adapterOptions.prefixId=t),this.options.undoRedo||(this.options.undoRedo={modeLevel:new Ur({maxStackSize:100}),sessionLevel:new Wr({maxStackSize:100}),keyboardShortcuts:new zr})}getDefaultPosition(){return`top-right`}onAdd(e){if(this.options&&this.options.modes&&this.options.modes.length===0)throw Error(`At least a mode must be enabled.`);this.map=e;let t=Qr(),n=[];return this.options?.modes?.forEach(e=>{if(this.options.modeOptions&&this.options.modeOptions[e]){let r=this.options.modeOptions[e];if(e===`select`){let n=t[e];if(n){let e=n.flags;Object.keys(e).forEach(t=>{r.flags[t]||(r.flags[t]=e[t])})}}n.push(r)}else t[e]&&n.push(t[e])}),n.forEach(e=>{e.state!==`unregistered`&&(e._state=`unregistered`)}),this.options?.modes?.includes(`render`)||(n.push(new q({modeName:`default`,styles:{}})),this.defaultMode=`default`),this.isExpanded=this.options.open===!0,this.terradraw=new Kr({adapter:new qr({map:e,...this.options.adapterOptions}),modes:n,undoRedo:this.options.undoRedo}),this.map?.loaded()?this.terradraw.start():this.map?.once(`load`,()=>{this.terradraw?.start()}),this.controlContainer=document.createElement(`div`),this.controlContainer.classList.add(`maplibregl-ctrl`),this.controlContainer.classList.add(`maplibregl-ctrl-group`),n.forEach(e=>{e.mode!==`default`&&this.addTerradrawButton(e.mode)}),Object.values(this.modeButtons).forEach(e=>{this.controlContainer?.appendChild(e)}),this.toggleButtonsWhenNoFeature(),this.terradraw?.on(`finish`,this.toggleButtonsWhenNoFeature.bind(this)),this.terradraw?.on(`history`,this.handleHistoryChange.bind(this)),this.map.once(`idle`,()=>{this.toggleButtonsWhenNoFeature()}),this.controlContainer}onRemove(){!this.controlContainer||!this.controlContainer.parentNode||!this.map||(this.deactivate(),this.modeButtons={},this.terradraw=void 0,this.map=void 0,this.controlContainer.parentNode.removeChild(this.controlContainer))}on(e,t){this.events[e]?this.events[e].push(t):this.events[e]=[t]}off(e,t){if(!this.events[e])return;let n=this.events[e].findIndex(e=>e===t);n!==-1&&this.events[e].splice(n,1)}dispatchEvent(e,t){this.events[e]&&this.events[e].forEach(e=>{let n=(this.terradraw?.getSnapshot())?.filter(e=>e.properties.selected===!0);e({feature:n,mode:this.terradraw?.getMode(),...t})})}activate(){this.terradraw&&(this.terradraw.enabled||this.terradraw.start())}deactivate(){this.terradraw&&this.terradraw.enabled&&(this.resetActiveMode(),this.dispatchEvent(`mode-changed`),this.terradraw.stop())}handleModeChange(e,t){let n=t.setMode(e);return this.syncButtonStates(e),e!==this.defaultMode&&this.activate(),this.dispatchEvent(`mode-changed`),n}syncButtonStates(e){if(!this.controlContainer)return;let t=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-control`);for(let e=0;e<t.length;e++){let n=t.item(e);n&&n.classList.remove(`active`)}if(e!==this.defaultMode&&e!==`render`){let t=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-${e}-button`);t&&t.length>0&&t[0].classList.add(`active`)}this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature()}getTerraDrawInstance(){return this.terradraw?new Proxy(this.terradraw,{get:(e,t,n)=>t===`setMode`?t=>this.handleModeChange(t,e):t===`clearUndoRedoHistory`?()=>{e.clearUndoRedoHistory(),this.handleHistoryChange({undoSize:0,redoSize:0})}:Reflect.get(e,t,n)}):this.terradraw}handleHistoryChange(e){if(!this.controlContainer)return;let t=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}undo-button`);for(let n=0;n<t.length;n++){let r=t.item(n);r&&(r.disabled=e.undoSize===0)}let n=this.controlContainer.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}redo-button`);for(let t=0;t<n.length;t++){let r=n.item(t);r&&(r.disabled=e.redoSize===0)}}toggleEditor(){this.terradraw&&(this.isExpanded=!this.isExpanded)}resetActiveMode(){this.terradraw&&(this.terradraw.enabled||this.terradraw.start(),this.terradraw?.setMode(this.defaultMode),this.syncButtonStates(this.defaultMode))}addTerradrawButton(e){let t=document.createElement(`button`);t.type=`button`,this.modeButtons[e]=t,e===`render`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),this.isExpanded&&t.classList.add(`enabled`),t.type=`button`,t.title=$r(`expand or collapse drawing tool`),t.addEventListener(`click`,this.toggleEditor.bind(this))):(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}add-control`),this.isExpanded||t.classList.add(`hidden`),t.title=$r(e.replace(/-/g,` `)),e===`delete`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.addEventListener(`click`,this.handleDeleteAllFeatures.bind(this))):e===`delete-selection`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.classList.add(`hidden-delete-selection`),t.addEventListener(`click`,this.handleDeleteSelectedFeatures.bind(this))):e===`download`?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.addEventListener(`click`,this.handleDownload.bind(this))):[`undo`,`redo`].includes(e)?(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}${e}-button`),t.disabled=!0,t.addEventListener(`click`,()=>{this.terradraw&&(e===`undo`?this.terradraw.undo():this.terradraw.redo())})):(t.classList.add(`maplibregl-terradraw-${this.cssPrefix}add-${e}-button`),t.addEventListener(`click`,()=>{if(!this.terradraw)return;let n=t.classList.contains(`active`);this.activate(),this.resetActiveMode(),n||(this.terradraw.setMode(e),this.syncButtonStates(e)),this.dispatchEvent(`mode-changed`)})))}getFeatures(e=!1){if(!this.terradraw)return;let t={type:`FeatureCollection`,features:(this.terradraw?.getSnapshot()).filter(e=>e.properties.mode!==`select`)};return e===!0&&(t.features=t.features.filter(e=>e.properties.selected===!0)),t}cleanStyle(e,t){return ti(e,t,ei,this.options.adapterOptions?.prefixId)}showDeleteConfirmationDialog(e){let t=new ni(`maplibre-terradraw-delete-confirmation-dialog`,`Delete All Features`);t.create(document.body,n=>{let r=document.createElement(`p`);r.textContent=`Are you sure you want to delete all features?`,n.appendChild(r);let i=document.createElement(`div`);i.classList.add(`dialog-buttons`);let a=document.createElement(`button`);a.type=`button`,a.textContent=`Cancel`,a.classList.add(`dialog-button-cancel`),a.addEventListener(`click`,()=>{t.close()});let o=document.createElement(`button`);return o.type=`button`,o.textContent=`Delete`,o.classList.add(`dialog-button-delete`),o.addEventListener(`click`,()=>{e(),t.close()}),i.appendChild(a),i.appendChild(o),n.appendChild(i),n}),t.open()}handleDeleteAllFeatures(){if(!this.terradraw||!this.terradraw.enabled)return;let e=()=>{this.terradraw?.clear(),this.resetActiveMode(),this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature(),this.dispatchEvent(`feature-deleted`)};this.options.showDeleteConfirmation===!0?this.showDeleteConfirmationDialog(e):e()}handleDeleteSelectedFeatures(){if(!this.terradraw||!this.terradraw.enabled)return;let e=(this.terradraw?.getSnapshot()).filter(e=>e.properties.selected===!0);if(e.length>0){let t=e.map(e=>e.id);this.terradraw.removeFeatures(t);for(let e of t)this.terradraw.deselectFeature(e);this.dispatchEvent(`feature-deleted`,{deletedIds:t})}this.toggleDeleteSelectionButton(),this.toggleButtonsWhenNoFeature()}handleDownload(){let e=this.getFeatures(!1),t=`data:application/json;charset=utf-8,`+encodeURIComponent(JSON.stringify(e)),n=document.createElement(`a`);n.setAttribute(`href`,t),n.setAttribute(`download`,`data.geojson`),document.body.appendChild(n),n.click(),n.remove()}toggleButtonsWhenNoFeature(){if(!this.controlContainer)return;let e=(this.terradraw?.getSnapshot())?.filter(e=>e.properties.mode!==`select`),t=!!(e&&e.length>0),n=[`maplibregl-terradraw-${this.cssPrefix}add-select-button`,`maplibregl-terradraw-${this.cssPrefix}download-button`,`maplibregl-terradraw-${this.cssPrefix}delete-button`];for(let e of n){let n=this.controlContainer.getElementsByClassName(e);for(let e=0;e<n.length;e++){let r=n.item(e);r&&(r.disabled=!t)}}}toggleDeleteSelectionButton(){let e=this.terradraw?.enabled||!1,t=this.terradraw?.getMode(),n=this.getFeatures(!1),r=n&&n.features.length>0,i=r&&e&&t===`select`,a=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}delete-selection-button`);for(let e=0;e<a.length;e++){let t=a.item(e);t&&(i?t.classList.remove(`hidden-delete-selection`):t.classList.add(`hidden-delete-selection`))}if(!r){let e=document.getElementsByClassName(`maplibregl-terradraw-${this.cssPrefix}add-select-button`);for(let t=0;t<e.length;t++){let n=e.item(t);n&&n.classList.remove(`active`)}}}clearExtendedFeatures(e,t=void 0){if(this.map)for(let n of e){let e=this.map.getStyle().sources[n];e&&typeof e.data!=`string`&&e.data.type===`FeatureCollection`&&(t===void 0?e.data.features=[]:e.data.features=e.data.features.filter(e=>e.properties?.originalId?!t.includes(e.properties.originalId):!t.includes(e.id)),this.map.getSource(n)?.setData(e.data))}}},ii={base:Fe,ctc:we,graph:Ge,geojson:Ye,draw:class{drawControl=null;mapInstance;onFinishCallback;onChangeCallback;onDeleteCallback;onSelectCallback;changeTimer=null;lastFeatureCount=0;constructor(e){this.mapInstance=e.map}async addToMap(e=!0){this.drawControl||(this.drawControl=new ri({open:e}),this.mapInstance.addControl(this.drawControl,`top-right`),await new Promise(e=>{this.mapInstance.isStyleLoaded()?e():this.mapInstance.once(`idle`,()=>e())}),this.bindEvents())}bindEvents(){if(!this.drawControl)return;let e=this.drawControl.getTerraDrawInstance();e&&(e.on(`change`,()=>{let t=e.getSnapshot(),n=this.toGeoJSON(t);t.length<this.lastFeatureCount?this.onDeleteCallback?.(n):t.length>this.lastFeatureCount&&this.onFinishCallback?.(n),this.lastFeatureCount=t.length,this.changeTimer&&clearTimeout(this.changeTimer),this.changeTimer=setTimeout(()=>{this.onChangeCallback?.(n)},50)}),e.on(`select`,e=>this.onSelectCallback?.(String(e))),e.on(`deselect`,()=>this.onSelectCallback?.(null)))}toGeoJSON(e){return{type:`FeatureCollection`,features:e.map(e=>({type:`Feature`,geometry:e.geometry,properties:{...e.properties||{},id:e.id}}))}}changeMode(e){if(!this.drawControl)return;let t=this.drawControl.getTerraDrawInstance();if(t){if(e===`undo`){t.undo();return}if(e===`redo`){t.redo();return}if(e===`download`){this.downloadGeoJSON();return}t.setMode(e)}}setEnabled(e){if(!this.drawControl)return;let t=this.drawControl.getTerraDrawInstance();t&&(e?t.setMode(`select`):t.setMode(`render`))}getFeatureById(e){if(!this.drawControl)return;let t=this.drawControl.getTerraDrawInstance();if(t)return t.getSnapshot().find(t=>t.id===e)}deleteFeatureById(e){if(!this.drawControl)return;let t=this.drawControl.getTerraDrawInstance();if(!t)return;let n=Array.isArray(e)?e:[e];t.removeFeatures(n)}updateModeStyles(e,t){if(!this.drawControl)return;let n=this.drawControl.getTerraDrawInstance();n&&n.updateModeOptions(e,{styles:t})}drawWithForcedCoordinates(e,t){if(!this.drawControl)return;let n=this.drawControl.getTerraDrawInstance();if(!n)return;let r;e===`point`?r={type:`Point`,coordinates:t[0]}:e===`linestring`?r={type:`LineString`,coordinates:t}:e===`polygon`&&(r={type:`Polygon`,coordinates:[[...t,t[0]]]}),r&&n.addFeatures([{type:`Feature`,geometry:r,properties:{}}])}addFeatures(e){if(!this.drawControl||!e.features.length)return;let t=this.drawControl.getTerraDrawInstance();t&&(t.addFeatures(e.features),this.lastFeatureCount=t.getSnapshot().length)}clear(){if(!this.drawControl)return;let e=this.drawControl.getTerraDrawInstance();e&&(e.clear(),this.lastFeatureCount=0)}downloadGeoJSON(){let e=this.drawControl?.getTerraDrawInstance(),t=this.toGeoJSON(e?.getSnapshot()||[]),n=new Blob([JSON.stringify(t,null,2)],{type:`application/json`}),r=URL.createObjectURL(n),i=document.createElement(`a`);i.href=r,i.download=`draw_data_${Date.now()}.geojson`,i.click(),URL.revokeObjectURL(r)}destroy(){this.drawControl&&(this.changeTimer&&clearTimeout(this.changeTimer),this.mapInstance.removeControl(this.drawControl),this.drawControl=null,this.onFinishCallback=void 0,this.onChangeCallback=void 0,this.onDeleteCallback=void 0,this.onSelectCallback=void 0)}setOnFinish(e){this.onFinishCallback=e}setOnChange(e){this.onChangeCallback=e}setOnDelete(e){this.onDeleteCallback=e}setOnSelect(e){this.onSelectCallback=e}}},$={ctc:(e,t,n)=>({id:`ctc`,sourceUrl:t,layers:n,sourceLayers:n.map(t=>t===`switch_loc`?`${e}_SG_t_${t}`:`${e}_SG_t_${t}_graph`)}),raster:e=>({id:`raster`,sourceUrl:e,zoom:20}),geom:(e,t,n)=>({id:`geom`,sourceUrl:t,layers:n,sourceLayers:n.map(t=>t===`switch_loc`?`${e}_t_${t}`:`${e}_t_${t}_geom`)}),graph:(e,t,n)=>({id:`graph`,sourceUrl:t,layers:n,sourceLayers:n.map(t=>t===`switch_loc`?`${e}_t_${t}`:`${e}_t_${t}_graph`)}),geojson:e=>({id:e}),rswp:e=>({id:`rswp`,sourceUrl:e}),mbtiles:(e,t)=>({id:`mbtiles`,sourceUrl:e,layers:t,sourceLayers:t.map(e=>`t_${e}_graph`)}),rage:(e,t,n,r)=>({id:`geom`,subSourceId:`raster`,sourceUrl:e,subSourceUrl:t,layers:r,sourceLayers:r.map(e=>e===`switch_loc`?`${n}_t_${e}`:`${n}_t_${e}_geom`)})};function ai(e,t,n){let r=BigInt(e),i=BigInt(t),a=BigInt(n),o=r*r*i^a;o===0n&&(o=3735928559n);let s=o;s^=s<<11n,s^=s>>5n,s^=s<<13n,s===0n&&(s=3405691582n);let c=s,l=s^s<<16n,u=s^s>>16n;return{z:r^c,x:i^l,y:a^u}}function oi(e){e.map.setTransformRequest((e,t)=>{if(String(t)!==`Tile`)return{url:e};let n=/^https?:\/\//i.test(e)?e:`${window.location.origin}${e}`,r=new URL(n),i=r.pathname.split(`/`).filter(e=>e);if(i.length>=3){let e=Number(i[i.length-3]),t=Number(i[i.length-2]),n=i[i.length-1],a=n.includes(`.`)?n.split(`.`).pop():`pbf`,o=Number(n.replace(/\.(pbf|png)$/i,``));if(Number.isInteger(e)&&e>=0&&Number.isInteger(t)&&t>=0&&Number.isInteger(o)&&o>=0){let n=ai(e,t,o),s=i.slice(0,i.length-3).join(`/`);return{url:`${r.protocol}//${r.host}/${s}/${n.z}/${n.x}/${n.y}.${a}`}}}return{url:e}})}var si=20037508.34,ci=(e,t)=>[e/si*180,Math.atan(Math.exp(t/si*Math.PI))*360/Math.PI-90],li=e=>`coordinates`in e,ui=e=>typeof e[0]==`number`?ci(e[0],e[1]):e.map(ui),di=e=>e?.features?{...e,features:e.features.map(e=>({...e,geometry:li(e.geometry)?{...e.geometry,coordinates:ui(e.geometry.coordinates)}:e.geometry}))}:e,fi=(e,t)=>{if(e===`signal`){if(!t?.features)return;t.features.forEach(({properties:e})=>{e&&(!e.positionSide&&e.posi_side&&(e.positionSide=e.posi_side,delete e.posi_side),!e.installType&&e.install_type&&(e.installType=e.install_type,delete e.install_type),!e.functionType&&e.function_type&&(e.functionType=e.function_type,delete e.function_type))})}if(e===`track_circuit`){if(!t?.features)return;t.features.forEach(({properties:e})=>{e&&(!e.fromCode&&e.from_code&&(e.fromCode=e.from_code,delete e.from_code),!e.toCode&&e.to_code&&(e.toCode=e.to_code,delete e.to_code))})}if(e===`insulation`){if(!t?.features)return;t.features.forEach(({properties:e})=>{e&&(!e.downSignal&&e.downsignal&&(e.downSignal=e.downsignal,delete e.downsignal),!e.upSignal&&e.upsignal&&(e.upSignal=e.upsignal,delete e.upsignal))})}},pi=class{map;mapConfigs;stashFeatures=new Map;constructor(e){let n={version:8,sources:{},layers:[]};this.map=new t.default.Map({container:e,style:n,center:[0,0],zoom:14}),ii.base(this),this.map.on(`load`,()=>{this.drawTool=new ii.draw(this)})}initMap(e){let t=async()=>{try{console.log(`开始构建业务地图: ${e.id}`),Array.isArray(e.source)?e.source.forEach((e,t)=>{this.map.addSource(this.mapConfigs.sourceLayers[t],e)}):this.map.getSource(e.id)?console.warn(`地图源已存在,跳过添加: ${e.id}`):this.map.addSource(e.id,e.source),e.subSourceId&&(this.map.getSource(e.subSourceId)?console.warn(`地图源已存在,跳过添加: ${e.subSourceId}`):this.map.addSource(e.subSourceId,e.subSource)),(await re()).forEach(e=>{this.map.hasImage(e.id)?console.warn(`图标已存在,跳过添加: ${e.id}`):this.map.addImage(e.id,e.image)}),e.layers&&e.layers.forEach(e=>{this.map.getLayer(e.id)?console.debug(`图层已存在: ${e.id}`):this.map.addLayer(e)});let t=this.map.getStyle().sources,n=Object.keys(t);console.log(`源列表 (${n.length}):`,n,t);let r=this.map.getStyle().layers,i=r.map(e=>e.id);console.log(`图层列表 (${i.length}):`,r);let a=this.map.listImages();console.log(`图标列表 (${a.length}):`,a),console.groupEnd(),console.log(`地图构建全部完成: ${e.id}`)}catch(t){console.error(`地图初始化失败: ${e.id}`,t),t instanceof Error&&console.error(`错误详情: ${t.message}`)}};this.map.loaded()?t():this.map.on(`load`,()=>{t()}),this.map.once(`idle`,()=>{setTimeout(()=>{this.stashAllFeature()},800)})}createCTCMap(e,t,n){this.mapConfigs=$.ctc(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.ctc(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.ctc(this)}createCTCEncryptedMap(e,t,n){oi(this),this.mapConfigs=$.ctc(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.ctc(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.ctc(this)}createRSWPMap(e){let t=$.rswp(e),n=w.raster(t.sourceUrl),r=E.raster(t.id),i=$.geojson(`rswp-geojson`),a=w.geojson(),o={id:t.id,source:n,subSourceId:i.id,subSource:a,layers:r};this.mapConfigs=t,this.mapConfigs.subSourceId=i.id,this.initMap(o)}createGraphMap(e,t,n){this.mapConfigs=$.graph(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.graph(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.graph(this)}createGraphEncryptedMap(e,t,n){oi(this),this.mapConfigs=$.graph(e,t,n);let r=w.graph(this.mapConfigs.sourceUrl),i=E.ctc(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a),ii.ctc(this)}createGeomMap(e,t,n){this.mapConfigs=$.geom(e,t,n);let r=w.geom(this.mapConfigs.sourceUrl),i=E.geom(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a)}createGeomEncryptedMap(e,t,n){oi(this),this.mapConfigs=$.geom(e,t,n);let r=w.geom(this.mapConfigs.sourceUrl),i=E.geom(this.mapConfigs),a={id:this.mapConfigs.id,source:r,layers:i};this.initMap(a)}async createGeoJsonStationMap(e){let t=e.map(e=>e.name),r=t.map(e=>`geojson_${e}`);this.mapConfigs=$.geojson(`geojson`),this.mapConfigs.layers=t,this.mapConfigs.sourceLayers=r;let i=await Promise.all(e.map(async(e,t)=>{let n=r[t],i=e.name;if(this.map.getSource(n))return;let a=e.data,o;return typeof a==`string`?(o=di(await(await fetch(a)).json()),fi(i,o)):(o=di(a),fi(i,o)),w.geojson(o)})),a={id:this.mapConfigs.id,source:i,layers:E.geojson(t,r)};this.initMap(a);let o=e.find(e=>e.name===`track`)?.data;if(o){let e=(0,n.default)(di(o));this.map.fitBounds([[e[0],e[1]],[e[2],e[3]]],{padding:100,maxZoom:15})}ii.geojson(this)}createRasterMap(e){this.mapConfigs=$.raster(e);let t=w.raster(this.mapConfigs.sourceUrl),n=E.raster(this.mapConfigs.id),r={id:this.mapConfigs.id,source:t,layers:n};this.initMap(r)}createEncryptedRasterMap(e){oi(this),this.mapConfigs=$.raster(e);let t=w.raster(this.mapConfigs.sourceUrl),n=E.raster(this.mapConfigs.id),r={id:this.mapConfigs.id,source:t,layers:n};this.initMap(r)}createRAGEMap(e,t,n){let r=[`track`,`signal`,`bumper`,`prevention`];oi(this),this.mapConfigs=$.rage(e,t,n,r);let i=w.geom(this.mapConfigs.sourceUrl),a=w.raster(this.mapConfigs.subSourceUrl),o=E.geom(this.mapConfigs),s=[...E.raster(this.mapConfigs.subSourceId),...o],c={id:this.mapConfigs.id,source:i,subSourceId:this.mapConfigs.subSourceId,subSource:a,layers:s};this.initMap(c)}getMap(){return this.map}getMapConfigs(){return this.mapConfigs}async stashAllFeature(){if(!this.mapConfigs)return;let e=this.mapConfigs.sourceLayers,t=this.mapConfigs.id;this.stashFeatures.clear(),e?.forEach(e=>{e.includes(`prevention`)||this.map.querySourceFeatures(t,{sourceLayer:e}).forEach(t=>{t.properties.code&&this.stashFeatures.set(t.properties.code,{sourceLayer:e})})});let n=this.mapConfigs.layers??[];await Promise.all(n.map(async e=>{if(e===`prevention`)return;let t=`geojson_${e}`,n=this.map.getSource(t);n&&(await n.getData()).features?.forEach(e=>{let n=e.properties?.code;n&&!this.stashFeatures.get(n)&&this.stashFeatures.set(n,{sourceLayer:t,properties:e.properties})})}))}updateFeatureState(e,t){if(!this.stashFeatures.get(e))return;Object.assign(this.stashFeatures.get(e),t);let n=this.stashFeatures.get(e);if(n.sourceLayer?.startsWith(`geojson_`))this.map.setFeatureState({source:n.sourceLayer,id:e},n);else{if(!this.mapConfigs)return;this.map.setFeatureState({source:this.mapConfigs.id,sourceLayer:n.sourceLayer,id:e},n)}}getFeatureState(e){if(this.stashFeatures.get(e))return this.stashFeatures.get(e)}locateGeojsonFeature(e){let t=(0,n.default)(di(e));this.map.fitBounds([[t[0],t[1]],[t[2],t[3]]],{padding:50,maxZoom:18})}},mi=document.createElement(`style`);mi.textContent=`
|
|
7
7
|
.maplibregl-ctrl-attrib.maplibregl-compact {
|
|
8
8
|
display: none !important;
|
|
9
9
|
}
|