/* Leaflet.draw 1.0.4, a plugin that adds drawing and editing tools to Leaflet powered maps. (c) 2012-2017, Jacob Toye, Jon West, Smartrak, Leaflet https://github.com/Leaflet/Leaflet.draw http://leafletjs.com */ !(function (t, e, i) { function o(t, e) { for (; (t = t.parentElement) && !t.classList.contains(e); ); return t; } (L.drawVersion = "1.0.4"), (L.Draw = {}), (L.drawLocal = { draw: { toolbar: { actions: { title: "Cancel disegno", text: "Cancella" }, finish: { title: "Finisci disegno", text: "Finisci" }, undo: { title: "Cancella ultimo punto disegnato", text: "Cancella ultimo punto" }, buttons: { polyline: "Disegna una polilinea", polygon: "Disegna un poligono", rectangle: "Disegna un rettangolo", circle: "Disegna un un cerchio", marker: "Disegna un marker", circlemarker: "Disegna un circlemarker" }, }, handlers: { circle: { tooltip: { start: "Click and drag to draw circle." }, radius: "Radius" }, circlemarker: { tooltip: { start: "Click sulla mappa e posizione il marker." } }, marker: { tooltip: { start: "Click sulla mappa e posizione il marker." } }, polygon: { tooltip: { start: "Click per iniziare a disegnare.", cont: "Click per continuare a disegnare.", end: "Click sul primo punto per chiudere il disegno." } }, polyline: { error: "Error: shape edges cannot cross!", tooltip: { start: "Click per iniziare a disegnare una linea.", cont: "Click per continuare a disegnare una linea.", end: "Click ultimo punto per finire linea." } }, rectangle: { tooltip: { start: "Click and muovi per disegnare un rettangolo." } }, simpleshape: { tooltip: { end: "Rilascia il mouse per finire il disegno." } }, }, }, edit: { toolbar: { actions: { save: { title: "Salva modifiche", text: "Salva" }, cancel: { title: "Cancella modifiche, discards all changes", text: "Cancel" }, clearAll: { title: "Cancella tutti i layers", text: "Cancella tutto" } }, buttons: { edit: "Modifica layers", editDisabled: "Nessun layer da modificare", remove: "Cancella layer", removeDisabled: "Nessun layer da cancellare" }, }, handlers: { edit: { tooltip: { text: "Drag handles or markers to edit features.", subtext: "Click cancel to undo changes." } }, remove: { tooltip: { text: "Click on a feature to remove." } } }, }, }), (L.Draw.Event = {}), (L.Draw.Event.CREATED = "draw:created"), (L.Draw.Event.EDITED = "draw:edited"), (L.Draw.Event.DELETED = "draw:deleted"), (L.Draw.Event.DRAWSTART = "draw:drawstart"), (L.Draw.Event.DRAWSTOP = "draw:drawstop"), (L.Draw.Event.DRAWVERTEX = "draw:drawvertex"), (L.Draw.Event.EDITSTART = "draw:editstart"), (L.Draw.Event.EDITMOVE = "draw:editmove"), (L.Draw.Event.EDITRESIZE = "draw:editresize"), (L.Draw.Event.EDITVERTEX = "draw:editvertex"), (L.Draw.Event.EDITSTOP = "draw:editstop"), (L.Draw.Event.DELETESTART = "draw:deletestart"), (L.Draw.Event.DELETESTOP = "draw:deletestop"), (L.Draw.Event.TOOLBAROPENED = "draw:toolbaropened"), (L.Draw.Event.TOOLBARCLOSED = "draw:toolbarclosed"), (L.Draw.Event.MARKERCONTEXT = "draw:markercontext"), (L.Draw = L.Draw || {}), (L.Draw.Feature = L.Handler.extend({ initialize: function (t, e) { (this._map = t), (this._container = t._container), (this._overlayPane = t._panes.overlayPane), (this._popupPane = t._panes.popupPane), e && e.shapeOptions && (e.shapeOptions = L.Util.extend({}, this.options.shapeOptions, e.shapeOptions)), L.setOptions(this, e); var i = L.version.split("."); 1 === parseInt(i[0], 10) && parseInt(i[1], 10) >= 2 ? L.Draw.Feature.include(L.Evented.prototype) : L.Draw.Feature.include(L.Mixin.Events); }, enable: function () { this._enabled || (L.Handler.prototype.enable.call(this), this.fire("enabled", { handler: this.type }), this._map.fire(L.Draw.Event.DRAWSTART, { layerType: this.type })); }, disable: function () { this._enabled && (L.Handler.prototype.disable.call(this), this._map.fire(L.Draw.Event.DRAWSTOP, { layerType: this.type }), this.fire("disabled", { handler: this.type })); }, addHooks: function () { var t = this._map; t && (L.DomUtil.disableTextSelection(), t.getContainer().focus(), (this._tooltip = new L.Draw.Tooltip(this._map)), L.DomEvent.on(this._container, "keyup", this._cancelDrawing, this)); }, removeHooks: function () { this._map && (L.DomUtil.enableTextSelection(), this._tooltip.dispose(), (this._tooltip = null), L.DomEvent.off(this._container, "keyup", this._cancelDrawing, this)); }, setOptions: function (t) { L.setOptions(this, t); }, _fireCreatedEvent: function (t) { this._map.fire(L.Draw.Event.CREATED, { layer: t, layerType: this.type }); }, _cancelDrawing: function (t) { 27 === t.keyCode && (this._map.fire("draw:canceled", { layerType: this.type }), this.disable()); }, })), (L.Draw.Polyline = L.Draw.Feature.extend({ statics: { TYPE: "polyline" }, Poly: L.Polyline, options: { allowIntersection: !0, repeatMode: !1, drawError: { color: "#b00b00", timeout: 2500 }, icon: new L.DivIcon({ iconSize: new L.Point(8, 8), className: "leaflet-div-icon leaflet-editing-icon" }), touchIcon: new L.DivIcon({ iconSize: new L.Point(20, 20), className: "leaflet-div-icon leaflet-editing-icon leaflet-touch-icon" }), guidelineDistance: 20, maxGuideLineLength: 4e3, shapeOptions: { stroke: !0, color: "#3388ff", weight: 4, opacity: 0.5, fill: !1, clickable: !0 }, metric: !0, feet: !0, nautic: !1, showLength: !0, zIndexOffset: 2e3, factor: 1, maxPoints: 0, }, initialize: function (t, e) { L.Browser.touch && (this.options.icon = this.options.touchIcon), (this.options.drawError.message = L.drawLocal.draw.handlers.polyline.error), e && e.drawError && (e.drawError = L.Util.extend({}, this.options.drawError, e.drawError)), (this.type = L.Draw.Polyline.TYPE), L.Draw.Feature.prototype.initialize.call(this, t, e); }, addHooks: function () { L.Draw.Feature.prototype.addHooks.call(this), this._map && ((this._markers = []), (this._markerGroup = new L.LayerGroup()), this._map.addLayer(this._markerGroup), (this._poly = new L.Polyline([], this.options.shapeOptions)), this._tooltip.updateContent(this._getTooltipText()), this._mouseMarker || (this._mouseMarker = L.marker(this._map.getCenter(), { icon: L.divIcon({ className: "leaflet-mouse-marker", iconAnchor: [20, 20], iconSize: [40, 40] }), opacity: 0, zIndexOffset: this.options.zIndexOffset })), this._mouseMarker.on("mouseout", this._onMouseOut, this).on("mousemove", this._onMouseMove, this).on("mousedown", this._onMouseDown, this).on("mouseup", this._onMouseUp, this).addTo(this._map), this._map.on("mouseup", this._onMouseUp, this).on("mousemove", this._onMouseMove, this).on("zoomlevelschange", this._onZoomEnd, this).on("touchstart", this._onTouch, this).on("zoomend", this._onZoomEnd, this)); }, removeHooks: function () { L.Draw.Feature.prototype.removeHooks.call(this), this._clearHideErrorTimeout(), this._cleanUpShape(), this._map.removeLayer(this._markerGroup), delete this._markerGroup, delete this._markers, this._map.removeLayer(this._poly), delete this._poly, this._mouseMarker.off("mousedown", this._onMouseDown, this).off("mouseout", this._onMouseOut, this).off("mouseup", this._onMouseUp, this).off("mousemove", this._onMouseMove, this), this._map.removeLayer(this._mouseMarker), delete this._mouseMarker, this._clearGuides(), this._map .off("mouseup", this._onMouseUp, this) .off("mousemove", this._onMouseMove, this) .off("zoomlevelschange", this._onZoomEnd, this) .off("zoomend", this._onZoomEnd, this) .off("touchstart", this._onTouch, this) .off("click", this._onTouch, this); }, deleteLastVertex: function () { if (!(this._markers.length <= 1)) { var t = this._markers.pop(), e = this._poly, i = e.getLatLngs(), o = i.splice(-1, 1)[0]; this._poly.setLatLngs(i), this._markerGroup.removeLayer(t), e.getLatLngs().length < 2 && this._map.removeLayer(e), this._vertexChanged(o, !1); } }, addVertex: function (t) { if (this._markers.length >= 2 && !this.options.allowIntersection && this._poly.newLatLngIntersects(t)) return void this._showErrorTooltip(); this._errorShown && this._hideErrorTooltip(), this._markers.push(this._createMarker(t)), this._poly.addLatLng(t), 2 === this._poly.getLatLngs().length && this._map.addLayer(this._poly), this._vertexChanged(t, !0); }, completeShape: function () { this._markers.length <= 1 || !this._shapeIsValid() || (this._fireCreatedEvent(), this.disable(), this.options.repeatMode && this.enable()); }, _finishShape: function () { var t = this._poly._defaultShape ? this._poly._defaultShape() : this._poly.getLatLngs(), e = this._poly.newLatLngIntersects(t[t.length - 1]); if ((!this.options.allowIntersection && e) || !this._shapeIsValid()) return void this._showErrorTooltip(); this._fireCreatedEvent(), this.disable(), this.options.repeatMode && this.enable(); }, _shapeIsValid: function () { return !0; }, _onZoomEnd: function () { null !== this._markers && this._updateGuide(); }, _onMouseMove: function (t) { var e = this._map.mouseEventToLayerPoint(t.originalEvent), i = this._map.layerPointToLatLng(e); (this._currentLatLng = i), this._updateTooltip(i), this._updateGuide(e), this._mouseMarker.setLatLng(i), L.DomEvent.preventDefault(t.originalEvent); }, _vertexChanged: function (t, e) { this._map.fire(L.Draw.Event.DRAWVERTEX, { layers: this._markerGroup }), this._updateFinishHandler(), this._updateRunningMeasure(t, e), this._clearGuides(), this._updateTooltip(); }, _onMouseDown: function (t) { if (!this._clickHandled && !this._touchHandled && !this._disableMarkers) { this._onMouseMove(t), (this._clickHandled = !0), this._disableNewMarkers(); var e = t.originalEvent, i = e.clientX, o = e.clientY; this._startPoint.call(this, i, o); } }, _startPoint: function (t, e) { this._mouseDownOrigin = L.point(t, e); }, _onMouseUp: function (t) { var e = t.originalEvent, i = e.clientX, o = e.clientY; this._endPoint.call(this, i, o, t), (this._clickHandled = null); }, _endPoint: function (e, i, o) { if (this._mouseDownOrigin) { var a = L.point(e, i).distanceTo(this._mouseDownOrigin), n = this._calculateFinishDistance(o.latlng); this.options.maxPoints > 1 && this.options.maxPoints == this._markers.length + 1 ? (this.addVertex(o.latlng), this._finishShape()) : n < 10 && L.Browser.touch ? this._finishShape() : Math.abs(a) < 9 * (t.devicePixelRatio || 1) && this.addVertex(o.latlng), this._enableNewMarkers(); } this._mouseDownOrigin = null; }, _onTouch: function (t) { var e, i, o = t.originalEvent; !o.touches || !o.touches[0] || this._clickHandled || this._touchHandled || this._disableMarkers || ((e = o.touches[0].clientX), (i = o.touches[0].clientY), this._disableNewMarkers(), (this._touchHandled = !0), this._startPoint.call(this, e, i), this._endPoint.call(this, e, i, t), (this._touchHandled = null)), (this._clickHandled = null); }, _onMouseOut: function () { this._tooltip && this._tooltip._onMouseOut.call(this._tooltip); }, _calculateFinishDistance: function (t) { var e; if (this._markers.length > 0) { var i; if (this.type === L.Draw.Polyline.TYPE) i = this._markers[this._markers.length - 1]; else { if (this.type !== L.Draw.Polygon.TYPE) return 1 / 0; i = this._markers[0]; } var o = this._map.latLngToContainerPoint(i.getLatLng()), a = new L.Marker(t, { icon: this.options.icon, zIndexOffset: 2 * this.options.zIndexOffset }), n = this._map.latLngToContainerPoint(a.getLatLng()); e = o.distanceTo(n); } else e = 1 / 0; return e; }, _updateFinishHandler: function () { var t = this._markers.length; t > 1 && this._markers[t - 1].on("click", this._finishShape, this), t > 2 && this._markers[t - 2].off("click", this._finishShape, this); }, _createMarker: function (t) { var e = new L.Marker(t, { icon: this.options.icon, zIndexOffset: 2 * this.options.zIndexOffset }); return this._markerGroup.addLayer(e), e; }, _updateGuide: function (t) { var e = this._markers ? this._markers.length : 0; e > 0 && ((t = t || this._map.latLngToLayerPoint(this._currentLatLng)), this._clearGuides(), this._drawGuide(this._map.latLngToLayerPoint(this._markers[e - 1].getLatLng()), t)); }, _updateTooltip: function (t) { var e = this._getTooltipText(); t && this._tooltip.updatePosition(t), this._errorShown || this._tooltip.updateContent(e); }, _drawGuide: function (t, e) { var i, o, a, n = Math.floor(Math.sqrt(Math.pow(e.x - t.x, 2) + Math.pow(e.y - t.y, 2))), s = this.options.guidelineDistance, r = this.options.maxGuideLineLength, l = n > r ? n - r : s; for (this._guidesContainer || (this._guidesContainer = L.DomUtil.create("div", "leaflet-draw-guides", this._overlayPane)); l < n; l += this.options.guidelineDistance) (i = l / n), (o = { x: Math.floor(t.x * (1 - i) + i * e.x), y: Math.floor(t.y * (1 - i) + i * e.y) }), (a = L.DomUtil.create("div", "leaflet-draw-guide-dash", this._guidesContainer)), (a.style.backgroundColor = this._errorShown ? this.options.drawError.color : this.options.shapeOptions.color), L.DomUtil.setPosition(a, o); }, _updateGuideColor: function (t) { if (this._guidesContainer) for (var e = 0, i = this._guidesContainer.childNodes.length; e < i; e++) this._guidesContainer.childNodes[e].style.backgroundColor = t; }, _clearGuides: function () { if (this._guidesContainer) for (; this._guidesContainer.firstChild; ) this._guidesContainer.removeChild(this._guidesContainer.firstChild); }, _getTooltipText: function () { var t, e, i = this.options.showLength; return ( 0 === this._markers.length ? (t = { text: L.drawLocal.draw.handlers.polyline.tooltip.start }) : ((e = i ? this._getMeasurementString() : ""), (t = 1 === this._markers.length ? { text: L.drawLocal.draw.handlers.polyline.tooltip.cont, subtext: e } : { text: L.drawLocal.draw.handlers.polyline.tooltip.end, subtext: e })), t ); }, _updateRunningMeasure: function (t, e) { var i, o, a = this._markers.length; 1 === this._markers.length ? (this._measurementRunningTotal = 0) : ((i = a - (e ? 2 : 1)), (o = L.GeometryUtil.isVersion07x() ? t.distanceTo(this._markers[i].getLatLng()) * (this.options.factor || 1) : this._map.distance(t, this._markers[i].getLatLng()) * (this.options.factor || 1)), (this._measurementRunningTotal += o * (e ? 1 : -1))); }, _getMeasurementString: function () { var t, e = this._currentLatLng, i = this._markers[this._markers.length - 1].getLatLng(); return ( (t = L.GeometryUtil.isVersion07x() ? i && e && e.distanceTo ? this._measurementRunningTotal + e.distanceTo(i) * (this.options.factor || 1) : this._measurementRunningTotal || 0 : i && e ? this._measurementRunningTotal + this._map.distance(e, i) * (this.options.factor || 1) : this._measurementRunningTotal || 0), L.GeometryUtil.readableDistance(t, this.options.metric, this.options.feet, this.options.nautic, this.options.precision) ); }, _showErrorTooltip: function () { (this._errorShown = !0), this._tooltip.showAsError().updateContent({ text: this.options.drawError.message }), this._updateGuideColor(this.options.drawError.color), this._poly.setStyle({ color: this.options.drawError.color }), this._clearHideErrorTimeout(), (this._hideErrorTimeout = setTimeout(L.Util.bind(this._hideErrorTooltip, this), this.options.drawError.timeout)); }, _hideErrorTooltip: function () { (this._errorShown = !1), this._clearHideErrorTimeout(), this._tooltip.removeError().updateContent(this._getTooltipText()), this._updateGuideColor(this.options.shapeOptions.color), this._poly.setStyle({ color: this.options.shapeOptions.color }); }, _clearHideErrorTimeout: function () { this._hideErrorTimeout && (clearTimeout(this._hideErrorTimeout), (this._hideErrorTimeout = null)); }, _disableNewMarkers: function () { this._disableMarkers = !0; }, _enableNewMarkers: function () { setTimeout( function () { this._disableMarkers = !1; }.bind(this), 50 ); }, _cleanUpShape: function () { this._markers.length > 1 && this._markers[this._markers.length - 1].off("click", this._finishShape, this); }, _fireCreatedEvent: function () { var t = new this.Poly(this._poly.getLatLngs(), this.options.shapeOptions); L.Draw.Feature.prototype._fireCreatedEvent.call(this, t); }, })), (L.Draw.Polygon = L.Draw.Polyline.extend({ statics: { TYPE: "polygon" }, Poly: L.Polygon, options: { showArea: !1, showLength: !1, shapeOptions: { stroke: !0, color: "#3388ff", weight: 4, opacity: 0.5, fill: !0, fillColor: null, fillOpacity: 0.2, clickable: !0 }, metric: !0, feet: !0, nautic: !1, precision: {} }, initialize: function (t, e) { L.Draw.Polyline.prototype.initialize.call(this, t, e), (this.type = L.Draw.Polygon.TYPE); }, _updateFinishHandler: function () { var t = this._markers.length; 1 === t && this._markers[0].on("click", this._finishShape, this), t > 2 && (this._markers[t - 1].on("dblclick", this._finishShape, this), t > 3 && this._markers[t - 2].off("dblclick", this._finishShape, this)); }, _getTooltipText: function () { var t, e; return ( 0 === this._markers.length ? (t = L.drawLocal.draw.handlers.polygon.tooltip.start) : this._markers.length < 3 ? ((t = L.drawLocal.draw.handlers.polygon.tooltip.cont), (e = this._getMeasurementString())) : ((t = L.drawLocal.draw.handlers.polygon.tooltip.end), (e = this._getMeasurementString())), { text: t, subtext: e } ); }, _getMeasurementString: function () { var t = this._area, e = ""; return t || this.options.showLength ? (this.options.showLength && (e = L.Draw.Polyline.prototype._getMeasurementString.call(this)), t && (e += "
" + L.GeometryUtil.readableArea(t, this.options.metric, this.options.precision)), e) : null; }, _shapeIsValid: function () { return this._markers.length >= 3; }, _vertexChanged: function (t, e) { var i; !this.options.allowIntersection && this.options.showArea && ((i = this._poly.getLatLngs()), (this._area = L.GeometryUtil.geodesicArea(i))), L.Draw.Polyline.prototype._vertexChanged.call(this, t, e); }, _cleanUpShape: function () { var t = this._markers.length; t > 0 && (this._markers[0].off("click", this._finishShape, this), t > 2 && this._markers[t - 1].off("dblclick", this._finishShape, this)); }, })), (L.SimpleShape = {}), (L.Draw.SimpleShape = L.Draw.Feature.extend({ options: { repeatMode: !1 }, initialize: function (t, e) { (this._endLabelText = L.drawLocal.draw.handlers.simpleshape.tooltip.end), L.Draw.Feature.prototype.initialize.call(this, t, e); }, addHooks: function () { L.Draw.Feature.prototype.addHooks.call(this), this._map && ((this._mapDraggable = this._map.dragging.enabled()), this._mapDraggable && this._map.dragging.disable(), (this._container.style.cursor = "crosshair"), this._tooltip.updateContent({ text: this._initialLabelText }), this._map.on("mousedown", this._onMouseDown, this).on("mousemove", this._onMouseMove, this).on("touchstart", this._onMouseDown, this).on("touchmove", this._onMouseMove, this), e.addEventListener("touchstart", L.DomEvent.preventDefault, { passive: !1 })); }, removeHooks: function () { L.Draw.Feature.prototype.removeHooks.call(this), this._map && (this._mapDraggable && this._map.dragging.enable(), (this._container.style.cursor = ""), this._map.off("mousedown", this._onMouseDown, this).off("mousemove", this._onMouseMove, this).off("touchstart", this._onMouseDown, this).off("touchmove", this._onMouseMove, this), L.DomEvent.off(e, "mouseup", this._onMouseUp, this), L.DomEvent.off(e, "touchend", this._onMouseUp, this), e.removeEventListener("touchstart", L.DomEvent.preventDefault), this._shape && (this._map.removeLayer(this._shape), delete this._shape)), (this._isDrawing = !1); }, _getTooltipText: function () { return { text: this._endLabelText }; }, _onMouseDown: function (t) { (this._isDrawing = !0), (this._startLatLng = t.latlng), L.DomEvent.on(e, "mouseup", this._onMouseUp, this).on(e, "touchend", this._onMouseUp, this).preventDefault(t.originalEvent); }, _onMouseMove: function (t) { var e = t.latlng; this._tooltip.updatePosition(e), this._isDrawing && (this._tooltip.updateContent(this._getTooltipText()), this._drawShape(e)); }, _onMouseUp: function () { this._shape && this._fireCreatedEvent(), this.disable(), this.options.repeatMode && this.enable(); }, })), (L.Draw.Rectangle = L.Draw.SimpleShape.extend({ statics: { TYPE: "rectangle" }, options: { shapeOptions: { stroke: !0, color: "#3388ff", weight: 4, opacity: 0.5, fill: !0, fillColor: null, fillOpacity: 0.2, clickable: !0 }, showArea: !0, metric: !0 }, initialize: function (t, e) { (this.type = L.Draw.Rectangle.TYPE), (this._initialLabelText = L.drawLocal.draw.handlers.rectangle.tooltip.start), L.Draw.SimpleShape.prototype.initialize.call(this, t, e); }, disable: function () { this._enabled && ((this._isCurrentlyTwoClickDrawing = !1), L.Draw.SimpleShape.prototype.disable.call(this)); }, _onMouseUp: function (t) { if (!this._shape && !this._isCurrentlyTwoClickDrawing) return void (this._isCurrentlyTwoClickDrawing = !0); (this._isCurrentlyTwoClickDrawing && !o(t.target, "leaflet-pane")) || L.Draw.SimpleShape.prototype._onMouseUp.call(this); }, _drawShape: function (t) { this._shape ? this._shape.setBounds(new L.LatLngBounds(this._startLatLng, t)) : ((this._shape = new L.Rectangle(new L.LatLngBounds(this._startLatLng, t), this.options.shapeOptions)), this._map.addLayer(this._shape)); }, _fireCreatedEvent: function () { var t = new L.Rectangle(this._shape.getBounds(), this.options.shapeOptions); L.Draw.SimpleShape.prototype._fireCreatedEvent.call(this, t); }, _getTooltipText: function () { var t, e, i, o = L.Draw.SimpleShape.prototype._getTooltipText.call(this), a = this._shape, n = this.options.showArea; return ( a && ((t = this._shape._defaultShape ? this._shape._defaultShape() : this._shape.getLatLngs()), (e = L.GeometryUtil.geodesicArea(t)), (i = n ? L.GeometryUtil.readableArea(e, this.options.metric) : "")), { text: o.text, subtext: i } ); }, })), (L.Draw.Marker = L.Draw.Feature.extend({ statics: { TYPE: "marker" }, options: { icon: new L.Icon.Default(), repeatMode: !1, zIndexOffset: 2e3 }, initialize: function (t, e) { (this.type = L.Draw.Marker.TYPE), (this._initialLabelText = L.drawLocal.draw.handlers.marker.tooltip.start), L.Draw.Feature.prototype.initialize.call(this, t, e); }, addHooks: function () { L.Draw.Feature.prototype.addHooks.call(this), this._map && (this._tooltip.updateContent({ text: this._initialLabelText }), this._mouseMarker || (this._mouseMarker = L.marker(this._map.getCenter(), { icon: L.divIcon({ className: "leaflet-mouse-marker", iconAnchor: [20, 20], iconSize: [40, 40] }), opacity: 0, zIndexOffset: this.options.zIndexOffset })), this._mouseMarker.on("click", this._onClick, this).addTo(this._map), this._map.on("mousemove", this._onMouseMove, this), this._map.on("click", this._onTouch, this)); }, removeHooks: function () { L.Draw.Feature.prototype.removeHooks.call(this), this._map && (this._map.off("click", this._onClick, this).off("click", this._onTouch, this), this._marker && (this._marker.off("click", this._onClick, this), this._map.removeLayer(this._marker), delete this._marker), this._mouseMarker.off("click", this._onClick, this), this._map.removeLayer(this._mouseMarker), delete this._mouseMarker, this._map.off("mousemove", this._onMouseMove, this)); }, _onMouseMove: function (t) { var e = t.latlng; this._tooltip.updatePosition(e), this._mouseMarker.setLatLng(e), this._marker ? ((e = this._mouseMarker.getLatLng()), this._marker.setLatLng(e)) : ((this._marker = this._createMarker(e)), this._marker.on("click", this._onClick, this), this._map.on("click", this._onClick, this).addLayer(this._marker)); }, _createMarker: function (t) { return new L.Marker(t, { icon: this.options.icon, zIndexOffset: this.options.zIndexOffset }); }, _onClick: function () { this._fireCreatedEvent(), this.disable(), this.options.repeatMode && this.enable(); }, _onTouch: function (t) { this._onMouseMove(t), this._onClick(); }, _fireCreatedEvent: function () { var t = new L.Marker.Touch(this._marker.getLatLng(), { icon: this.options.icon }); L.Draw.Feature.prototype._fireCreatedEvent.call(this, t); }, })), (L.Draw.CircleMarker = L.Draw.Marker.extend({ statics: { TYPE: "circlemarker" }, options: { stroke: !0, color: "#3388ff", weight: 4, opacity: 0.5, fill: !0, fillColor: null, fillOpacity: 0.2, clickable: !0, zIndexOffset: 2e3 }, initialize: function (t, e) { (this.type = L.Draw.CircleMarker.TYPE), (this._initialLabelText = L.drawLocal.draw.handlers.circlemarker.tooltip.start), L.Draw.Feature.prototype.initialize.call(this, t, e); }, _fireCreatedEvent: function () { var t = new L.CircleMarker(this._marker.getLatLng(), this.options); L.Draw.Feature.prototype._fireCreatedEvent.call(this, t); }, _createMarker: function (t) { return new L.CircleMarker(t, this.options); }, })), (L.Draw.Circle = L.Draw.SimpleShape.extend({ statics: { TYPE: "circle" }, options: { shapeOptions: { stroke: !0, color: "#3388ff", weight: 4, opacity: 0.5, fill: !0, fillColor: null, fillOpacity: 0.2, clickable: !0 }, showRadius: !0, metric: !0, feet: !0, nautic: !1 }, initialize: function (t, e) { (this.type = L.Draw.Circle.TYPE), (this._initialLabelText = L.drawLocal.draw.handlers.circle.tooltip.start), L.Draw.SimpleShape.prototype.initialize.call(this, t, e); }, _drawShape: function (t) { if (L.GeometryUtil.isVersion07x()) var e = this._startLatLng.distanceTo(t); else var e = this._map.distance(this._startLatLng, t); this._shape ? this._shape.setRadius(e) : ((this._shape = new L.Circle(this._startLatLng, e, this.options.shapeOptions)), this._map.addLayer(this._shape)); }, _fireCreatedEvent: function () { var t = new L.Circle(this._startLatLng, this._shape.getRadius(), this.options.shapeOptions); L.Draw.SimpleShape.prototype._fireCreatedEvent.call(this, t); }, _onMouseMove: function (t) { var e, i = t.latlng, o = this.options.showRadius, a = this.options.metric; if ((this._tooltip.updatePosition(i), this._isDrawing)) { this._drawShape(i), (e = this._shape.getRadius().toFixed(1)); var n = ""; o && (n = L.drawLocal.draw.handlers.circle.radius + ": " + L.GeometryUtil.readableDistance(e, a, this.options.feet, this.options.nautic)), this._tooltip.updateContent({ text: this._endLabelText, subtext: n }); } }, })), (L.Edit = L.Edit || {}), (L.Edit.Marker = L.Handler.extend({ initialize: function (t, e) { (this._marker = t), L.setOptions(this, e); }, addHooks: function () { var t = this._marker; t.dragging.enable(), t.on("dragend", this._onDragEnd, t), this._toggleMarkerHighlight(); }, removeHooks: function () { var t = this._marker; t.dragging.disable(), t.off("dragend", this._onDragEnd, t), this._toggleMarkerHighlight(); }, _onDragEnd: function (t) { var e = t.target; (e.edited = !0), this._map.fire(L.Draw.Event.EDITMOVE, { layer: e }); }, _toggleMarkerHighlight: function () { var t = this._marker._icon; t && ((t.style.display = "none"), L.DomUtil.hasClass(t, "leaflet-edit-marker-selected") ? (L.DomUtil.removeClass(t, "leaflet-edit-marker-selected"), this._offsetMarker(t, -4)) : (L.DomUtil.addClass(t, "leaflet-edit-marker-selected"), this._offsetMarker(t, 4)), (t.style.display = "")); }, _offsetMarker: function (t, e) { var i = parseInt(t.style.marginTop, 10) - e, o = parseInt(t.style.marginLeft, 10) - e; (t.style.marginTop = i + "px"), (t.style.marginLeft = o + "px"); }, })), L.Marker.addInitHook(function () { L.Edit.Marker && ((this.editing = new L.Edit.Marker(this)), this.options.editable && this.editing.enable()); }), (L.Edit = L.Edit || {}), (L.Edit.Poly = L.Handler.extend({ initialize: function (t) { (this.latlngs = [t._latlngs]), t._holes && (this.latlngs = this.latlngs.concat(t._holes)), (this._poly = t), this._poly.on("revert-edited", this._updateLatLngs, this); }, _defaultShape: function () { return L.Polyline._flat ? (L.Polyline._flat(this._poly._latlngs) ? this._poly._latlngs : this._poly._latlngs[0]) : this._poly._latlngs; }, _eachVertexHandler: function (t) { for (var e = 0; e < this._verticesHandlers.length; e++) t(this._verticesHandlers[e]); }, addHooks: function () { this._initHandlers(), this._eachVertexHandler(function (t) { t.addHooks(); }); }, removeHooks: function () { this._eachVertexHandler(function (t) { t.removeHooks(); }); }, updateMarkers: function () { this._eachVertexHandler(function (t) { t.updateMarkers(); }); }, _initHandlers: function () { this._verticesHandlers = []; for (var t = 0; t < this.latlngs.length; t++) this._verticesHandlers.push(new L.Edit.PolyVerticesEdit(this._poly, this.latlngs[t], this._poly.options.poly)); }, _updateLatLngs: function (t) { (this.latlngs = [t.layer._latlngs]), t.layer._holes && (this.latlngs = this.latlngs.concat(t.layer._holes)); }, })), (L.Edit.PolyVerticesEdit = L.Handler.extend({ options: { icon: new L.DivIcon({ iconSize: new L.Point(8, 8), className: "leaflet-div-icon leaflet-editing-icon" }), touchIcon: new L.DivIcon({ iconSize: new L.Point(20, 20), className: "leaflet-div-icon leaflet-editing-icon leaflet-touch-icon" }), drawError: { color: "#b00b00", timeout: 1e3 }, }, initialize: function (t, e, i) { L.Browser.touch && (this.options.icon = this.options.touchIcon), (this._poly = t), i && i.drawError && (i.drawError = L.Util.extend({}, this.options.drawError, i.drawError)), (this._latlngs = e), L.setOptions(this, i); }, _defaultShape: function () { return L.Polyline._flat ? (L.Polyline._flat(this._latlngs) ? this._latlngs : this._latlngs[0]) : this._latlngs; }, addHooks: function () { var t = this._poly, e = t._path; t instanceof L.Polygon || ((t.options.fill = !1), t.options.editing && (t.options.editing.fill = !1)), e && t.options.editing && t.options.editing.className && (t.options.original.className && t.options.original.className.split(" ").forEach(function (t) { L.DomUtil.removeClass(e, t); }), t.options.editing.className.split(" ").forEach(function (t) { L.DomUtil.addClass(e, t); })), t.setStyle(t.options.editing), this._poly._map && ((this._map = this._poly._map), this._markerGroup || this._initMarkers(), this._poly._map.addLayer(this._markerGroup)); }, removeHooks: function () { var t = this._poly, e = t._path; e && t.options.editing && t.options.editing.className && (t.options.editing.className.split(" ").forEach(function (t) { L.DomUtil.removeClass(e, t); }), t.options.original.className && t.options.original.className.split(" ").forEach(function (t) { L.DomUtil.addClass(e, t); })), t.setStyle(t.options.original), t._map && (t._map.removeLayer(this._markerGroup), delete this._markerGroup, delete this._markers); }, updateMarkers: function () { this._markerGroup.clearLayers(), this._initMarkers(); }, _initMarkers: function () { this._markerGroup || (this._markerGroup = new L.LayerGroup()), (this._markers = []); var t, e, i, o, a = this._defaultShape(); for (t = 0, i = a.length; t < i; t++) (o = this._createMarker(a[t], t)), o.on("click", this._onMarkerClick, this), o.on("contextmenu", this._onContextMenu, this), this._markers.push(o); var n, s; for (t = 0, e = i - 1; t < i; e = t++) (0 !== t || (L.Polygon && this._poly instanceof L.Polygon)) && ((n = this._markers[e]), (s = this._markers[t]), this._createMiddleMarker(n, s), this._updatePrevNext(n, s)); }, _createMarker: function (t, e) { var i = new L.Marker.Touch(t, { draggable: !0, icon: this.options.icon }); return ( (i._origLatLng = t), (i._index = e), i .on("dragstart", this._onMarkerDragStart, this) .on("drag", this._onMarkerDrag, this) .on("dragend", this._fireEdit, this) .on("touchmove", this._onTouchMove, this) .on("touchend", this._fireEdit, this) .on("MSPointerMove", this._onTouchMove, this) .on("MSPointerUp", this._fireEdit, this), this._markerGroup.addLayer(i), i ); }, _onMarkerDragStart: function () { this._poly.fire("editstart"); }, _spliceLatLngs: function () { var t = this._defaultShape(), e = [].splice.apply(t, arguments); return this._poly._convertLatLngs(t, !0), this._poly.redraw(), e; }, _removeMarker: function (t) { var e = t._index; this._markerGroup.removeLayer(t), this._markers.splice(e, 1), this._spliceLatLngs(e, 1), this._updateIndexes(e, -1), t .off("dragstart", this._onMarkerDragStart, this) .off("drag", this._onMarkerDrag, this) .off("dragend", this._fireEdit, this) .off("touchmove", this._onMarkerDrag, this) .off("touchend", this._fireEdit, this) .off("click", this._onMarkerClick, this) .off("MSPointerMove", this._onTouchMove, this) .off("MSPointerUp", this._fireEdit, this); }, _fireEdit: function () { (this._poly.edited = !0), this._poly.fire("edit"), this._poly._map.fire(L.Draw.Event.EDITVERTEX, { layers: this._markerGroup, poly: this._poly }); }, _onMarkerDrag: function (t) { var e = t.target, i = this._poly, o = L.LatLngUtil.cloneLatLng(e._origLatLng); if ((L.extend(e._origLatLng, e._latlng), i.options.poly)) { var a = i._map._editTooltip; if (!i.options.poly.allowIntersection && i.intersects()) { L.extend(e._origLatLng, o), e.setLatLng(o); var n = i.options.color; i.setStyle({ color: this.options.drawError.color }), a && a.updateContent({ text: L.drawLocal.draw.handlers.polyline.error }), setTimeout(function () { i.setStyle({ color: n }), a && a.updateContent({ text: L.drawLocal.edit.handlers.edit.tooltip.text, subtext: L.drawLocal.edit.handlers.edit.tooltip.subtext }); }, 1e3); } } e._middleLeft && e._middleLeft.setLatLng(this._getMiddleLatLng(e._prev, e)), e._middleRight && e._middleRight.setLatLng(this._getMiddleLatLng(e, e._next)), (this._poly._bounds._southWest = L.latLng(1 / 0, 1 / 0)), (this._poly._bounds._northEast = L.latLng(-1 / 0, -1 / 0)); var s = this._poly.getLatLngs(); this._poly._convertLatLngs(s, !0), this._poly.redraw(), this._poly.fire("editdrag"); }, _onMarkerClick: function (t) { var e = L.Polygon && this._poly instanceof L.Polygon ? 4 : 3, i = t.target; this._defaultShape().length < e || (this._removeMarker(i), this._updatePrevNext(i._prev, i._next), i._middleLeft && this._markerGroup.removeLayer(i._middleLeft), i._middleRight && this._markerGroup.removeLayer(i._middleRight), i._prev && i._next ? this._createMiddleMarker(i._prev, i._next) : i._prev ? i._next || (i._prev._middleRight = null) : (i._next._middleLeft = null), this._fireEdit()); }, _onContextMenu: function (t) { var e = t.target; this._poly; this._poly._map.fire(L.Draw.Event.MARKERCONTEXT, { marker: e, layers: this._markerGroup, poly: this._poly }), L.DomEvent.stopPropagation; }, _onTouchMove: function (t) { var e = this._map.mouseEventToLayerPoint(t.originalEvent.touches[0]), i = this._map.layerPointToLatLng(e), o = t.target; L.extend(o._origLatLng, i), o._middleLeft && o._middleLeft.setLatLng(this._getMiddleLatLng(o._prev, o)), o._middleRight && o._middleRight.setLatLng(this._getMiddleLatLng(o, o._next)), this._poly.redraw(), this.updateMarkers(); }, _updateIndexes: function (t, e) { this._markerGroup.eachLayer(function (i) { i._index > t && (i._index += e); }); }, _createMiddleMarker: function (t, e) { var i, o, a, n = this._getMiddleLatLng(t, e), s = this._createMarker(n); s.setOpacity(0.6), (t._middleRight = e._middleLeft = s), (o = function () { s.off("touchmove", o, this); var a = e._index; (s._index = a), s.off("click", i, this).on("click", this._onMarkerClick, this), (n.lat = s.getLatLng().lat), (n.lng = s.getLatLng().lng), this._spliceLatLngs(a, 0, n), this._markers.splice(a, 0, s), s.setOpacity(1), this._updateIndexes(a, 1), e._index++, this._updatePrevNext(t, s), this._updatePrevNext(s, e), this._poly.fire("editstart"); }), (a = function () { s.off("dragstart", o, this), s.off("dragend", a, this), s.off("touchmove", o, this), this._createMiddleMarker(t, s), this._createMiddleMarker(s, e); }), (i = function () { o.call(this), a.call(this), this._fireEdit(); }), s.on("click", i, this).on("dragstart", o, this).on("dragend", a, this).on("touchmove", o, this), this._markerGroup.addLayer(s); }, _updatePrevNext: function (t, e) { t && (t._next = e), e && (e._prev = t); }, _getMiddleLatLng: function (t, e) { var i = this._poly._map, o = i.project(t.getLatLng()), a = i.project(e.getLatLng()); return i.unproject(o._add(a)._divideBy(2)); }, })), L.Polyline.addInitHook(function () { this.editing || (L.Edit.Poly && ((this.editing = new L.Edit.Poly(this)), this.options.editable && this.editing.enable()), this.on("add", function () { this.editing && this.editing.enabled() && this.editing.addHooks(); }), this.on("remove", function () { this.editing && this.editing.enabled() && this.editing.removeHooks(); })); }), (L.Edit = L.Edit || {}), (L.Edit.SimpleShape = L.Handler.extend({ options: { moveIcon: new L.DivIcon({ iconSize: new L.Point(8, 8), className: "leaflet-div-icon leaflet-editing-icon leaflet-edit-move" }), resizeIcon: new L.DivIcon({ iconSize: new L.Point(8, 8), className: "leaflet-div-icon leaflet-editing-icon leaflet-edit-resize" }), touchMoveIcon: new L.DivIcon({ iconSize: new L.Point(20, 20), className: "leaflet-div-icon leaflet-editing-icon leaflet-edit-move leaflet-touch-icon" }), touchResizeIcon: new L.DivIcon({ iconSize: new L.Point(20, 20), className: "leaflet-div-icon leaflet-editing-icon leaflet-edit-resize leaflet-touch-icon" }), }, initialize: function (t, e) { L.Browser.touch && ((this.options.moveIcon = this.options.touchMoveIcon), (this.options.resizeIcon = this.options.touchResizeIcon)), (this._shape = t), L.Util.setOptions(this, e); }, addHooks: function () { var t = this._shape; this._shape._map && ((this._map = this._shape._map), t.setStyle(t.options.editing), t._map && ((this._map = t._map), this._markerGroup || this._initMarkers(), this._map.addLayer(this._markerGroup))); }, removeHooks: function () { var t = this._shape; if ((t.setStyle(t.options.original), t._map)) { this._unbindMarker(this._moveMarker); for (var e = 0, i = this._resizeMarkers.length; e < i; e++) this._unbindMarker(this._resizeMarkers[e]); (this._resizeMarkers = null), this._map.removeLayer(this._markerGroup), delete this._markerGroup; } this._map = null; }, updateMarkers: function () { this._markerGroup.clearLayers(), this._initMarkers(); }, _initMarkers: function () { this._markerGroup || (this._markerGroup = new L.LayerGroup()), this._createMoveMarker(), this._createResizeMarker(); }, _createMoveMarker: function () {}, _createResizeMarker: function () {}, _createMarker: function (t, e) { var i = new L.Marker.Touch(t, { draggable: !0, icon: e, zIndexOffset: 10 }); return this._bindMarker(i), this._markerGroup.addLayer(i), i; }, _bindMarker: function (t) { t.on("dragstart", this._onMarkerDragStart, this) .on("drag", this._onMarkerDrag, this) .on("dragend", this._onMarkerDragEnd, this) .on("touchstart", this._onTouchStart, this) .on("touchmove", this._onTouchMove, this) .on("MSPointerMove", this._onTouchMove, this) .on("touchend", this._onTouchEnd, this) .on("MSPointerUp", this._onTouchEnd, this); }, _unbindMarker: function (t) { t.off("dragstart", this._onMarkerDragStart, this) .off("drag", this._onMarkerDrag, this) .off("dragend", this._onMarkerDragEnd, this) .off("touchstart", this._onTouchStart, this) .off("touchmove", this._onTouchMove, this) .off("MSPointerMove", this._onTouchMove, this) .off("touchend", this._onTouchEnd, this) .off("MSPointerUp", this._onTouchEnd, this); }, _onMarkerDragStart: function (t) { t.target.setOpacity(0), this._shape.fire("editstart"); }, _fireEdit: function () { (this._shape.edited = !0), this._shape.fire("edit"); }, _onMarkerDrag: function (t) { var e = t.target, i = e.getLatLng(); e === this._moveMarker ? this._move(i) : this._resize(i), this._shape.redraw(), this._shape.fire("editdrag"); }, _onMarkerDragEnd: function (t) { t.target.setOpacity(1), this._fireEdit(); }, _onTouchStart: function (t) { if ((L.Edit.SimpleShape.prototype._onMarkerDragStart.call(this, t), "function" == typeof this._getCorners)) { var e = this._getCorners(), i = t.target, o = i._cornerIndex; i.setOpacity(0), (this._oppositeCorner = e[(o + 2) % 4]), this._toggleCornerMarkers(0, o); } this._shape.fire("editstart"); }, _onTouchMove: function (t) { var e = this._map.mouseEventToLayerPoint(t.originalEvent.touches[0]), i = this._map.layerPointToLatLng(e); return t.target === this._moveMarker ? this._move(i) : this._resize(i), this._shape.redraw(), !1; }, _onTouchEnd: function (t) { t.target.setOpacity(1), this.updateMarkers(), this._fireEdit(); }, _move: function () {}, _resize: function () {}, })), (L.Edit = L.Edit || {}), (L.Edit.Rectangle = L.Edit.SimpleShape.extend({ _createMoveMarker: function () { var t = this._shape.getBounds(), e = t.getCenter(); this._moveMarker = this._createMarker(e, this.options.moveIcon); }, _createResizeMarker: function () { var t = this._getCorners(); this._resizeMarkers = []; for (var e = 0, i = t.length; e < i; e++) this._resizeMarkers.push(this._createMarker(t[e], this.options.resizeIcon)), (this._resizeMarkers[e]._cornerIndex = e); }, _onMarkerDragStart: function (t) { L.Edit.SimpleShape.prototype._onMarkerDragStart.call(this, t); var e = this._getCorners(), i = t.target, o = i._cornerIndex; (this._oppositeCorner = e[(o + 2) % 4]), this._toggleCornerMarkers(0, o); }, _onMarkerDragEnd: function (t) { var e, i, o = t.target; o === this._moveMarker && ((e = this._shape.getBounds()), (i = e.getCenter()), o.setLatLng(i)), this._toggleCornerMarkers(1), this._repositionCornerMarkers(), L.Edit.SimpleShape.prototype._onMarkerDragEnd.call(this, t); }, _move: function (t) { for (var e, i = this._shape._defaultShape ? this._shape._defaultShape() : this._shape.getLatLngs(), o = this._shape.getBounds(), a = o.getCenter(), n = [], s = 0, r = i.length; s < r; s++) (e = [i[s].lat - a.lat, i[s].lng - a.lng]), n.push([t.lat + e[0], t.lng + e[1]]); this._shape.setLatLngs(n), this._repositionCornerMarkers(), this._map.fire(L.Draw.Event.EDITMOVE, { layer: this._shape }); }, _resize: function (t) { var e; this._shape.setBounds(L.latLngBounds(t, this._oppositeCorner)), (e = this._shape.getBounds()), this._moveMarker.setLatLng(e.getCenter()), this._map.fire(L.Draw.Event.EDITRESIZE, { layer: this._shape }); }, _getCorners: function () { var t = this._shape.getBounds(); return [t.getNorthWest(), t.getNorthEast(), t.getSouthEast(), t.getSouthWest()]; }, _toggleCornerMarkers: function (t) { for (var e = 0, i = this._resizeMarkers.length; e < i; e++) this._resizeMarkers[e].setOpacity(t); }, _repositionCornerMarkers: function () { for (var t = this._getCorners(), e = 0, i = this._resizeMarkers.length; e < i; e++) this._resizeMarkers[e].setLatLng(t[e]); }, })), L.Rectangle.addInitHook(function () { L.Edit.Rectangle && ((this.editing = new L.Edit.Rectangle(this)), this.options.editable && this.editing.enable()); }), (L.Edit = L.Edit || {}), (L.Edit.CircleMarker = L.Edit.SimpleShape.extend({ _createMoveMarker: function () { var t = this._shape.getLatLng(); this._moveMarker = this._createMarker(t, this.options.moveIcon); }, _createResizeMarker: function () { this._resizeMarkers = []; }, _move: function (t) { if (this._resizeMarkers.length) { var e = this._getResizeMarkerPoint(t); this._resizeMarkers[0].setLatLng(e); } this._shape.setLatLng(t), this._map.fire(L.Draw.Event.EDITMOVE, { layer: this._shape }); }, })), L.CircleMarker.addInitHook(function () { L.Edit.CircleMarker && ((this.editing = new L.Edit.CircleMarker(this)), this.options.editable && this.editing.enable()), this.on("add", function () { this.editing && this.editing.enabled() && this.editing.addHooks(); }), this.on("remove", function () { this.editing && this.editing.enabled() && this.editing.removeHooks(); }); }), (L.Edit = L.Edit || {}), (L.Edit.Circle = L.Edit.CircleMarker.extend({ _createResizeMarker: function () { var t = this._shape.getLatLng(), e = this._getResizeMarkerPoint(t); (this._resizeMarkers = []), this._resizeMarkers.push(this._createMarker(e, this.options.resizeIcon)); }, _getResizeMarkerPoint: function (t) { var e = this._shape._radius * Math.cos(Math.PI / 4), i = this._map.project(t); return this._map.unproject([i.x + e, i.y - e]); }, _resize: function (t) { var e = this._moveMarker.getLatLng(); L.GeometryUtil.isVersion07x() ? (radius = e.distanceTo(t)) : (radius = this._map.distance(e, t)), this._shape.setRadius(radius), this._map.editTooltip && this._map._editTooltip.updateContent({ text: L.drawLocal.edit.handlers.edit.tooltip.subtext + "
" + L.drawLocal.edit.handlers.edit.tooltip.text, subtext: L.drawLocal.draw.handlers.circle.radius + ": " + L.GeometryUtil.readableDistance(radius, !0, this.options.feet, this.options.nautic), }), this._shape.setRadius(radius), this._map.fire(L.Draw.Event.EDITRESIZE, { layer: this._shape }); }, })), L.Circle.addInitHook(function () { L.Edit.Circle && ((this.editing = new L.Edit.Circle(this)), this.options.editable && this.editing.enable()); }), L.Map.mergeOptions({ touchExtend: !0 }), (L.Map.TouchExtend = L.Handler.extend({ initialize: function (t) { (this._map = t), (this._container = t._container), (this._pane = t._panes.overlayPane); }, addHooks: function () { L.DomEvent.on(this._container, "touchstart", this._onTouchStart, this), L.DomEvent.on(this._container, "touchend", this._onTouchEnd, this), L.DomEvent.on(this._container, "touchmove", this._onTouchMove, this), this._detectIE() ? (L.DomEvent.on(this._container, "MSPointerDown", this._onTouchStart, this), L.DomEvent.on(this._container, "MSPointerUp", this._onTouchEnd, this), L.DomEvent.on(this._container, "MSPointerMove", this._onTouchMove, this), L.DomEvent.on(this._container, "MSPointerCancel", this._onTouchCancel, this)) : (L.DomEvent.on(this._container, "touchcancel", this._onTouchCancel, this), L.DomEvent.on(this._container, "touchleave", this._onTouchLeave, this)); }, removeHooks: function () { L.DomEvent.off(this._container, "touchstart", this._onTouchStart, this), L.DomEvent.off(this._container, "touchend", this._onTouchEnd, this), L.DomEvent.off(this._container, "touchmove", this._onTouchMove, this), this._detectIE() ? (L.DomEvent.off(this._container, "MSPointerDown", this._onTouchStart, this), L.DomEvent.off(this._container, "MSPointerUp", this._onTouchEnd, this), L.DomEvent.off(this._container, "MSPointerMove", this._onTouchMove, this), L.DomEvent.off(this._container, "MSPointerCancel", this._onTouchCancel, this)) : (L.DomEvent.off(this._container, "touchcancel", this._onTouchCancel, this), L.DomEvent.off(this._container, "touchleave", this._onTouchLeave, this)); }, _touchEvent: function (t, e) { var i = {}; if (void 0 !== t.touches) { if (!t.touches.length) return; i = t.touches[0]; } else { if ("touch" !== t.pointerType) return; if (((i = t), !this._filterClick(t))) return; } var o = this._map.mouseEventToContainerPoint(i), a = this._map.mouseEventToLayerPoint(i), n = this._map.layerPointToLatLng(a); this._map.fire(e, { latlng: n, layerPoint: a, containerPoint: o, pageX: i.pageX, pageY: i.pageY, originalEvent: t }); }, _filterClick: function (t) { var e = t.timeStamp || t.originalEvent.timeStamp, i = L.DomEvent._lastClick && e - L.DomEvent._lastClick; return (i && i > 100 && i < 500) || (t.target._simulatedClick && !t._simulated) ? (L.DomEvent.stop(t), !1) : ((L.DomEvent._lastClick = e), !0); }, _onTouchStart: function (t) { if (this._map._loaded) { this._touchEvent(t, "touchstart"); } }, _onTouchEnd: function (t) { if (this._map._loaded) { this._touchEvent(t, "touchend"); } }, _onTouchCancel: function (t) { if (this._map._loaded) { var e = "touchcancel"; this._detectIE() && (e = "pointercancel"), this._touchEvent(t, e); } }, _onTouchLeave: function (t) { if (this._map._loaded) { this._touchEvent(t, "touchleave"); } }, _onTouchMove: function (t) { if (this._map._loaded) { this._touchEvent(t, "touchmove"); } }, _detectIE: function () { var e = t.navigator.userAgent, i = e.indexOf("MSIE "); if (i > 0) return parseInt(e.substring(i + 5, e.indexOf(".", i)), 10); if (e.indexOf("Trident/") > 0) { var o = e.indexOf("rv:"); return parseInt(e.substring(o + 3, e.indexOf(".", o)), 10); } var a = e.indexOf("Edge/"); return a > 0 && parseInt(e.substring(a + 5, e.indexOf(".", a)), 10); }, })), L.Map.addInitHook("addHandler", "touchExtend", L.Map.TouchExtend), (L.Marker.Touch = L.Marker.extend({ _initInteraction: function () { return this.addInteractiveTarget ? L.Marker.prototype._initInteraction.apply(this) : this._initInteractionLegacy(); }, _initInteractionLegacy: function () { if (this.options.clickable) { var t = this._icon, e = ["dblclick", "mousedown", "mouseover", "mouseout", "contextmenu", "touchstart", "touchend", "touchmove"]; this._detectIE ? e.concat(["MSPointerDown", "MSPointerUp", "MSPointerMove", "MSPointerCancel"]) : e.concat(["touchcancel"]), L.DomUtil.addClass(t, "leaflet-clickable"), L.DomEvent.on(t, "click", this._onMouseClick, this), L.DomEvent.on(t, "keypress", this._onKeyPress, this); for (var i = 0; i < e.length; i++) L.DomEvent.on(t, e[i], this._fireMouseEvent, this); L.Handler.MarkerDrag && ((this.dragging = new L.Handler.MarkerDrag(this)), this.options.draggable && this.dragging.enable()); } }, _detectIE: function () { var e = t.navigator.userAgent, i = e.indexOf("MSIE "); if (i > 0) return parseInt(e.substring(i + 5, e.indexOf(".", i)), 10); if (e.indexOf("Trident/") > 0) { var o = e.indexOf("rv:"); return parseInt(e.substring(o + 3, e.indexOf(".", o)), 10); } var a = e.indexOf("Edge/"); return a > 0 && parseInt(e.substring(a + 5, e.indexOf(".", a)), 10); }, })), (L.LatLngUtil = { cloneLatLngs: function (t) { for (var e = [], i = 0, o = t.length; i < o; i++) Array.isArray(t[i]) ? e.push(L.LatLngUtil.cloneLatLngs(t[i])) : e.push(this.cloneLatLng(t[i])); return e; }, cloneLatLng: function (t) { return L.latLng(t.lat, t.lng); }, }), (function () { var t = { km: 2, ha: 2, m: 0, mi: 2, ac: 2, yd: 0, ft: 0, nm: 2 }; L.GeometryUtil = L.extend(L.GeometryUtil || {}, { geodesicArea: function (t) { var e, i, o = t.length, a = 0, n = Math.PI / 180; if (o > 2) { for (var s = 0; s < o; s++) (e = t[s]), (i = t[(s + 1) % o]), (a += (i.lng - e.lng) * n * (2 + Math.sin(e.lat * n) + Math.sin(i.lat * n))); a = (6378137 * a * 6378137) / 2; } return Math.abs(a); }, formattedNumber: function (t, e) { var i = parseFloat(t).toFixed(e), o = L.drawLocal.format && L.drawLocal.format.numeric, a = o && o.delimiters, n = a && a.thousands, s = a && a.decimal; if (n || s) { var r = i.split("."); (i = n ? r[0].replace(/(\d)(?=(\d{3})+(?!\d))/g, "$1" + n) : r[0]), (s = s || "."), r.length > 1 && (i = i + s + r[1]); } return i; }, readableArea: function (e, i, o) { var a, n, o = L.Util.extend({}, t, o); return ( i ? ((n = ["ha", "m"]), (type = typeof i), "string" === type ? (n = [i]) : "boolean" !== type && (n = i), (a = e >= 1e6 && -1 !== n.indexOf("km") ? L.GeometryUtil.formattedNumber(1e-6 * e, o.km) + " km²" : e >= 1e4 && -1 !== n.indexOf("ha") ? L.GeometryUtil.formattedNumber(1e-4 * e, o.ha) + " ha" : L.GeometryUtil.formattedNumber(e, o.m) + " m²")) : ((e /= 0.836127), (a = e >= 3097600 ? L.GeometryUtil.formattedNumber(e / 3097600, o.mi) + " mi²" : e >= 4840 ? L.GeometryUtil.formattedNumber(e / 4840, o.ac) + " acres" : L.GeometryUtil.formattedNumber(e, o.yd) + " yd²")), a ); }, readableDistance: function (e, i, o, a, n) { var s, n = L.Util.extend({}, t, n); switch (i ? ("string" == typeof i ? i : "metric") : o ? "feet" : a ? "nauticalMile" : "yards") { case "metric": s = e > 1e3 ? L.GeometryUtil.formattedNumber(e / 1e3, n.km) + " km" : L.GeometryUtil.formattedNumber(e, n.m) + " m"; break; case "feet": (e *= 3.28083), (s = L.GeometryUtil.formattedNumber(e, n.ft) + " ft"); break; case "nauticalMile": (e *= 0.53996), (s = L.GeometryUtil.formattedNumber(e / 1e3, n.nm) + " nm"); break; case "yards": default: (e *= 1.09361), (s = e > 1760 ? L.GeometryUtil.formattedNumber(e / 1760, n.mi) + " miles" : L.GeometryUtil.formattedNumber(e, n.yd) + " yd"); } return s; }, isVersion07x: function () { var t = L.version.split("."); return 0 === parseInt(t[0], 10) && 7 === parseInt(t[1], 10); }, }); })(), L.Util.extend(L.LineUtil, { segmentsIntersect: function (t, e, i, o) { return this._checkCounterclockwise(t, i, o) !== this._checkCounterclockwise(e, i, o) && this._checkCounterclockwise(t, e, i) !== this._checkCounterclockwise(t, e, o); }, _checkCounterclockwise: function (t, e, i) { return (i.y - t.y) * (e.x - t.x) > (e.y - t.y) * (i.x - t.x); }, }), L.Polyline.include({ intersects: function () { var t, e, i, o = this._getProjectedPoints(), a = o ? o.length : 0; if (this._tooFewPointsForIntersection()) return !1; for (t = a - 1; t >= 3; t--) if (((e = o[t - 1]), (i = o[t]), this._lineSegmentsIntersectsRange(e, i, t - 2))) return !0; return !1; }, newLatLngIntersects: function (t, e) { return !!this._map && this.newPointIntersects(this._map.latLngToLayerPoint(t), e); }, newPointIntersects: function (t, e) { var i = this._getProjectedPoints(), o = i ? i.length : 0, a = i ? i[o - 1] : null, n = o - 2; return !this._tooFewPointsForIntersection(1) && this._lineSegmentsIntersectsRange(a, t, n, e ? 1 : 0); }, _tooFewPointsForIntersection: function (t) { var e = this._getProjectedPoints(), i = e ? e.length : 0; return (i += t || 0), !e || i <= 3; }, _lineSegmentsIntersectsRange: function (t, e, i, o) { var a, n, s = this._getProjectedPoints(); o = o || 0; for (var r = i; r > o; r--) if (((a = s[r - 1]), (n = s[r]), L.LineUtil.segmentsIntersect(t, e, a, n))) return !0; return !1; }, _getProjectedPoints: function () { if (!this._defaultShape) return this._originalPoints; for (var t = [], e = this._defaultShape(), i = 0; i < e.length; i++) t.push(this._map.latLngToLayerPoint(e[i])); return t; }, }), L.Polygon.include({ intersects: function () { var t, e, i, o, a = this._getProjectedPoints(); return !this._tooFewPointsForIntersection() && (!!L.Polyline.prototype.intersects.call(this) || ((t = a.length), (e = a[0]), (i = a[t - 1]), (o = t - 2), this._lineSegmentsIntersectsRange(i, e, o, 1))); }, }), (L.Control.Draw = L.Control.extend({ options: { position: "topleft", draw: {}, edit: !1 }, initialize: function (t) { if (L.version < "0.7") throw new Error("Leaflet.draw 0.2.3+ requires Leaflet 0.7.0+. Download latest from https://github.com/Leaflet/Leaflet/"); L.Control.prototype.initialize.call(this, t); var e; (this._toolbars = {}), L.DrawToolbar && this.options.draw && ((e = new L.DrawToolbar(this.options.draw)), (this._toolbars[L.DrawToolbar.TYPE] = e), this._toolbars[L.DrawToolbar.TYPE].on("enable", this._toolbarEnabled, this)), L.EditToolbar && this.options.edit && ((e = new L.EditToolbar(this.options.edit)), (this._toolbars[L.EditToolbar.TYPE] = e), this._toolbars[L.EditToolbar.TYPE].on("enable", this._toolbarEnabled, this)), (L.toolbar = this); }, onAdd: function (t) { var e, i = L.DomUtil.create("div", "leaflet-draw"), o = !1; for (var a in this._toolbars) this._toolbars.hasOwnProperty(a) && (e = this._toolbars[a].addToolbar(t)) && (o || (L.DomUtil.hasClass(e, "leaflet-draw-toolbar-top") || L.DomUtil.addClass(e.childNodes[0], "leaflet-draw-toolbar-top"), (o = !0)), i.appendChild(e)); return i; }, onRemove: function () { for (var t in this._toolbars) this._toolbars.hasOwnProperty(t) && this._toolbars[t].removeToolbar(); }, setDrawingOptions: function (t) { for (var e in this._toolbars) this._toolbars[e] instanceof L.DrawToolbar && this._toolbars[e].setOptions(t); }, _toolbarEnabled: function (t) { var e = t.target; for (var i in this._toolbars) this._toolbars[i] !== e && this._toolbars[i].disable(); }, })), L.Map.mergeOptions({ drawControlTooltips: !0, drawControl: !1 }), L.Map.addInitHook(function () { this.options.drawControl && ((this.drawControl = new L.Control.Draw()), this.addControl(this.drawControl)); }), (L.Toolbar = L.Class.extend({ initialize: function (t) { L.setOptions(this, t), (this._modes = {}), (this._actionButtons = []), (this._activeMode = null); var e = L.version.split("."); 1 === parseInt(e[0], 10) && parseInt(e[1], 10) >= 2 ? L.Toolbar.include(L.Evented.prototype) : L.Toolbar.include(L.Mixin.Events); }, enabled: function () { return null !== this._activeMode; }, disable: function () { this.enabled() && this._activeMode.handler.disable(); }, addToolbar: function (t) { var e, i = L.DomUtil.create("div", "leaflet-draw-section"), o = 0, a = this._toolbarClass || "", n = this.getModeHandlers(t); for (this._toolbarContainer = L.DomUtil.create("div", "leaflet-draw-toolbar leaflet-bar"), this._map = t, e = 0; e < n.length; e++) n[e].enabled && this._initModeHandler(n[e].handler, this._toolbarContainer, o++, a, n[e].title); if (o) return (this._lastButtonIndex = --o), (this._actionsContainer = L.DomUtil.create("ul", "leaflet-draw-actions")), i.appendChild(this._toolbarContainer), i.appendChild(this._actionsContainer), i; }, removeToolbar: function () { for (var t in this._modes) this._modes.hasOwnProperty(t) && (this._disposeButton(this._modes[t].button, this._modes[t].handler.enable, this._modes[t].handler), this._modes[t].handler.disable(), this._modes[t].handler.off("enabled", this._handlerActivated, this).off("disabled", this._handlerDeactivated, this)); this._modes = {}; for (var e = 0, i = this._actionButtons.length; e < i; e++) this._disposeButton(this._actionButtons[e].button, this._actionButtons[e].callback, this); (this._actionButtons = []), (this._actionsContainer = null); }, _initModeHandler: function (t, e, i, o, a) { var n = t.type; (this._modes[n] = {}), (this._modes[n].handler = t), (this._modes[n].button = this._createButton({ type: n, title: a, className: o + "-" + n, container: e, callback: this._modes[n].handler.enable, context: this._modes[n].handler })), (this._modes[n].buttonIndex = i), this._modes[n].handler.on("enabled", this._handlerActivated, this).on("disabled", this._handlerDeactivated, this); }, _detectIOS: function () { return /iPad|iPhone|iPod/.test(navigator.userAgent) && !t.MSStream; }, _createButton: function (t) { var e = L.DomUtil.create("a", t.className || "", t.container), i = L.DomUtil.create("span", "sr-only", t.container); (e.href = "#"), e.appendChild(i), t.title && ((e.title = t.title), (i.innerHTML = t.title)), t.text && ((e.innerHTML = t.text), (i.innerHTML = t.text)); var o = this._detectIOS() ? "touchstart" : "click"; return ( L.DomEvent.on(e, "click", L.DomEvent.stopPropagation) .on(e, "mousedown", L.DomEvent.stopPropagation) .on(e, "dblclick", L.DomEvent.stopPropagation) .on(e, "touchstart", L.DomEvent.stopPropagation) .on(e, "click", L.DomEvent.preventDefault) .on(e, o, t.callback, t.context), e ); }, _disposeButton: function (t, e) { var i = this._detectIOS() ? "touchstart" : "click"; L.DomEvent.off(t, "click", L.DomEvent.stopPropagation) .off(t, "mousedown", L.DomEvent.stopPropagation) .off(t, "dblclick", L.DomEvent.stopPropagation) .off(t, "touchstart", L.DomEvent.stopPropagation) .off(t, "click", L.DomEvent.preventDefault) .off(t, i, e); }, _handlerActivated: function (t) { this.disable(), (this._activeMode = this._modes[t.handler]), L.DomUtil.addClass(this._activeMode.button, "leaflet-draw-toolbar-button-enabled"), this._showActionsToolbar(), this.fire("enable"); }, _handlerDeactivated: function () { this._hideActionsToolbar(), L.DomUtil.removeClass(this._activeMode.button, "leaflet-draw-toolbar-button-enabled"), (this._activeMode = null), this.fire("disable"); }, _createActions: function (t) { var e, i, o, a, n = this._actionsContainer, s = this.getActions(t), r = s.length; for (i = 0, o = this._actionButtons.length; i < o; i++) this._disposeButton(this._actionButtons[i].button, this._actionButtons[i].callback); for (this._actionButtons = []; n.firstChild; ) n.removeChild(n.firstChild); for (var l = 0; l < r; l++) ("enabled" in s[l] && !s[l].enabled) || ((e = L.DomUtil.create("li", "", n)), (a = this._createButton({ title: s[l].title, text: s[l].text, container: e, callback: s[l].callback, context: s[l].context })), this._actionButtons.push({ button: a, callback: s[l].callback })); }, _showActionsToolbar: function () { var t = this._activeMode.buttonIndex, e = this._lastButtonIndex, i = this._activeMode.button.offsetTop - 1; this._createActions(this._activeMode.handler), (this._actionsContainer.style.top = i + "px"), 0 === t && (L.DomUtil.addClass(this._toolbarContainer, "leaflet-draw-toolbar-notop"), L.DomUtil.addClass(this._actionsContainer, "leaflet-draw-actions-top")), t === e && (L.DomUtil.addClass(this._toolbarContainer, "leaflet-draw-toolbar-nobottom"), L.DomUtil.addClass(this._actionsContainer, "leaflet-draw-actions-bottom")), (this._actionsContainer.style.display = "block"), this._map.fire(L.Draw.Event.TOOLBAROPENED); }, _hideActionsToolbar: function () { (this._actionsContainer.style.display = "none"), L.DomUtil.removeClass(this._toolbarContainer, "leaflet-draw-toolbar-notop"), L.DomUtil.removeClass(this._toolbarContainer, "leaflet-draw-toolbar-nobottom"), L.DomUtil.removeClass(this._actionsContainer, "leaflet-draw-actions-top"), L.DomUtil.removeClass(this._actionsContainer, "leaflet-draw-actions-bottom"), this._map.fire(L.Draw.Event.TOOLBARCLOSED); }, })), (L.Draw = L.Draw || {}), (L.Draw.Tooltip = L.Class.extend({ initialize: function (t) { (this._map = t), (this._popupPane = t._panes.popupPane), (this._visible = !1), (this._container = t.options.drawControlTooltips ? L.DomUtil.create("div", "leaflet-draw-tooltip", this._popupPane) : null), (this._singleLineLabel = !1), this._map.on("mouseout", this._onMouseOut, this); }, dispose: function () { this._map.off("mouseout", this._onMouseOut, this), this._container && (this._popupPane.removeChild(this._container), (this._container = null)); }, updateContent: function (t) { return this._container ? ((t.subtext = t.subtext || ""), 0 !== t.subtext.length || this._singleLineLabel ? t.subtext.length > 0 && this._singleLineLabel && (L.DomUtil.removeClass(this._container, "leaflet-draw-tooltip-single"), (this._singleLineLabel = !1)) : (L.DomUtil.addClass(this._container, "leaflet-draw-tooltip-single"), (this._singleLineLabel = !0)), (this._container.innerHTML = (t.subtext.length > 0 ? '' + t.subtext + "
" : "") + "" + t.text + ""), t.text || t.subtext ? ((this._visible = !0), (this._container.style.visibility = "inherit")) : ((this._visible = !1), (this._container.style.visibility = "hidden")), this) : this; }, updatePosition: function (t) { var e = this._map.latLngToLayerPoint(t), i = this._container; return this._container && (this._visible && (i.style.visibility = "inherit"), L.DomUtil.setPosition(i, e)), this; }, showAsError: function () { return this._container && L.DomUtil.addClass(this._container, "leaflet-error-draw-tooltip"), this; }, removeError: function () { return this._container && L.DomUtil.removeClass(this._container, "leaflet-error-draw-tooltip"), this; }, _onMouseOut: function () { this._container && (this._container.style.visibility = "hidden"); }, })), (L.DrawToolbar = L.Toolbar.extend({ statics: { TYPE: "draw" }, options: { polyline: {}, polygon: {}, rectangle: {}, circle: {}, marker: {}, circlemarker: {} }, initialize: function (t) { for (var e in this.options) this.options.hasOwnProperty(e) && t[e] && (t[e] = L.extend({}, this.options[e], t[e])); (this._toolbarClass = "leaflet-draw-draw"), L.Toolbar.prototype.initialize.call(this, t); }, getModeHandlers: function (t) { return [ { enabled: this.options.polyline, handler: new L.Draw.Polyline(t, this.options.polyline), title: L.drawLocal.draw.toolbar.buttons.polyline }, { enabled: this.options.polygon, handler: new L.Draw.Polygon(t, this.options.polygon), title: L.drawLocal.draw.toolbar.buttons.polygon }, { enabled: this.options.rectangle, handler: new L.Draw.Rectangle(t, this.options.rectangle), title: L.drawLocal.draw.toolbar.buttons.rectangle }, { enabled: this.options.circle, handler: new L.Draw.Circle(t, this.options.circle), title: L.drawLocal.draw.toolbar.buttons.circle }, { enabled: this.options.marker, handler: new L.Draw.Marker(t, this.options.marker), title: L.drawLocal.draw.toolbar.buttons.marker }, { enabled: this.options.circlemarker, handler: new L.Draw.CircleMarker(t, this.options.circlemarker), title: L.drawLocal.draw.toolbar.buttons.circlemarker }, ]; }, getActions: function (t) { return [ { enabled: t.completeShape, title: L.drawLocal.draw.toolbar.finish.title, text: L.drawLocal.draw.toolbar.finish.text, callback: t.completeShape, context: t }, { enabled: t.deleteLastVertex, title: L.drawLocal.draw.toolbar.undo.title, text: L.drawLocal.draw.toolbar.undo.text, callback: t.deleteLastVertex, context: t }, { title: L.drawLocal.draw.toolbar.actions.title, text: L.drawLocal.draw.toolbar.actions.text, callback: this.disable, context: this }, ]; }, setOptions: function (t) { L.setOptions(this, t); for (var e in this._modes) this._modes.hasOwnProperty(e) && t.hasOwnProperty(e) && this._modes[e].handler.setOptions(t[e]); }, })), (L.EditToolbar = L.Toolbar.extend({ statics: { TYPE: "edit" }, options: { edit: { selectedPathOptions: { dashArray: "10, 10", fill: !0, fillColor: "#fe57a1", fillOpacity: 0.1, maintainColor: !1 } }, remove: {}, poly: null, featureGroup: null }, initialize: function (t) { t.edit && (void 0 === t.edit.selectedPathOptions && (t.edit.selectedPathOptions = this.options.edit.selectedPathOptions), (t.edit.selectedPathOptions = L.extend({}, this.options.edit.selectedPathOptions, t.edit.selectedPathOptions))), t.remove && (t.remove = L.extend({}, this.options.remove, t.remove)), t.poly && (t.poly = L.extend({}, this.options.poly, t.poly)), (this._toolbarClass = "leaflet-draw-edit"), L.Toolbar.prototype.initialize.call(this, t), (this._selectedFeatureCount = 0); }, getModeHandlers: function (t) { var e = this.options.featureGroup; return [ { enabled: this.options.edit, handler: new L.EditToolbar.Edit(t, { featureGroup: e, selectedPathOptions: this.options.edit.selectedPathOptions, poly: this.options.poly }), title: L.drawLocal.edit.toolbar.buttons.edit }, { enabled: this.options.remove, handler: new L.EditToolbar.Delete(t, { featureGroup: e }), title: L.drawLocal.edit.toolbar.buttons.remove }, ]; }, getActions: function (t) { var e = [ { title: L.drawLocal.edit.toolbar.actions.save.title, text: L.drawLocal.edit.toolbar.actions.save.text, callback: this._save, context: this }, { title: L.drawLocal.edit.toolbar.actions.cancel.title, text: L.drawLocal.edit.toolbar.actions.cancel.text, callback: this.disable, context: this }, ]; return t.removeAllLayers && e.push({ title: L.drawLocal.edit.toolbar.actions.clearAll.title, text: L.drawLocal.edit.toolbar.actions.clearAll.text, callback: this._clearAllLayers, context: this }), e; }, addToolbar: function (t) { var e = L.Toolbar.prototype.addToolbar.call(this, t); return this._checkDisabled(), this.options.featureGroup.on("layeradd layerremove", this._checkDisabled, this), e; }, removeToolbar: function () { this.options.featureGroup.off("layeradd layerremove", this._checkDisabled, this), L.Toolbar.prototype.removeToolbar.call(this); }, disable: function () { this.enabled() && (this._activeMode.handler.revertLayers(), L.Toolbar.prototype.disable.call(this)); }, _save: function () { this._activeMode.handler.save(), this._activeMode && this._activeMode.handler.disable(); }, _clearAllLayers: function () { this._activeMode.handler.removeAllLayers(), this._activeMode && this._activeMode.handler.disable(); }, _checkDisabled: function () { var t, e = this.options.featureGroup, i = 0 !== e.getLayers().length; this.options.edit && ((t = this._modes[L.EditToolbar.Edit.TYPE].button), i ? L.DomUtil.removeClass(t, "leaflet-disabled") : L.DomUtil.addClass(t, "leaflet-disabled"), t.setAttribute("title", i ? L.drawLocal.edit.toolbar.buttons.edit : L.drawLocal.edit.toolbar.buttons.editDisabled)), this.options.remove && ((t = this._modes[L.EditToolbar.Delete.TYPE].button), i ? L.DomUtil.removeClass(t, "leaflet-disabled") : L.DomUtil.addClass(t, "leaflet-disabled"), t.setAttribute("title", i ? L.drawLocal.edit.toolbar.buttons.remove : L.drawLocal.edit.toolbar.buttons.removeDisabled)); }, })), (L.EditToolbar.Edit = L.Handler.extend({ statics: { TYPE: "edit" }, initialize: function (t, e) { if ((L.Handler.prototype.initialize.call(this, t), L.setOptions(this, e), (this._featureGroup = e.featureGroup), !(this._featureGroup instanceof L.FeatureGroup))) throw new Error("options.featureGroup must be a L.FeatureGroup"); (this._uneditedLayerProps = {}), (this.type = L.EditToolbar.Edit.TYPE); var i = L.version.split("."); 1 === parseInt(i[0], 10) && parseInt(i[1], 10) >= 2 ? L.EditToolbar.Edit.include(L.Evented.prototype) : L.EditToolbar.Edit.include(L.Mixin.Events); }, enable: function () { !this._enabled && this._hasAvailableLayers() && (this.fire("enabled", { handler: this.type }), this._map.fire(L.Draw.Event.EDITSTART, { handler: this.type }), L.Handler.prototype.enable.call(this), this._featureGroup.on("layeradd", this._enableLayerEdit, this).on("layerremove", this._disableLayerEdit, this)); }, disable: function () { this._enabled && (this._featureGroup.off("layeradd", this._enableLayerEdit, this).off("layerremove", this._disableLayerEdit, this), L.Handler.prototype.disable.call(this), this._map.fire(L.Draw.Event.EDITSTOP, { handler: this.type }), this.fire("disabled", { handler: this.type })); }, addHooks: function () { var t = this._map; t && (t.getContainer().focus(), this._featureGroup.eachLayer(this._enableLayerEdit, this), (this._tooltip = new L.Draw.Tooltip(this._map)), this._tooltip.updateContent({ text: L.drawLocal.edit.handlers.edit.tooltip.text, subtext: L.drawLocal.edit.handlers.edit.tooltip.subtext }), (t._editTooltip = this._tooltip), this._updateTooltip(), this._map.on("mousemove", this._onMouseMove, this).on("touchmove", this._onMouseMove, this).on("MSPointerMove", this._onMouseMove, this).on(L.Draw.Event.EDITVERTEX, this._updateTooltip, this)); }, removeHooks: function () { this._map && (this._featureGroup.eachLayer(this._disableLayerEdit, this), (this._uneditedLayerProps = {}), this._tooltip.dispose(), (this._tooltip = null), this._map.off("mousemove", this._onMouseMove, this).off("touchmove", this._onMouseMove, this).off("MSPointerMove", this._onMouseMove, this).off(L.Draw.Event.EDITVERTEX, this._updateTooltip, this)); }, revertLayers: function () { this._featureGroup.eachLayer(function (t) { this._revertLayer(t); }, this); }, save: function () { var t = new L.LayerGroup(); this._featureGroup.eachLayer(function (e) { e.edited && (t.addLayer(e), (e.edited = !1)); }), this._map.fire(L.Draw.Event.EDITED, { layers: t }); }, _backupLayer: function (t) { var e = L.Util.stamp(t); this._uneditedLayerProps[e] || (t instanceof L.Polyline || t instanceof L.Polygon || t instanceof L.Rectangle ? (this._uneditedLayerProps[e] = { latlngs: L.LatLngUtil.cloneLatLngs(t.getLatLngs()) }) : t instanceof L.Circle ? (this._uneditedLayerProps[e] = { latlng: L.LatLngUtil.cloneLatLng(t.getLatLng()), radius: t.getRadius() }) : (t instanceof L.Marker || t instanceof L.CircleMarker) && (this._uneditedLayerProps[e] = { latlng: L.LatLngUtil.cloneLatLng(t.getLatLng()) })); }, _getTooltipText: function () { return { text: L.drawLocal.edit.handlers.edit.tooltip.text, subtext: L.drawLocal.edit.handlers.edit.tooltip.subtext }; }, _updateTooltip: function () { this._tooltip.updateContent(this._getTooltipText()); }, _revertLayer: function (t) { var e = L.Util.stamp(t); (t.edited = !1), this._uneditedLayerProps.hasOwnProperty(e) && (t instanceof L.Polyline || t instanceof L.Polygon || t instanceof L.Rectangle ? t.setLatLngs(this._uneditedLayerProps[e].latlngs) : t instanceof L.Circle ? (t.setLatLng(this._uneditedLayerProps[e].latlng), t.setRadius(this._uneditedLayerProps[e].radius)) : (t instanceof L.Marker || t instanceof L.CircleMarker) && t.setLatLng(this._uneditedLayerProps[e].latlng), t.fire("revert-edited", { layer: t })); }, _enableLayerEdit: function (t) { var e, i, o = t.layer || t.target || t; this._backupLayer(o), this.options.poly && ((i = L.Util.extend({}, this.options.poly)), (o.options.poly = i)), this.options.selectedPathOptions && ((e = L.Util.extend({}, this.options.selectedPathOptions)), e.maintainColor && ((e.color = o.options.color), (e.fillColor = o.options.fillColor)), (o.options.original = L.extend({}, o.options)), (o.options.editing = e)), o instanceof L.Marker ? (o.editing && o.editing.enable(), o.dragging.enable(), o .on("dragend", this._onMarkerDragEnd) .on("touchmove", this._onTouchMove, this) .on("MSPointerMove", this._onTouchMove, this) .on("touchend", this._onMarkerDragEnd, this) .on("MSPointerUp", this._onMarkerDragEnd, this)) : o.editing.enable(); }, _disableLayerEdit: function (t) { var e = t.layer || t.target || t; (e.edited = !1), e.editing && e.editing.disable(), delete e.options.editing, delete e.options.original, this._selectedPathOptions && (e instanceof L.Marker ? this._toggleMarkerHighlight(e) : (e.setStyle(e.options.previousOptions), delete e.options.previousOptions)), e instanceof L.Marker ? (e.dragging.disable(), e .off("dragend", this._onMarkerDragEnd, this) .off("touchmove", this._onTouchMove, this) .off("MSPointerMove", this._onTouchMove, this) .off("touchend", this._onMarkerDragEnd, this) .off("MSPointerUp", this._onMarkerDragEnd, this)) : e.editing.disable(); }, _onMouseMove: function (t) { this._tooltip.updatePosition(t.latlng); }, _onMarkerDragEnd: function (t) { var e = t.target; (e.edited = !0), this._map.fire(L.Draw.Event.EDITMOVE, { layer: e }); }, _onTouchMove: function (t) { var e = t.originalEvent.changedTouches[0], i = this._map.mouseEventToLayerPoint(e), o = this._map.layerPointToLatLng(i); t.target.setLatLng(o); }, _hasAvailableLayers: function () { return 0 !== this._featureGroup.getLayers().length; }, })), (L.EditToolbar.Delete = L.Handler.extend({ statics: { TYPE: "remove" }, initialize: function (t, e) { if ((L.Handler.prototype.initialize.call(this, t), L.Util.setOptions(this, e), (this._deletableLayers = this.options.featureGroup), !(this._deletableLayers instanceof L.FeatureGroup))) throw new Error("options.featureGroup must be a L.FeatureGroup"); this.type = L.EditToolbar.Delete.TYPE; var i = L.version.split("."); 1 === parseInt(i[0], 10) && parseInt(i[1], 10) >= 2 ? L.EditToolbar.Delete.include(L.Evented.prototype) : L.EditToolbar.Delete.include(L.Mixin.Events); }, enable: function () { !this._enabled && this._hasAvailableLayers() && (this.fire("enabled", { handler: this.type }), this._map.fire(L.Draw.Event.DELETESTART, { handler: this.type }), L.Handler.prototype.enable.call(this), this._deletableLayers.on("layeradd", this._enableLayerDelete, this).on("layerremove", this._disableLayerDelete, this)); }, disable: function () { this._enabled && (this._deletableLayers.off("layeradd", this._enableLayerDelete, this).off("layerremove", this._disableLayerDelete, this), L.Handler.prototype.disable.call(this), this._map.fire(L.Draw.Event.DELETESTOP, { handler: this.type }), this.fire("disabled", { handler: this.type })); }, addHooks: function () { var t = this._map; t && (t.getContainer().focus(), this._deletableLayers.eachLayer(this._enableLayerDelete, this), (this._deletedLayers = new L.LayerGroup()), (this._tooltip = new L.Draw.Tooltip(this._map)), this._tooltip.updateContent({ text: L.drawLocal.edit.handlers.remove.tooltip.text }), this._map.on("mousemove", this._onMouseMove, this)); }, removeHooks: function () { this._map && (this._deletableLayers.eachLayer(this._disableLayerDelete, this), (this._deletedLayers = null), this._tooltip.dispose(), (this._tooltip = null), this._map.off("mousemove", this._onMouseMove, this)); }, revertLayers: function () { this._deletedLayers.eachLayer(function (t) { this._deletableLayers.addLayer(t), t.fire("revert-deleted", { layer: t }); }, this); }, save: function () { this._map.fire(L.Draw.Event.DELETED, { layers: this._deletedLayers }); }, removeAllLayers: function () { this._deletableLayers.eachLayer(function (t) { this._removeLayer({ layer: t }); }, this), this.save(); }, _enableLayerDelete: function (t) { (t.layer || t.target || t).on("click", this._removeLayer, this); }, _disableLayerDelete: function (t) { var e = t.layer || t.target || t; e.off("click", this._removeLayer, this), this._deletedLayers.removeLayer(e); }, _removeLayer: function (t) { var e = t.layer || t.target || t; this._deletableLayers.removeLayer(e), this._deletedLayers.addLayer(e), e.fire("deleted"); }, _onMouseMove: function (t) { this._tooltip.updatePosition(t.latlng); }, _hasAvailableLayers: function () { return 0 !== this._deletableLayers.getLayers().length; }, })); })(window, document);