From 6ba04f46bff01f5b870a3d5e564c5d17c0ae9b77 Mon Sep 17 00:00:00 2001 From: Peter Pult Date: Tue, 15 Oct 2019 14:37:27 +0200 Subject: [PATCH 1/3] refactor: remove pmIgnore and optIn and replace it with useType --- README.md | 51 +++++---- src/js/Draw/L.PM.Draw.CircleMarker.js | 8 +- src/js/Draw/L.PM.Draw.Cut.js | 11 +- src/js/Draw/L.PM.Draw.Marker.js | 1 + src/js/L.PM.Map.js | 9 +- src/js/L.PM.js | 153 ++++++++------------------ src/js/Mixins/Snapping.js | 2 +- 7 files changed, 98 insertions(+), 137 deletions(-) diff --git a/README.md b/README.md index ca451ff2..3d1023d6 100644 --- a/README.md +++ b/README.md @@ -42,7 +42,6 @@ - [Customization](#customize) - [Need a feature?](#feature-request) | [Existing Feature Requests](https://github.com/geoman-io/leaflet-geoman/issues?q=is%3Aissue+is%3Aclosed+label%3A%22feature+request%22+sort%3Areactions-%2B1-desc) - ### Installation #### Migrate from Leaflet.PM @@ -51,6 +50,7 @@ npm uninstall leaflet.pm npm i @geoman-io/leaflet-geoman-free ``` + That's it. #### Install via npm @@ -93,8 +93,13 @@ import '@geoman-io/leaflet-geoman-free/dist/leaflet-geoman.css'; #### Init leaflet-geoman -Just include `leaflet-geoman.min.js` right after Leaflet. It initializes itself. If -you want certain layers to be ignored by leaflet-geoman, pass `pmIgnore: true` to +Just include `leaflet-geoman.min.js` right after Leaflet and initialize it with: + +```js +L.PM.initialize(); +``` + +If you want certain layers to be ignored by leaflet-geoman, pass `pmIgnore: true` to their options when creating them. Example: ```js @@ -115,7 +120,6 @@ All layers will be ignored by leaflet-geoman, unless you specify `pmIgnore: fals L.marker([51.50915, -0.096112], { pmIgnore: false }).addTo(map); ``` - #### leaflet-geoman Toolbar leaflet-geoman Toolbar @@ -132,19 +136,19 @@ map.pm.addControls({ See the available options in the table below. -| Option | Default | Description | -| :------------ | :---------- | :----------------------------------------------------------------------------------------------- | -| position | `'topleft'` | toolbar position, possible values are `'topleft'`, `'topright'`, `'bottomleft'`, `'bottomright'` | -| drawMarker | `true` | adds button to draw markers | -| drawCircleMarker | `true` | adds button to draw circle markers | -| drawPolyline | `true` | adds button to draw rectangle | -| drawRectangle | `true` | adds button to draw rectangle | -| drawPolygon | `true` | adds button to draw polygon | -| drawCircle | `true` | adds button to draw circle | -| editMode | `true` | adds button to toggle edit mode for all layers | -| dragMode | `true` | adds button to toggle drag mode for all layers | -| cutPolygon | `true` | adds button to cut a hole in a polygon | -| removalMode | `true` | adds a button to remove layers | +| Option | Default | Description | +| :--------------- | :---------- | :----------------------------------------------------------------------------------------------- | +| position | `'topleft'` | toolbar position, possible values are `'topleft'`, `'topright'`, `'bottomleft'`, `'bottomright'` | +| drawMarker | `true` | adds button to draw markers | +| drawCircleMarker | `true` | adds button to draw circle markers | +| drawPolyline | `true` | adds button to draw rectangle | +| drawRectangle | `true` | adds button to draw rectangle | +| drawPolygon | `true` | adds button to draw polygon | +| drawCircle | `true` | adds button to draw circle | +| editMode | `true` | adds button to toggle edit mode for all layers | +| dragMode | `true` | adds button to toggle drag mode for all layers | +| cutPolygon | `true` | adds button to cut a hole in a polygon | +| removalMode | `true` | adds a button to remove layers | If you are wondering how e.g. the `drawPolygon` button will enable drawing mode with specific options, here it is: Simply enable drawing mode programatically, @@ -240,14 +244,14 @@ Here's a list of layer events you can listen to: | pm:centerplaced | `e` | Called when the center of a circle is placed/moved. | For making the snapping to other layers selective, you can add the "snapIgnore" option to your layers to disable the snapping to them during drawing. + ```js -L.geoJSON(data,{ - snapIgnore : true -}) +L.geoJSON(data, { + snapIgnore: true, +}); //This layer will be ignored by the snapping engine during drawing ``` - ### Edit Mode Let's you edit vertices of layers. Use it like this: @@ -324,6 +328,7 @@ map.on('pm:globaleditmodetoggled', e => { console.log(e); }); ``` + The event has an object with an enabled boolean and a reference to the map. ### Drag Mode @@ -355,6 +360,7 @@ map.on('pm:globaldrawmodetoggled', e => { console.log(e); }); ``` + The event has an object with an enabled boolean and a reference to the map. ### Removal Mode @@ -385,6 +391,7 @@ map.on('pm:globalremovalmodetoggled', e => { console.log(e); }); ``` + The event has an object with an enabled boolean and a reference to the map. ### Cutting Mode @@ -526,4 +533,4 @@ I also took a hard look at the great [L.GeometryUtil](https://github.com/makinacorpus/Leaflet.GeometryUtil) for some of my helper functions. -If you want to support the development of leaflet-geoman, consider subscribing to the services of [Geoman](https://geoman.io). \ No newline at end of file +If you want to support the development of leaflet-geoman, consider subscribing to the services of [Geoman](https://geoman.io). diff --git a/src/js/Draw/L.PM.Draw.CircleMarker.js b/src/js/Draw/L.PM.Draw.CircleMarker.js index 36a2ac30..7d21ae92 100644 --- a/src/js/Draw/L.PM.Draw.CircleMarker.js +++ b/src/js/Draw/L.PM.Draw.CircleMarker.js @@ -60,7 +60,12 @@ Draw.CircleMarker = Draw.Marker.extend({ }); }, isRelevantMarker(layer) { - return layer instanceof L.CircleMarker && !(layer instanceof L.Circle) && layer.pm && !layer._pmTempLayer; + return ( + layer instanceof L.CircleMarker && + !(layer instanceof L.Circle) && + layer.pm && + !layer._pmTempLayer + ); }, _createMarker(e) { if (!e.latlng) { @@ -83,6 +88,7 @@ Draw.CircleMarker = Draw.Marker.extend({ marker.addTo(this._map); // enable editing for the marker + marker.pm = marker.pm || new L.PM.Edit.CircleMarker(marker); marker.pm.enable(); // fire the pm:create event and pass shape and marker diff --git a/src/js/Draw/L.PM.Draw.Cut.js b/src/js/Draw/L.PM.Draw.Cut.js index 52be391a..3b909fd2 100644 --- a/src/js/Draw/L.PM.Draw.Cut.js +++ b/src/js/Draw/L.PM.Draw.Cut.js @@ -42,8 +42,15 @@ Draw.Cut = Draw.Polygon.extend({ resultingLayer.addTo(this._map); // give the new layer the original options - resultingLayer.pm.enable(this.options); - resultingLayer.pm.disable(); + // resultingLayer.pm = + // resultingLayer.pm || new L.PM.Edit[this._shape](resultingLayer); + console.log('resulting layer'); + console.log(resultingLayer); + if (resultingLayer.pm) { + console.log('resulting layer already has pm object'); + resultingLayer.pm.enable(this.options); + resultingLayer.pm.disable(); + } // fire pm:cut on the cutted layer l.fire('pm:cut', { diff --git a/src/js/Draw/L.PM.Draw.Marker.js b/src/js/Draw/L.PM.Draw.Marker.js index 5a24b860..90ba053b 100644 --- a/src/js/Draw/L.PM.Draw.Marker.js +++ b/src/js/Draw/L.PM.Draw.Marker.js @@ -129,6 +129,7 @@ Draw.Marker = Draw.extend({ marker.addTo(this._map); // enable editing for the marker + marker.pm = marker.pm || new L.PM.Edit.Marker(marker); marker.pm.enable(); // fire the pm:create event and pass shape and marker diff --git a/src/js/L.PM.Map.js b/src/js/L.PM.Map.js index aaec9eaf..75188ecc 100644 --- a/src/js/L.PM.Map.js +++ b/src/js/L.PM.Map.js @@ -70,7 +70,6 @@ const Map = L.Class.extend({ return layers; }, removeLayer(e) { - const layer = e.target; // only remove layer, if it's handled by leaflet-geoman, // not a tempLayer and not currently being dragged @@ -99,7 +98,7 @@ const Map = L.Class.extend({ // toogle the button in the toolbar if this is called programatically this.Toolbar.toggleButton('dragMode', this._globalDragMode); - + this._fireDragModeEvent(true); }, disableGlobalDragMode() { @@ -197,9 +196,9 @@ const Map = L.Class.extend({ }, _fireRemovalModeEvent(enabled) { this.map.fire('pm:globalremovalmodetoggled', { - enabled, - map: this.map, - }); + enabled, + map: this.map, + }); }, toggleGlobalRemovalMode() { // toggle global edit mode diff --git a/src/js/L.PM.js b/src/js/L.PM.js index abadb1c1..30f0a051 100644 --- a/src/js/L.PM.js +++ b/src/js/L.PM.js @@ -32,6 +32,11 @@ import './Edit/L.PM.Edit.CircleMarker'; import '../css/layers.css'; import '../css/controls.css'; +const useTypes = { + ALL_LEAFLET_LAYERS: 'ALL_LEAFLET_LAYERS', + GEOMAN_LAYERS_ONLY: 'GEOMAN_LAYERS_ONLY', +}; + L.PM = L.PM || { version, Map, @@ -42,115 +47,51 @@ L.PM = L.PM || { initialize(options) { this.addInitHooks(options); }, - addInitHooks(options = {}) { - - function initMap() { - this.pm = undefined; - - if (options.optIn) { - if (this.options.pmIgnore === false) { - this.pm = new L.PM.Map(this); - } - } else if (!this.options.pmIgnore) { - this.pm = new L.PM.Map(this); - } - } - - L.Map.addInitHook(initMap); - - function initLayerGroup() { - // doesn't need pmIgnore condition as the init hook of the individual layers will check it - this.pm = new L.PM.Edit.LayerGroup(this); - } - - L.LayerGroup.addInitHook(initLayerGroup); - - function initMarker() { - this.pm = undefined; - - if (options.optIn) { - if (this.options.pmIgnore === false) { - this.pm = new L.PM.Edit.Marker(this); - } - } else if (!this.options.pmIgnore) { - this.pm = new L.PM.Edit.Marker(this); - } - } - - L.Marker.addInitHook(initMarker); - - function initCircleMarker() { - this.pm = undefined; - - if (options.optIn) { - if (this.options.pmIgnore === false) { - this.pm = new L.PM.Edit.CircleMarker(this); - } - } else if (!this.options.pmIgnore) { - this.pm = new L.PM.Edit.CircleMarker(this); - } - } - L.CircleMarker.addInitHook(initCircleMarker); - + addInitHooks(options) { + // eslint-disable-next-line func-names + L.Map.addInitHook(function() { + this.pm = new L.PM.Map(this); + }); - function initPolyline() { - this.pm = undefined; + console.log(options); - if (options.optIn) { - if (this.options.pmIgnore === false) { - this.pm = new L.PM.Edit.Line(this); - } - } else if (!this.options.pmIgnore) { - this.pm = new L.PM.Edit.Line(this); - } + if (options.useType === useTypes.GEOMAN_LAYERS_ONLY) { + return; } - L.Polyline.addInitHook(initPolyline); - - function initPolygon() { - this.pm = undefined; - - if (options.optIn) { - if (this.options.pmIgnore === false) { - this.pm = new L.PM.Edit.Polygon(this); - } - } else if (!this.options.pmIgnore) { - this.pm = new L.PM.Edit.Polygon(this); - } - - } - - L.Polygon.addInitHook(initPolygon); - - function initRectangle() { - this.pm = undefined; - - if (options.optIn) { - if (this.options.pmIgnore === false) { - this.pm = new L.PM.Edit.Rectangle(this); - } - } else if (!this.options.pmIgnore) { - this.pm = new L.PM.Edit.Rectangle(this); - } - } - - L.Rectangle.addInitHook(initRectangle); - - function initCircle() { - this.pm = undefined; - - if (options.optIn) { - if (this.options.pmIgnore === false) { - this.pm = new L.PM.Edit.Circle(this); - } - } else if (!this.options.pmIgnore) { - this.pm = new L.PM.Edit.Circle(this); - } - } - - L.Circle.addInitHook(initCircle); + // eslint-disable-next-line func-names + L.LayerGroup.addInitHook(function() { + this.pm = new L.PM.Edit.LayerGroup(this); + }); + + // eslint-disable-next-line func-names + L.Marker.addInitHook(function() { + this.pm = new L.PM.Edit.Marker(this); + }); + + // eslint-disable-next-line func-names + L.CircleMarker.addInitHook(function() { + this.pm = new L.PM.Edit.CircleMarker(this); + }); + + // eslint-disable-next-line func-names + L.Polyline.addInitHook(function() { + this.pm = new L.PM.Edit.Line(this); + }); + + // eslint-disable-next-line func-names + L.Polygon.addInitHook(function() { + this.pm = new L.PM.Edit.Polygon(this); + }); + + // eslint-disable-next-line func-names + L.Rectangle.addInitHook(function() { + this.pm = new L.PM.Edit.Rectangle(this); + }); + + // eslint-disable-next-line func-names + L.Circle.addInitHook(function() { + this.pm = new L.PM.Edit.Circle(this); + }); }, }; - -// initialize leaflet-geoman -L.PM.initialize(); diff --git a/src/js/Mixins/Snapping.js b/src/js/Mixins/Snapping.js index 22a71b83..b9fc80b3 100644 --- a/src/js/Mixins/Snapping.js +++ b/src/js/Mixins/Snapping.js @@ -221,7 +221,7 @@ const SnapMixin = { layers.push(layer); // this is for debugging - const debugLine = L.polyline([], { color: 'red', pmIgnore: true }); + const debugLine = L.polyline([], { color: 'red' }); debugLine._pmTempLayer = true; debugIndicatorLines.push(debugLine); From 0d293a9da9d2e06356826a4047485ec7aee47e43 Mon Sep 17 00:00:00 2001 From: Peter Pult Date: Wed, 16 Oct 2019 10:09:12 +0200 Subject: [PATCH 2/3] chore: remove logs --- src/js/Draw/L.PM.Draw.Cut.js | 5 ----- src/js/L.PM.js | 2 -- 2 files changed, 7 deletions(-) diff --git a/src/js/Draw/L.PM.Draw.Cut.js b/src/js/Draw/L.PM.Draw.Cut.js index 3b909fd2..aeb12fd5 100644 --- a/src/js/Draw/L.PM.Draw.Cut.js +++ b/src/js/Draw/L.PM.Draw.Cut.js @@ -42,12 +42,7 @@ Draw.Cut = Draw.Polygon.extend({ resultingLayer.addTo(this._map); // give the new layer the original options - // resultingLayer.pm = - // resultingLayer.pm || new L.PM.Edit[this._shape](resultingLayer); - console.log('resulting layer'); - console.log(resultingLayer); if (resultingLayer.pm) { - console.log('resulting layer already has pm object'); resultingLayer.pm.enable(this.options); resultingLayer.pm.disable(); } diff --git a/src/js/L.PM.js b/src/js/L.PM.js index 30f0a051..5e918f35 100644 --- a/src/js/L.PM.js +++ b/src/js/L.PM.js @@ -53,8 +53,6 @@ L.PM = L.PM || { this.pm = new L.PM.Map(this); }); - console.log(options); - if (options.useType === useTypes.GEOMAN_LAYERS_ONLY) { return; } From 2a2e15158e8837d6cc141d20bb966e8cf9db83ea Mon Sep 17 00:00:00 2001 From: Peter Pult Date: Thu, 17 Oct 2019 15:40:09 +0200 Subject: [PATCH 3/3] make dist available for delivering --- .gitignore | 5 +- dist/leaflet-geoman.css | 164 +++++++++++++++++++++++++++++++++++++ dist/leaflet-geoman.min.js | 1 + 3 files changed, 168 insertions(+), 2 deletions(-) create mode 100644 dist/leaflet-geoman.css create mode 100644 dist/leaflet-geoman.min.js diff --git a/.gitignore b/.gitignore index b4f9a3f1..e5d8f85f 100644 --- a/.gitignore +++ b/.gitignore @@ -3,7 +3,8 @@ npm-debug.log /node_modules/ /bower_components/ /.idea/ -/dist/ \.source* /cypress/screenshots -/cypress/videos \ No newline at end of file +/cypress/videos + +# /dist/ \ No newline at end of file diff --git a/dist/leaflet-geoman.css b/dist/leaflet-geoman.css new file mode 100644 index 00000000..9cad5938 --- /dev/null +++ b/dist/leaflet-geoman.css @@ -0,0 +1,164 @@ +.marker-icon, +.marker-icon:focus { + background-color: #ffffff; + border: 1px solid #3388ff; + border-radius: 50%; + margin: -8px 0 0 -8px !important; + width: 14px !important; + height: 14px !important; + outline: 0; + transition: opacity ease 0.3s; +} + +.marker-icon-middle, +.marker-icon-middle:focus { + opacity: 0.7; + margin: -6px 0 0 -6px !important; + width: 10px !important; + height: 10px !important; +} + +.leaflet-pm-draggable { + cursor: move !important; +} + +.cursor-marker { + cursor: crosshair; + pointer-events: none; + display: none; +} + +.cursor-marker.visible { + display: block !important; +} + +.leaflet-pm-invalid { + stroke: red; + transition: fill ease 0s, stroke ease 0s; +} + +.rect-style-marker, +.rect-start-marker { + opacity: 0; +} + +.rect-style-marker.visible, +.rect-start-marker.visible { + opacity: 1 !important; +} + +.hidden { + display: none; +} + +.leaflet-pm-toolbar { +} + +.leaflet-pm-toolbar .leaflet-buttons-control-button { + padding: 5px; + box-sizing: border-box; + position: relative; + z-index: 3; +} + +.leaflet-pm-toolbar .control-fa-icon { + font-size: 19px; + line-height: 24px; +} + +.leaflet-pm-toolbar .control-icon { + width: 100%; + height: 100%; + box-sizing: border-box; + background-size: contain; + background-repeat: no-repeat; + background-position: center center; +} + +.leaflet-pm-toolbar .leaflet-pm-icon-marker { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-polygon { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-polyline { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-circle { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-circle-marker { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-rectangle { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-delete { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-edit { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-drag { + background-image: url(); +} +.leaflet-pm-toolbar .leaflet-pm-icon-cut { + background-image: url(); +} + +.leaflet-buttons-control-button:hover { + cursor: pointer; + background-color: #f4f4f4; +} +.active .leaflet-buttons-control-button { + box-shadow: inset 0 -1px 5px 2px rgba(81, 77, 77, 0.31); +} + +.leaflet-buttons-control-text-hide { + display: none; +} + +.button-container { + position: relative; +} + +.button-container .leaflet-pm-actions-container { + z-index: 2; + position: absolute; + top: 0; + left: 31px; + display: none; + white-space: nowrap; +} + +.leaflet-right + .leaflet-pm-toolbar + .button-container + .leaflet-pm-actions-container { + right: 31px; + left: auto; +} + +.button-container.active .leaflet-pm-actions-container { + display: block; +} + +.button-container .leaflet-pm-actions-container .leaflet-pm-action:last-child { + border-radius: 0px 3px 3px 0px; + border-right: 0px; +} +.button-container .leaflet-pm-actions-container .leaflet-pm-action { + padding: 0px 10px; + background-color: #666; + color: #fff; + display: inline-block; + width: auto; + border-right: 1px solid #eee; + user-select: none; +} + +.button-container .leaflet-pm-actions-container .leaflet-pm-action:hover { + cursor: pointer; + background-color: #777; +} + diff --git a/dist/leaflet-geoman.min.js b/dist/leaflet-geoman.min.js new file mode 100644 index 00000000..d6f8d13b --- /dev/null +++ b/dist/leaflet-geoman.min.js @@ -0,0 +1 @@ +!function(t){var e={};function r(n){if(e[n])return e[n].exports;var i=e[n]={i:n,l:!1,exports:{}};return t[n].call(i.exports,i,i.exports,r),i.l=!0,i.exports}r.m=t,r.c=e,r.d=function(t,e,n){r.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},r.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},r.t=function(t,e){if(1&e&&(t=r(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var i in t)r.d(n,i,function(e){return t[e]}.bind(null,i));return n},r.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return r.d(e,"a",e),e},r.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},r.p="",r(r.s=55)}([function(t,e,r){var n=r(123);t.exports=function(t,e,r){var i=null==t?void 0:n(t,e);return void 0===i?r:i}},function(t,e,r){"use strict";function n(t,e,r){void 0===r&&(r={});var n={type:"Feature"};return 0!==r.id&&!r.id||(n.id=r.id),r.bbox&&(n.bbox=r.bbox),n.properties=e||{},n.geometry=t,n}function i(t,e,r){return void 0===r&&(r={}),n({type:"Point",coordinates:t},e,r)}function o(t,e,r){void 0===r&&(r={});for(var i=0,o=t;i>1],s=n-1,l=i+1;;){for(;o(e[++s],a)<0;);for(;0n[0]?1:r[0]n[1]?1:-1:function(t,e,r,n){return t.left===e.left?0===_(r,t.otherEvent.point,e.otherEvent.point)?!t.isSubject&&e.isSubject?1:-1:t.isBelow(e.otherEvent.point)?-1:1:t.left?1:-1}(t,e,r)}function y(t,e,r){var n=new d(e,!1,t,t.isSubject),i=new d(e,!0,t.otherEvent,t.isSubject);return g(t.point,t.otherEvent.point)&&console.warn("what is that, a collapsed segment?",t),n.contourId=i.contourId=t.contourId,0e.contourId?1:-1):1===m(t,e)?1:-1}function M(t,e,r,n){var i=t+1,o=e.length;if(o-1>1)-1;0<=r;r--)this._down(r)}function S(t,e){return t>1,o=e[i];if(0<=r(n,o))break;e[t]=o,t=i}e[t]=n},_down:function(t){for(var e=this.data,r=this.compare,n=this.length>>1,i=e[t];tn[2]||n[0]>r[2]||r[1]>n[3]||n[1]>r[3])&&(i===l?o=T:i===c?o=t:i!==h&&i!==u||(o=t.concat(e))),o}(t,e,o,a,n))?i===T?null:i:function(t,e){var r,n,i,o=function(t){var e,r,n,i,o=[];for(r=0,n=t.length;rg||a===c&&_.point[0]>i[2])break;if(_.left){h=s=f.insert(_),s=s!==(u=f.minNode())?f.prev(s):null,h=f.next(h);var m=s?s.key:null;if(p(_,m,a),h&&2===L(_,h.key,t)&&(p(_,m,a),p(_,h.key,a)),s&&2===L(s.key,_,t)){var y=s;p(m,(y=y!==u?f.prev(y):null)?y.key:null,a),p(_,m,a)}}else _=_.otherEvent,h=s=f.find(_),s&&h&&(s=s!==u?f.prev(s):null,h=f.next(h),f.remove(_),h&&s&&L(s.key,h.key,t))}return d}(s,0,0,o,a,n),n)}var j={UNION:h,DIFFERENCE:c,INTERSECTION:l,XOR:u};t.union=function(t,e){return D(t,e,h)},t.diff=function(t,e){return D(t,e,c)},t.xor=function(t,e){return D(t,e,u)},t.intersection=function(t,e){return D(t,e,l)},t.operations=j,Object.defineProperty(t,"__esModule",{value:!0})}(e)},function(t,e,r){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n=r(1);function i(t,e,r){if(null!==t)for(var n,o,a,s,l,h,c,u,p=0,f=0,d=t.type,g="FeatureCollection"===d,_="Feature"===d,m=g?t.features.length:1,y=0;y>>0,n=arguments[1],i=0;i>>0,n=arguments[1],i=0;i=u.length?void 0:a+1),l!==h){var p=u[h],f=u[l];this._createMiddleMarker(p,f)}u.splice(a,1),this._fireEdit(),this._layer.fire("pm:vertexremoved",{layer:this._layer,marker:r,indexPath:o})}},findDeepMarkerIndex:function(t,e){var r;t.some(function t(n){return function(i,o){var a=n.concat(o);return i._leaflet_id===e._leaflet_id?(r=a,!0):Array.isArray(i)&&i.some(t(a))}}([]));var n={};return r&&(n={indexPath:r,index:r[r.length-1],parentPath:r.slice(0,r.length-1)}),n},updatePolygonCoordsFromMarkerDrag:function(t){var e=this._layer.getLatLngs(),r=t.getLatLng(),n=this.findDeepMarkerIndex(this._markers,t),i=n.indexPath,o=n.index,a=n.parentPath;(1