kille.bw
Open in
urlscan Pro
18.234.250.107
Public Scan
Submitted URL: http://kille.bw/wp-content/plugins/directorist/assets/vendor-js/openstreet-map/openstreetlayers.js?ver=1712826766
Effective URL: https://kille.bw/wp-content/plugins/directorist/assets/vendor-js/openstreet-map/openstreetlayers.js?ver=1712826766
Submission: On April 13 via api from US — Scanned from DE
Effective URL: https://kille.bw/wp-content/plugins/directorist/assets/vendor-js/openstreet-map/openstreetlayers.js?ver=1712826766
Submission: On April 13 via api from US — Scanned from DE
Form analysis
0 forms found in the DOMText Content
/* @preserve * Leaflet 1.5.1+build.2e3e0ff, a JS library for interactive maps. http://leafletjs.com * (c) 2010-2018 Vladimir Agafonkin, (c) 2010-2011 CloudMade */ !(function (t, i) { "object" == typeof exports && "undefined" != typeof module ? i(exports) : "function" == typeof define && define.amd ? define(["exports"], i) : i((t.L = {})); })(this, function (t) { "use strict"; var i = Object.freeze; function h(t) { var i, e, n, o; for (e = 1, n = arguments.length; e < n; e++) for (i in (o = arguments[e])) t[i] = o[i]; return t; } Object.freeze = function (t) { return t; }; var s = Object.create || function (t) { return (e.prototype = t), new e(); }; function e() {} function a(t, i) { var e = Array.prototype.slice; if (t.bind) return t.bind.apply(t, e.call(arguments, 1)); var n = e.call(arguments, 2); return function () { return t.apply(i, n.length ? n.concat(e.call(arguments)) : arguments); }; } var n = 0; function u(t) { return (t._leaflet_id = t._leaflet_id || ++n), t._leaflet_id; } function o(t, i, e) { var n, o, s, r; return ( (r = function () { (n = !1), o && (s.apply(e, o), (o = !1)); }), (s = function () { n ? (o = arguments) : (t.apply(e, arguments), setTimeout(r, i), (n = !0)); }) ); } function r(t, i, e) { var n = i[1], o = i[0], s = n - o; return t === n && e ? t : ((((t - o) % s) + s) % s) + o; } function l() { return !1; } function c(t, i) { return (i = void 0 === i ? 6 : i), +(Math.round(t + "e+" + i) + "e-" + i); } function _(t) { return t.trim ? t.trim() : t.replace(/^\s+|\s+$/g, ""); } function d(t) { return _(t).split(/\s+/); } function p(t, i) { for (var e in (t.hasOwnProperty("options") || (t.options = t.options ? s(t.options) : {}), i)) t.options[e] = i[e]; return t.options; } function m(t, i, e) { var n = []; for (var o in t) n.push(encodeURIComponent(e ? o.toUpperCase() : o) + "=" + encodeURIComponent(t[o])); return (i && -1 !== i.indexOf("?") ? "&" : "?") + n.join("&"); } var f = /\{ *([\w_-]+) *\}/g; function g(t, n) { return t.replace(f, function (t, i) { var e = n[i]; if (void 0 === e) throw new Error("No value provided for variable " + t); return "function" == typeof e && (e = e(n)), e; }); } var v = Array.isArray || function (t) { return "[object Array]" === Object.prototype.toString.call(t); }; function y(t, i) { for (var e = 0; e < t.length; e++) if (t[e] === i) return e; return -1; } var x = ""; function w(t) { return window["webkit" + t] || window["moz" + t] || window["ms" + t]; } var P = 0; function b(t) { var i = +new Date(), e = Math.max(0, 16 - (i - P)); return (P = i + e), window.setTimeout(t, e); } var T = window.requestAnimationFrame || w("RequestAnimationFrame") || b, z = window.cancelAnimationFrame || w("CancelAnimationFrame") || w("CancelRequestAnimationFrame") || function (t) { window.clearTimeout(t); }; function M(t, i, e) { if (!e || T !== b) return T.call(window, a(t, i)); t.call(i); } function C(t) { t && z.call(window, t); } var S = (Object.freeze || Object)({ freeze: i, extend: h, create: s, bind: a, lastId: n, stamp: u, throttle: o, wrapNum: r, falseFn: l, formatNum: c, trim: _, splitWords: d, setOptions: p, getParamString: m, template: g, isArray: v, indexOf: y, emptyImageUrl: x, requestFn: T, cancelFn: z, requestAnimFrame: M, cancelAnimFrame: C, }); function Z() {} (Z.extend = function (t) { function i() { this.initialize && this.initialize.apply(this, arguments), this.callInitHooks(); } var e = (i.__super__ = this.prototype), n = s(e); for (var o in (((n.constructor = i).prototype = n), this)) this.hasOwnProperty(o) && "prototype" !== o && "__super__" !== o && (i[o] = this[o]); return ( t.statics && (h(i, t.statics), delete t.statics), t.includes && ((function (t) { if ("undefined" == typeof L || !L || !L.Mixin) return; t = v(t) ? t : [t]; for (var i = 0; i < t.length; i++) t[i] === L.Mixin.Events && console.warn("Deprecated include of L.Mixin.Events: this property will be removed in future releases, please inherit from L.Evented instead.", new Error().stack); })(t.includes), h.apply(null, [n].concat(t.includes)), delete t.includes), n.options && (t.options = h(s(n.options), t.options)), h(n, t), (n._initHooks = []), (n.callInitHooks = function () { if (!this._initHooksCalled) { e.callInitHooks && e.callInitHooks.call(this), (this._initHooksCalled = !0); for (var t = 0, i = n._initHooks.length; t < i; t++) n._initHooks[t].call(this); } }), i ); }), (Z.include = function (t) { return h(this.prototype, t), this; }), (Z.mergeOptions = function (t) { return h(this.prototype.options, t), this; }), (Z.addInitHook = function (t) { var i = Array.prototype.slice.call(arguments, 1), e = "function" == typeof t ? t : function () { this[t].apply(this, i); }; return (this.prototype._initHooks = this.prototype._initHooks || []), this.prototype._initHooks.push(e), this; }); var E = { on: function (t, i, e) { if ("object" == typeof t) for (var n in t) this._on(n, t[n], i); else for (var o = 0, s = (t = d(t)).length; o < s; o++) this._on(t[o], i, e); return this; }, off: function (t, i, e) { if (t) if ("object" == typeof t) for (var n in t) this._off(n, t[n], i); else for (var o = 0, s = (t = d(t)).length; o < s; o++) this._off(t[o], i, e); else delete this._events; return this; }, _on: function (t, i, e) { this._events = this._events || {}; var n = this._events[t]; n || ((n = []), (this._events[t] = n)), e === this && (e = void 0); for (var o = { fn: i, ctx: e }, s = n, r = 0, a = s.length; r < a; r++) if (s[r].fn === i && s[r].ctx === e) return; s.push(o); }, _off: function (t, i, e) { var n, o, s; if (this._events && (n = this._events[t])) if (i) { if ((e === this && (e = void 0), n)) for (o = 0, s = n.length; o < s; o++) { var r = n[o]; if (r.ctx === e && r.fn === i) return (r.fn = l), this._firingCount && (this._events[t] = n = n.slice()), void n.splice(o, 1); } } else { for (o = 0, s = n.length; o < s; o++) n[o].fn = l; delete this._events[t]; } }, fire: function (t, i, e) { if (!this.listens(t, e)) return this; var n = h({}, i, { type: t, target: this, sourceTarget: (i && i.sourceTarget) || this }); if (this._events) { var o = this._events[t]; if (o) { this._firingCount = this._firingCount + 1 || 1; for (var s = 0, r = o.length; s < r; s++) { var a = o[s]; a.fn.call(a.ctx || this, n); } this._firingCount--; } } return e && this._propagateEvent(n), this; }, listens: function (t, i) { var e = this._events && this._events[t]; if (e && e.length) return !0; if (i) for (var n in this._eventParents) if (this._eventParents[n].listens(t, i)) return !0; return !1; }, once: function (t, i, e) { if ("object" == typeof t) { for (var n in t) this.once(n, t[n], i); return this; } var o = a(function () { this.off(t, i, e).off(t, o, e); }, this); return this.on(t, i, e).on(t, o, e); }, addEventParent: function (t) { return (this._eventParents = this._eventParents || {}), (this._eventParents[u(t)] = t), this; }, removeEventParent: function (t) { return this._eventParents && delete this._eventParents[u(t)], this; }, _propagateEvent: function (t) { for (var i in this._eventParents) this._eventParents[i].fire(t.type, h({ layer: t.target, propagatedFrom: t.target }, t), !0); }, }; (E.addEventListener = E.on), (E.removeEventListener = E.clearAllEventListeners = E.off), (E.addOneTimeEventListener = E.once), (E.fireEvent = E.fire), (E.hasEventListeners = E.listens); var k = Z.extend(E); function B(t, i, e) { (this.x = e ? Math.round(t) : t), (this.y = e ? Math.round(i) : i); } var A = Math.trunc || function (t) { return 0 < t ? Math.floor(t) : Math.ceil(t); }; function I(t, i, e) { return t instanceof B ? t : v(t) ? new B(t[0], t[1]) : null == t ? t : "object" == typeof t && "x" in t && "y" in t ? new B(t.x, t.y) : new B(t, i, e); } function O(t, i) { if (t) for (var e = i ? [t, i] : t, n = 0, o = e.length; n < o; n++) this.extend(e[n]); } function R(t, i) { return !t || t instanceof O ? t : new O(t, i); } function N(t, i) { if (t) for (var e = i ? [t, i] : t, n = 0, o = e.length; n < o; n++) this.extend(e[n]); } function D(t, i) { return t instanceof N ? t : new N(t, i); } function j(t, i, e) { if (isNaN(t) || isNaN(i)) throw new Error("Invalid LatLng object: (" + t + ", " + i + ")"); (this.lat = +t), (this.lng = +i), void 0 !== e && (this.alt = +e); } function W(t, i, e) { return t instanceof j ? t : v(t) && "object" != typeof t[0] ? 3 === t.length ? new j(t[0], t[1], t[2]) : 2 === t.length ? new j(t[0], t[1]) : null : null == t ? t : "object" == typeof t && "lat" in t ? new j(t.lat, "lng" in t ? t.lng : t.lon, t.alt) : void 0 === i ? null : new j(t, i, e); } (B.prototype = { clone: function () { return new B(this.x, this.y); }, add: function (t) { return this.clone()._add(I(t)); }, _add: function (t) { return (this.x += t.x), (this.y += t.y), this; }, subtract: function (t) { return this.clone()._subtract(I(t)); }, _subtract: function (t) { return (this.x -= t.x), (this.y -= t.y), this; }, divideBy: function (t) { return this.clone()._divideBy(t); }, _divideBy: function (t) { return (this.x /= t), (this.y /= t), this; }, multiplyBy: function (t) { return this.clone()._multiplyBy(t); }, _multiplyBy: function (t) { return (this.x *= t), (this.y *= t), this; }, scaleBy: function (t) { return new B(this.x * t.x, this.y * t.y); }, unscaleBy: function (t) { return new B(this.x / t.x, this.y / t.y); }, round: function () { return this.clone()._round(); }, _round: function () { return (this.x = Math.round(this.x)), (this.y = Math.round(this.y)), this; }, floor: function () { return this.clone()._floor(); }, _floor: function () { return (this.x = Math.floor(this.x)), (this.y = Math.floor(this.y)), this; }, ceil: function () { return this.clone()._ceil(); }, _ceil: function () { return (this.x = Math.ceil(this.x)), (this.y = Math.ceil(this.y)), this; }, trunc: function () { return this.clone()._trunc(); }, _trunc: function () { return (this.x = A(this.x)), (this.y = A(this.y)), this; }, distanceTo: function (t) { var i = (t = I(t)).x - this.x, e = t.y - this.y; return Math.sqrt(i * i + e * e); }, equals: function (t) { return (t = I(t)).x === this.x && t.y === this.y; }, contains: function (t) { return (t = I(t)), Math.abs(t.x) <= Math.abs(this.x) && Math.abs(t.y) <= Math.abs(this.y); }, toString: function () { return "Point(" + c(this.x) + ", " + c(this.y) + ")"; }, }), (O.prototype = { extend: function (t) { return ( (t = I(t)), this.min || this.max ? ((this.min.x = Math.min(t.x, this.min.x)), (this.max.x = Math.max(t.x, this.max.x)), (this.min.y = Math.min(t.y, this.min.y)), (this.max.y = Math.max(t.y, this.max.y))) : ((this.min = t.clone()), (this.max = t.clone())), this ); }, getCenter: function (t) { return new B((this.min.x + this.max.x) / 2, (this.min.y + this.max.y) / 2, t); }, getBottomLeft: function () { return new B(this.min.x, this.max.y); }, getTopRight: function () { return new B(this.max.x, this.min.y); }, getTopLeft: function () { return this.min; }, getBottomRight: function () { return this.max; }, getSize: function () { return this.max.subtract(this.min); }, contains: function (t) { var i, e; return (t = "number" == typeof t[0] || t instanceof B ? I(t) : R(t)) instanceof O ? ((i = t.min), (e = t.max)) : (i = e = t), i.x >= this.min.x && e.x <= this.max.x && i.y >= this.min.y && e.y <= this.max.y; }, intersects: function (t) { t = R(t); var i = this.min, e = this.max, n = t.min, o = t.max, s = o.x >= i.x && n.x <= e.x, r = o.y >= i.y && n.y <= e.y; return s && r; }, overlaps: function (t) { t = R(t); var i = this.min, e = this.max, n = t.min, o = t.max, s = o.x > i.x && n.x < e.x, r = o.y > i.y && n.y < e.y; return s && r; }, isValid: function () { return !(!this.min || !this.max); }, }), (N.prototype = { extend: function (t) { var i, e, n = this._southWest, o = this._northEast; if (t instanceof j) e = i = t; else { if (!(t instanceof N)) return t ? this.extend(W(t) || D(t)) : this; if (((i = t._southWest), (e = t._northEast), !i || !e)) return this; } return ( n || o ? ((n.lat = Math.min(i.lat, n.lat)), (n.lng = Math.min(i.lng, n.lng)), (o.lat = Math.max(e.lat, o.lat)), (o.lng = Math.max(e.lng, o.lng))) : ((this._southWest = new j(i.lat, i.lng)), (this._northEast = new j(e.lat, e.lng))), this ); }, pad: function (t) { var i = this._southWest, e = this._northEast, n = Math.abs(i.lat - e.lat) * t, o = Math.abs(i.lng - e.lng) * t; return new N(new j(i.lat - n, i.lng - o), new j(e.lat + n, e.lng + o)); }, getCenter: function () { return new j((this._southWest.lat + this._northEast.lat) / 2, (this._southWest.lng + this._northEast.lng) / 2); }, getSouthWest: function () { return this._southWest; }, getNorthEast: function () { return this._northEast; }, getNorthWest: function () { return new j(this.getNorth(), this.getWest()); }, getSouthEast: function () { return new j(this.getSouth(), this.getEast()); }, getWest: function () { return this._southWest.lng; }, getSouth: function () { return this._southWest.lat; }, getEast: function () { return this._northEast.lng; }, getNorth: function () { return this._northEast.lat; }, contains: function (t) { t = "number" == typeof t[0] || t instanceof j || "lat" in t ? W(t) : D(t); var i, e, n = this._southWest, o = this._northEast; return t instanceof N ? ((i = t.getSouthWest()), (e = t.getNorthEast())) : (i = e = t), i.lat >= n.lat && e.lat <= o.lat && i.lng >= n.lng && e.lng <= o.lng; }, intersects: function (t) { t = D(t); var i = this._southWest, e = this._northEast, n = t.getSouthWest(), o = t.getNorthEast(), s = o.lat >= i.lat && n.lat <= e.lat, r = o.lng >= i.lng && n.lng <= e.lng; return s && r; }, overlaps: function (t) { t = D(t); var i = this._southWest, e = this._northEast, n = t.getSouthWest(), o = t.getNorthEast(), s = o.lat > i.lat && n.lat < e.lat, r = o.lng > i.lng && n.lng < e.lng; return s && r; }, toBBoxString: function () { return [this.getWest(), this.getSouth(), this.getEast(), this.getNorth()].join(","); }, equals: function (t, i) { return !!t && ((t = D(t)), this._southWest.equals(t.getSouthWest(), i) && this._northEast.equals(t.getNorthEast(), i)); }, isValid: function () { return !(!this._southWest || !this._northEast); }, }); var H, F = { latLngToPoint: function (t, i) { var e = this.projection.project(t), n = this.scale(i); return this.transformation._transform(e, n); }, pointToLatLng: function (t, i) { var e = this.scale(i), n = this.transformation.untransform(t, e); return this.projection.unproject(n); }, project: function (t) { return this.projection.project(t); }, unproject: function (t) { return this.projection.unproject(t); }, scale: function (t) { return 256 * Math.pow(2, t); }, zoom: function (t) { return Math.log(t / 256) / Math.LN2; }, getProjectedBounds: function (t) { if (this.infinite) return null; var i = this.projection.bounds, e = this.scale(t); return new O(this.transformation.transform(i.min, e), this.transformation.transform(i.max, e)); }, infinite: !(j.prototype = { equals: function (t, i) { return !!t && ((t = W(t)), Math.max(Math.abs(this.lat - t.lat), Math.abs(this.lng - t.lng)) <= (void 0 === i ? 1e-9 : i)); }, toString: function (t) { return "LatLng(" + c(this.lat, t) + ", " + c(this.lng, t) + ")"; }, distanceTo: function (t) { return U.distance(this, W(t)); }, wrap: function () { return U.wrapLatLng(this); }, toBounds: function (t) { var i = (180 * t) / 40075017, e = i / Math.cos((Math.PI / 180) * this.lat); return D([this.lat - i, this.lng - e], [this.lat + i, this.lng + e]); }, clone: function () { return new j(this.lat, this.lng, this.alt); }, }), wrapLatLng: function (t) { var i = this.wrapLng ? r(t.lng, this.wrapLng, !0) : t.lng; return new j(this.wrapLat ? r(t.lat, this.wrapLat, !0) : t.lat, i, t.alt); }, wrapLatLngBounds: function (t) { var i = t.getCenter(), e = this.wrapLatLng(i), n = i.lat - e.lat, o = i.lng - e.lng; if (0 == n && 0 == o) return t; var s = t.getSouthWest(), r = t.getNorthEast(); return new N(new j(s.lat - n, s.lng - o), new j(r.lat - n, r.lng - o)); }, }, U = h({}, F, { wrapLng: [-180, 180], R: 6371e3, distance: function (t, i) { var e = Math.PI / 180, n = t.lat * e, o = i.lat * e, s = Math.sin(((i.lat - t.lat) * e) / 2), r = Math.sin(((i.lng - t.lng) * e) / 2), a = s * s + Math.cos(n) * Math.cos(o) * r * r, h = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); return this.R * h; }, }), V = 6378137, q = { R: V, MAX_LATITUDE: 85.0511287798, project: function (t) { var i = Math.PI / 180, e = this.MAX_LATITUDE, n = Math.max(Math.min(e, t.lat), -e), o = Math.sin(n * i); return new B(this.R * t.lng * i, (this.R * Math.log((1 + o) / (1 - o))) / 2); }, unproject: function (t) { var i = 180 / Math.PI; return new j((2 * Math.atan(Math.exp(t.y / this.R)) - Math.PI / 2) * i, (t.x * i) / this.R); }, bounds: ((H = V * Math.PI), new O([-H, -H], [H, H])), }; function G(t, i, e, n) { if (v(t)) return (this._a = t[0]), (this._b = t[1]), (this._c = t[2]), void (this._d = t[3]); (this._a = t), (this._b = i), (this._c = e), (this._d = n); } function K(t, i, e, n) { return new G(t, i, e, n); } G.prototype = { transform: function (t, i) { return this._transform(t.clone(), i); }, _transform: function (t, i) { return (i = i || 1), (t.x = i * (this._a * t.x + this._b)), (t.y = i * (this._c * t.y + this._d)), t; }, untransform: function (t, i) { return (i = i || 1), new B((t.x / i - this._b) / this._a, (t.y / i - this._d) / this._c); }, }; var Y, X = h({}, U, { code: "EPSG:3857", projection: q, transformation: ((Y = 0.5 / (Math.PI * q.R)), K(Y, 0.5, -Y, 0.5)) }), J = h({}, X, { code: "EPSG:900913" }); function $(t) { return document.createElementNS("https://www.w3.org/2000/svg", t); } function Q(t, i) { var e, n, o, s, r, a, h = ""; for (e = 0, o = t.length; e < o; e++) { for (n = 0, s = (r = t[e]).length; n < s; n++) h += (n ? "L" : "M") + (a = r[n]).x + " " + a.y; h += i ? (Zt ? "z" : "x") : ""; } return h || "M0 0"; } var tt = document.documentElement.style, it = "ActiveXObject" in window, et = it && !document.addEventListener, nt = "msLaunchUri" in navigator && !("documentMode" in document), ot = kt("webkit"), st = kt("android"), rt = kt("android 2") || kt("android 3"), at = parseInt(/WebKit\/([0-9]+)|$/.exec(navigator.userAgent)[1], 10), ht = st && kt("Google") && at < 537 && !("AudioNode" in window), ut = !!window.opera, lt = kt("chrome"), ct = kt("gecko") && !ot && !ut && !it, _t = !lt && kt("safari"), dt = kt("phantom"), pt = "OTransition" in tt, mt = 0 === navigator.platform.indexOf("Win"), ft = it && "transition" in tt, gt = "WebKitCSSMatrix" in window && "m11" in new window.WebKitCSSMatrix() && !rt, vt = "MozPerspective" in tt, yt = !window.L_DISABLE_3D && (ft || gt || vt) && !pt && !dt, xt = "undefined" != typeof orientation || kt("mobile"), wt = xt && ot, Pt = xt && gt, bt = !window.PointerEvent && window.MSPointerEvent, Lt = !(!window.PointerEvent && !bt), Tt = !window.L_NO_TOUCH && (Lt || "ontouchstart" in window || (window.DocumentTouch && document instanceof window.DocumentTouch)), zt = xt && ut, Mt = xt && ct, Ct = 1 < (window.devicePixelRatio || window.screen.deviceXDPI / window.screen.logicalXDPI), St = !!document.createElement("canvas").getContext, Zt = !(!document.createElementNS || !$("svg").createSVGRect), Et = !Zt && (function () { try { var t = document.createElement("div"); t.innerHTML = '<v:shape adj="1"/>'; var i = t.firstChild; return (i.style.behavior = "url(#default#VML)"), i && "object" == typeof i.adj; } catch (t) { return !1; } })(); function kt(t) { return 0 <= navigator.userAgent.toLowerCase().indexOf(t); } var Bt = (Object.freeze || Object)({ ie: it, ielt9: et, edge: nt, webkit: ot, android: st, android23: rt, androidStock: ht, opera: ut, chrome: lt, gecko: ct, safari: _t, phantom: dt, opera12: pt, win: mt, ie3d: ft, webkit3d: gt, gecko3d: vt, any3d: yt, mobile: xt, mobileWebkit: wt, mobileWebkit3d: Pt, msPointer: bt, pointer: Lt, touch: Tt, mobileOpera: zt, mobileGecko: Mt, retina: Ct, canvas: St, svg: Zt, vml: Et, }), At = bt ? "MSPointerDown" : "pointerdown", It = bt ? "MSPointerMove" : "pointermove", Ot = bt ? "MSPointerUp" : "pointerup", Rt = bt ? "MSPointerCancel" : "pointercancel", Nt = ["INPUT", "SELECT", "OPTION"], Dt = {}, jt = !1, Wt = 0; function Ht(t, i, e, n) { return ( "touchstart" === i ? (function (t, i, e) { var n = a(function (t) { if ("mouse" !== t.pointerType && t.MSPOINTER_TYPE_MOUSE && t.pointerType !== t.MSPOINTER_TYPE_MOUSE) { if (!(Nt.indexOf(t.target.tagName) < 0)) return; Di(t); } qt(t, i); }); (t["_leaflet_touchstart" + e] = n), t.addEventListener(At, n, !1), jt || (document.documentElement.addEventListener(At, Ft, !0), document.documentElement.addEventListener(It, Ut, !0), document.documentElement.addEventListener(Ot, Vt, !0), document.documentElement.addEventListener(Rt, Vt, !0), (jt = !0)); })(t, e, n) : "touchmove" === i ? (function (t, i, e) { var n = function (t) { ((t.pointerType !== t.MSPOINTER_TYPE_MOUSE && "mouse" !== t.pointerType) || 0 !== t.buttons) && qt(t, i); }; (t["_leaflet_touchmove" + e] = n), t.addEventListener(It, n, !1); })(t, e, n) : "touchend" === i && (function (t, i, e) { var n = function (t) { qt(t, i); }; (t["_leaflet_touchend" + e] = n), t.addEventListener(Ot, n, !1), t.addEventListener(Rt, n, !1); })(t, e, n), this ); } function Ft(t) { (Dt[t.pointerId] = t), Wt++; } function Ut(t) { Dt[t.pointerId] && (Dt[t.pointerId] = t); } function Vt(t) { delete Dt[t.pointerId], Wt--; } function qt(t, i) { for (var e in ((t.touches = []), Dt)) t.touches.push(Dt[e]); (t.changedTouches = [t]), i(t); } var Gt = bt ? "MSPointerDown" : Lt ? "pointerdown" : "touchstart", Kt = bt ? "MSPointerUp" : Lt ? "pointerup" : "touchend", Yt = "_leaflet_"; function Xt(t, o, i) { var s, r, a = !1; function e(t) { var i; if (Lt) { if (!nt || "mouse" === t.pointerType) return; i = Wt; } else i = t.touches.length; if (!(1 < i)) { var e = Date.now(), n = e - (s || e); (r = t.touches ? t.touches[0] : t), (a = 0 < n && n <= 250), (s = e); } } function n(t) { if (a && !r.cancelBubble) { if (Lt) { if (!nt || "mouse" === t.pointerType) return; var i, e, n = {}; for (e in r) (i = r[e]), (n[e] = i && i.bind ? i.bind(r) : i); r = n; } (r.type = "dblclick"), (r.button = 0), o(r), (s = null); } } return (t[Yt + Gt + i] = e), (t[Yt + Kt + i] = n), (t[Yt + "dblclick" + i] = o), t.addEventListener(Gt, e, !1), t.addEventListener(Kt, n, !1), t.addEventListener("dblclick", o, !1), this; } function Jt(t, i) { var e = t[Yt + Gt + i], n = t[Yt + Kt + i], o = t[Yt + "dblclick" + i]; return t.removeEventListener(Gt, e, !1), t.removeEventListener(Kt, n, !1), nt || t.removeEventListener("dblclick", o, !1), this; } var $t, Qt, ti, ii, ei, ni = yi(["transform", "webkitTransform", "OTransform", "MozTransform", "msTransform"]), oi = yi(["webkitTransition", "transition", "OTransition", "MozTransition", "msTransition"]), si = "webkitTransition" === oi || "OTransition" === oi ? oi + "End" : "transitionend"; function ri(t) { return "string" == typeof t ? document.getElementById(t) : t; } function ai(t, i) { var e = t.style[i] || (t.currentStyle && t.currentStyle[i]); if ((!e || "auto" === e) && document.defaultView) { var n = document.defaultView.getComputedStyle(t, null); e = n ? n[i] : null; } return "auto" === e ? null : e; } function hi(t, i, e) { var n = document.createElement(t); return (n.className = i || ""), e && e.appendChild(n), n; } function ui(t) { var i = t.parentNode; i && i.removeChild(t); } function li(t) { for (; t.firstChild; ) t.removeChild(t.firstChild); } function ci(t) { var i = t.parentNode; i && i.lastChild !== t && i.appendChild(t); } function _i(t) { var i = t.parentNode; i && i.firstChild !== t && i.insertBefore(t, i.firstChild); } function di(t, i) { if (void 0 !== t.classList) return t.classList.contains(i); var e = gi(t); return 0 < e.length && new RegExp("(^|\\s)" + i + "(\\s|$)").test(e); } function pi(t, i) { if (void 0 !== t.classList) for (var e = d(i), n = 0, o = e.length; n < o; n++) t.classList.add(e[n]); else if (!di(t, i)) { var s = gi(t); fi(t, (s ? s + " " : "") + i); } } function mi(t, i) { void 0 !== t.classList ? t.classList.remove(i) : fi(t, _((" " + gi(t) + " ").replace(" " + i + " ", " "))); } function fi(t, i) { void 0 === t.className.baseVal ? (t.className = i) : (t.className.baseVal = i); } function gi(t) { return t.correspondingElement && (t = t.correspondingElement), void 0 === t.className.baseVal ? t.className : t.className.baseVal; } function vi(t, i) { "opacity" in t.style ? (t.style.opacity = i) : "filter" in t.style && (function (t, i) { var e = !1, n = "DXImageTransform.Microsoft.Alpha"; try { e = t.filters.item(n); } catch (t) { if (1 === i) return; } (i = Math.round(100 * i)), e ? ((e.Enabled = 100 !== i), (e.Opacity = i)) : (t.style.filter += " progid:" + n + "(opacity=" + i + ")"); })(t, i); } function yi(t) { for (var i = document.documentElement.style, e = 0; e < t.length; e++) if (t[e] in i) return t[e]; return !1; } function xi(t, i, e) { var n = i || new B(0, 0); t.style[ni] = (ft ? "translate(" + n.x + "px," + n.y + "px)" : "translate3d(" + n.x + "px," + n.y + "px,0)") + (e ? " scale(" + e + ")" : ""); } function wi(t, i) { (t._leaflet_pos = i), yt ? xi(t, i) : ((t.style.left = i.x + "px"), (t.style.top = i.y + "px")); } function Pi(t) { return t._leaflet_pos || new B(0, 0); } if ("onselectstart" in document) ($t = function () { Ei(window, "selectstart", Di); }), (Qt = function () { Bi(window, "selectstart", Di); }); else { var bi = yi(["userSelect", "WebkitUserSelect", "OUserSelect", "MozUserSelect", "msUserSelect"]); ($t = function () { if (bi) { var t = document.documentElement.style; (ti = t[bi]), (t[bi] = "none"); } }), (Qt = function () { bi && ((document.documentElement.style[bi] = ti), (ti = void 0)); }); } function Li() { Ei(window, "dragstart", Di); } function Ti() { Bi(window, "dragstart", Di); } function zi(t) { for (; -1 === t.tabIndex; ) t = t.parentNode; t.style && (Mi(), (ei = (ii = t).style.outline), (t.style.outline = "none"), Ei(window, "keydown", Mi)); } function Mi() { ii && ((ii.style.outline = ei), (ei = ii = void 0), Bi(window, "keydown", Mi)); } function Ci(t) { for (; !(((t = t.parentNode).offsetWidth && t.offsetHeight) || t === document.body); ); return t; } function Si(t) { var i = t.getBoundingClientRect(); return { x: i.width / t.offsetWidth || 1, y: i.height / t.offsetHeight || 1, boundingClientRect: i }; } var Zi = (Object.freeze || Object)({ TRANSFORM: ni, TRANSITION: oi, TRANSITION_END: si, get: ri, getStyle: ai, create: hi, remove: ui, empty: li, toFront: ci, toBack: _i, hasClass: di, addClass: pi, removeClass: mi, setClass: fi, getClass: gi, setOpacity: vi, testProp: yi, setTransform: xi, setPosition: wi, getPosition: Pi, disableTextSelection: $t, enableTextSelection: Qt, disableImageDrag: Li, enableImageDrag: Ti, preventOutline: zi, restoreOutline: Mi, getSizedParentNode: Ci, getScale: Si, }); function Ei(t, i, e, n) { if ("object" == typeof i) for (var o in i) Ai(t, o, i[o], e); else for (var s = 0, r = (i = d(i)).length; s < r; s++) Ai(t, i[s], e, n); return this; } var ki = "_leaflet_events"; function Bi(t, i, e, n) { if ("object" == typeof i) for (var o in i) Ii(t, o, i[o], e); else if (i) for (var s = 0, r = (i = d(i)).length; s < r; s++) Ii(t, i[s], e, n); else { for (var a in t[ki]) Ii(t, a, t[ki][a]); delete t[ki]; } return this; } function Ai(i, t, e, n) { var o = t + u(e) + (n ? "_" + u(n) : ""); if (i[ki] && i[ki][o]) return this; var s = function (t) { return e.call(n || i, t || window.event); }, r = s; Lt && 0 === t.indexOf("touch") ? Ht(i, t, s, o) : !Tt || "dblclick" !== t || (Lt && lt) ? "addEventListener" in i ? "mousewheel" === t ? i.addEventListener("onwheel" in i ? "wheel" : "mousewheel", s, !1) : "mouseenter" === t || "mouseleave" === t ? ((s = function (t) { (t = t || window.event), Ki(i, t) && r(t); }), i.addEventListener("mouseenter" === t ? "mouseover" : "mouseout", s, !1)) : ("click" === t && st && (s = function (t) { !(function (t, i) { var e = t.timeStamp || (t.originalEvent && t.originalEvent.timeStamp), n = Ui && e - Ui; if ((n && 100 < n && n < 500) || (t.target._simulatedClick && !t._simulated)) return ji(t); (Ui = e), i(t); })(t, r); }), i.addEventListener(t, s, !1)) : "attachEvent" in i && i.attachEvent("on" + t, s) : Xt(i, s, o), (i[ki] = i[ki] || {}), (i[ki][o] = s); } function Ii(t, i, e, n) { var o = i + u(e) + (n ? "_" + u(n) : ""), s = t[ki] && t[ki][o]; if (!s) return this; Lt && 0 === i.indexOf("touch") ? (function (t, i, e) { var n = t["_leaflet_" + i + e]; "touchstart" === i ? t.removeEventListener(At, n, !1) : "touchmove" === i ? t.removeEventListener(It, n, !1) : "touchend" === i && (t.removeEventListener(Ot, n, !1), t.removeEventListener(Rt, n, !1)); })(t, i, o) : !Tt || "dblclick" !== i || (Lt && lt) ? "removeEventListener" in t ? "mousewheel" === i ? t.removeEventListener("onwheel" in t ? "wheel" : "mousewheel", s, !1) : t.removeEventListener("mouseenter" === i ? "mouseover" : "mouseleave" === i ? "mouseout" : i, s, !1) : "detachEvent" in t && t.detachEvent("on" + i, s) : Jt(t, o), (t[ki][o] = null); } function Oi(t) { return t.stopPropagation ? t.stopPropagation() : t.originalEvent ? (t.originalEvent._stopped = !0) : (t.cancelBubble = !0), Gi(t), this; } function Ri(t) { return Ai(t, "mousewheel", Oi), this; } function Ni(t) { return Ei(t, "mousedown touchstart dblclick", Oi), Ai(t, "click", qi), this; } function Di(t) { return t.preventDefault ? t.preventDefault() : (t.returnValue = !1), this; } function ji(t) { return Di(t), Oi(t), this; } function Wi(t, i) { if (!i) return new B(t.clientX, t.clientY); var e = Si(i), n = e.boundingClientRect; return new B((t.clientX - n.left) / e.x - i.clientLeft, (t.clientY - n.top) / e.y - i.clientTop); } var Hi = mt && lt ? 2 * window.devicePixelRatio : ct ? window.devicePixelRatio : 1; function Fi(t) { return nt ? t.wheelDeltaY / 2 : t.deltaY && 0 === t.deltaMode ? -t.deltaY / Hi : t.deltaY && 1 === t.deltaMode ? 20 * -t.deltaY : t.deltaY && 2 === t.deltaMode ? 60 * -t.deltaY : t.deltaX || t.deltaZ ? 0 : t.wheelDelta ? (t.wheelDeltaY || t.wheelDelta) / 2 : t.detail && Math.abs(t.detail) < 32765 ? 20 * -t.detail : t.detail ? (t.detail / -32765) * 60 : 0; } var Ui, Vi = {}; function qi(t) { Vi[t.type] = !0; } function Gi(t) { var i = Vi[t.type]; return (Vi[t.type] = !1), i; } function Ki(t, i) { var e = i.relatedTarget; if (!e) return !0; try { for (; e && e !== t; ) e = e.parentNode; } catch (t) { return !1; } return e !== t; } var Yi = (Object.freeze || Object)({ on: Ei, off: Bi, stopPropagation: Oi, disableScrollPropagation: Ri, disableClickPropagation: Ni, preventDefault: Di, stop: ji, getMousePosition: Wi, getWheelDelta: Fi, fakeStop: qi, skipped: Gi, isExternalTarget: Ki, addListener: Ei, removeListener: Bi, }), Xi = k.extend({ run: function (t, i, e, n) { this.stop(), (this._el = t), (this._inProgress = !0), (this._duration = e || 0.25), (this._easeOutPower = 1 / Math.max(n || 0.5, 0.2)), (this._startPos = Pi(t)), (this._offset = i.subtract(this._startPos)), (this._startTime = +new Date()), this.fire("start"), this._animate(); }, stop: function () { this._inProgress && (this._step(!0), this._complete()); }, _animate: function () { (this._animId = M(this._animate, this)), this._step(); }, _step: function (t) { var i = +new Date() - this._startTime, e = 1e3 * this._duration; i < e ? this._runFrame(this._easeOut(i / e), t) : (this._runFrame(1), this._complete()); }, _runFrame: function (t, i) { var e = this._startPos.add(this._offset.multiplyBy(t)); i && e._round(), wi(this._el, e), this.fire("step"); }, _complete: function () { C(this._animId), (this._inProgress = !1), this.fire("end"); }, _easeOut: function (t) { return 1 - Math.pow(1 - t, this._easeOutPower); }, }), Ji = k.extend({ options: { crs: X, center: void 0, zoom: void 0, minZoom: void 0, maxZoom: void 0, layers: [], maxBounds: void 0, renderer: void 0, zoomAnimation: !0, zoomAnimationThreshold: 4, fadeAnimation: !0, markerZoomAnimation: !0, transform3DLimit: 8388608, zoomSnap: 1, zoomDelta: 1, trackResize: !0, }, initialize: function (t, i) { (i = p(this, i)), (this._handlers = []), (this._layers = {}), (this._zoomBoundLayers = {}), (this._sizeChanged = !0), this._initContainer(t), this._initLayout(), (this._onResize = a(this._onResize, this)), this._initEvents(), i.maxBounds && this.setMaxBounds(i.maxBounds), void 0 !== i.zoom && (this._zoom = this._limitZoom(i.zoom)), i.center && void 0 !== i.zoom && this.setView(W(i.center), i.zoom, { reset: !0 }), this.callInitHooks(), (this._zoomAnimated = oi && yt && !zt && this.options.zoomAnimation), this._zoomAnimated && (this._createAnimProxy(), Ei(this._proxy, si, this._catchTransitionEnd, this)), this._addLayers(this.options.layers); }, setView: function (t, i, e) { if ( ((i = void 0 === i ? this._zoom : this._limitZoom(i)), (t = this._limitCenter(W(t), i, this.options.maxBounds)), (e = e || {}), this._stop(), this._loaded && !e.reset && !0 !== e) && (void 0 !== e.animate && ((e.zoom = h({ animate: e.animate }, e.zoom)), (e.pan = h({ animate: e.animate, duration: e.duration }, e.pan))), this._zoom !== i ? this._tryAnimatedZoom && this._tryAnimatedZoom(t, i, e.zoom) : this._tryAnimatedPan(t, e.pan)) ) return clearTimeout(this._sizeTimer), this; return this._resetView(t, i), this; }, setZoom: function (t, i) { return this._loaded ? this.setView(this.getCenter(), t, { zoom: i }) : ((this._zoom = t), this); }, zoomIn: function (t, i) { return (t = t || (yt ? this.options.zoomDelta : 1)), this.setZoom(this._zoom + t, i); }, zoomOut: function (t, i) { return (t = t || (yt ? this.options.zoomDelta : 1)), this.setZoom(this._zoom - t, i); }, setZoomAround: function (t, i, e) { var n = this.getZoomScale(i), o = this.getSize().divideBy(2), s = (t instanceof B ? t : this.latLngToContainerPoint(t)).subtract(o).multiplyBy(1 - 1 / n), r = this.containerPointToLatLng(o.add(s)); return this.setView(r, i, { zoom: e }); }, _getBoundsCenterZoom: function (t, i) { (i = i || {}), (t = t.getBounds ? t.getBounds() : D(t)); var e = I(i.paddingTopLeft || i.padding || [0, 0]), n = I(i.paddingBottomRight || i.padding || [0, 0]), o = this.getBoundsZoom(t, !1, e.add(n)); if ((o = "number" == typeof i.maxZoom ? Math.min(i.maxZoom, o) : o) === 1 / 0) return { center: t.getCenter(), zoom: o }; var s = n.subtract(e).divideBy(2), r = this.project(t.getSouthWest(), o), a = this.project(t.getNorthEast(), o); return { center: this.unproject(r.add(a).divideBy(2).add(s), o), zoom: o }; }, fitBounds: function (t, i) { if (!(t = D(t)).isValid()) throw new Error("Bounds are not valid."); var e = this._getBoundsCenterZoom(t, i); return this.setView(e.center, e.zoom, i); }, fitWorld: function (t) { return this.fitBounds( [ [-90, -180], [90, 180], ], t ); }, panTo: function (t, i) { return this.setView(t, this._zoom, { pan: i }); }, panBy: function (t, i) { if (((i = i || {}), !(t = I(t).round()).x && !t.y)) return this.fire("moveend"); if (!0 !== i.animate && !this.getSize().contains(t)) return this._resetView(this.unproject(this.project(this.getCenter()).add(t)), this.getZoom()), this; if ((this._panAnim || ((this._panAnim = new Xi()), this._panAnim.on({ step: this._onPanTransitionStep, end: this._onPanTransitionEnd }, this)), i.noMoveStart || this.fire("movestart"), !1 !== i.animate)) { pi(this._mapPane, "leaflet-pan-anim"); var e = this._getMapPanePos().subtract(t).round(); this._panAnim.run(this._mapPane, e, i.duration || 0.25, i.easeLinearity); } else this._rawPanBy(t), this.fire("move").fire("moveend"); return this; }, flyTo: function (n, o, t) { if (!1 === (t = t || {}).animate || !yt) return this.setView(n, o, t); this._stop(); var s = this.project(this.getCenter()), r = this.project(n), i = this.getSize(), a = this._zoom; (n = W(n)), (o = void 0 === o ? a : o); var h = Math.max(i.x, i.y), u = h * this.getZoomScale(a, o), l = r.distanceTo(s) || 1, c = 1.42, _ = c * c; function e(t) { var i = (u * u - h * h + (t ? -1 : 1) * _ * _ * l * l) / (2 * (t ? u : h) * _ * l), e = Math.sqrt(i * i + 1) - i; return e < 1e-9 ? -18 : Math.log(e); } function d(t) { return (Math.exp(t) - Math.exp(-t)) / 2; } function p(t) { return (Math.exp(t) + Math.exp(-t)) / 2; } var m = e(0); function f(t) { return ( (h * (p(m) * (function (t) { return d(t) / p(t); })(m + c * t) - d(m))) / _ ); } var g = Date.now(), v = (e(1) - m) / c, y = t.duration ? 1e3 * t.duration : 1e3 * v * 0.8; return ( this._moveStart(!0, t.noMoveStart), function t() { var i = (Date.now() - g) / y, e = (function (t) { return 1 - Math.pow(1 - t, 1.5); })(i) * v; i <= 1 ? ((this._flyToFrame = M(t, this)), this._move( this.unproject(s.add(r.subtract(s).multiplyBy(f(e) / l)), a), this.getScaleZoom( h / (function (t) { return h * (p(m) / p(m + c * t)); })(e), a ), { flyTo: !0 } )) : this._move(n, o)._moveEnd(!0); }.call(this), this ); }, flyToBounds: function (t, i) { var e = this._getBoundsCenterZoom(t, i); return this.flyTo(e.center, e.zoom, i); }, setMaxBounds: function (t) { return (t = D(t)).isValid() ? (this.options.maxBounds && this.off("moveend", this._panInsideMaxBounds), (this.options.maxBounds = t), this._loaded && this._panInsideMaxBounds(), this.on("moveend", this._panInsideMaxBounds)) : ((this.options.maxBounds = null), this.off("moveend", this._panInsideMaxBounds)); }, setMinZoom: function (t) { var i = this.options.minZoom; return (this.options.minZoom = t), this._loaded && i !== t && (this.fire("zoomlevelschange"), this.getZoom() < this.options.minZoom) ? this.setZoom(t) : this; }, setMaxZoom: function (t) { var i = this.options.maxZoom; return (this.options.maxZoom = t), this._loaded && i !== t && (this.fire("zoomlevelschange"), this.getZoom() > this.options.maxZoom) ? this.setZoom(t) : this; }, panInsideBounds: function (t, i) { this._enforcingBounds = !0; var e = this.getCenter(), n = this._limitCenter(e, this._zoom, D(t)); return e.equals(n) || this.panTo(n, i), (this._enforcingBounds = !1), this; }, panInside: function (t, i) { var e = I((i = i || {}).paddingTopLeft || i.padding || [0, 0]), n = I(i.paddingBottomRight || i.padding || [0, 0]), o = this.getCenter(), s = this.project(o), r = this.project(t), a = this.getPixelBounds(), h = a.getSize().divideBy(2), u = R([a.min.add(e), a.max.subtract(n)]); if (!u.contains(r)) { this._enforcingBounds = !0; var l = s.subtract(r), c = I(r.x + l.x, r.y + l.y); (r.x < u.min.x || r.x > u.max.x) && ((c.x = s.x - l.x), 0 < l.x ? (c.x += h.x - e.x) : (c.x -= h.x - n.x)), (r.y < u.min.y || r.y > u.max.y) && ((c.y = s.y - l.y), 0 < l.y ? (c.y += h.y - e.y) : (c.y -= h.y - n.y)), this.panTo(this.unproject(c), i), (this._enforcingBounds = !1); } return this; }, invalidateSize: function (t) { if (!this._loaded) return this; t = h({ animate: !1, pan: !0 }, !0 === t ? { animate: !0 } : t); var i = this.getSize(); (this._sizeChanged = !0), (this._lastCenter = null); var e = this.getSize(), n = i.divideBy(2).round(), o = e.divideBy(2).round(), s = n.subtract(o); return s.x || s.y ? (t.animate && t.pan ? this.panBy(s) : (t.pan && this._rawPanBy(s), this.fire("move"), t.debounceMoveend ? (clearTimeout(this._sizeTimer), (this._sizeTimer = setTimeout(a(this.fire, this, "moveend"), 200))) : this.fire("moveend")), this.fire("resize", { oldSize: i, newSize: e })) : this; }, stop: function () { return this.setZoom(this._limitZoom(this._zoom)), this.options.zoomSnap || this.fire("viewreset"), this._stop(); }, locate: function (t) { if (((t = this._locateOptions = h({ timeout: 1e4, watch: !1 }, t)), !("geolocation" in navigator))) return this._handleGeolocationError({ code: 0, message: "Geolocation not supported." }), this; var i = a(this._handleGeolocationResponse, this), e = a(this._handleGeolocationError, this); return t.watch ? (this._locationWatchId = navigator.geolocation.watchPosition(i, e, t)) : navigator.geolocation.getCurrentPosition(i, e, t), this; }, stopLocate: function () { return navigator.geolocation && navigator.geolocation.clearWatch && navigator.geolocation.clearWatch(this._locationWatchId), this._locateOptions && (this._locateOptions.setView = !1), this; }, _handleGeolocationError: function (t) { var i = t.code, e = t.message || (1 === i ? "permission denied" : 2 === i ? "position unavailable" : "timeout"); this._locateOptions.setView && !this._loaded && this.fitWorld(), this.fire("locationerror", { code: i, message: "Geolocation error: " + e + "." }); }, _handleGeolocationResponse: function (t) { var i = new j(t.coords.latitude, t.coords.longitude), e = i.toBounds(2 * t.coords.accuracy), n = this._locateOptions; if (n.setView) { var o = this.getBoundsZoom(e); this.setView(i, n.maxZoom ? Math.min(o, n.maxZoom) : o); } var s = { latlng: i, bounds: e, timestamp: t.timestamp }; for (var r in t.coords) "number" == typeof t.coords[r] && (s[r] = t.coords[r]); this.fire("locationfound", s); }, addHandler: function (t, i) { if (!i) return this; var e = (this[t] = new i(this)); return this._handlers.push(e), this.options[t] && e.enable(), this; }, remove: function () { if ((this._initEvents(!0), this._containerId !== this._container._leaflet_id)) throw new Error("Map container is being reused by another instance"); try { delete this._container._leaflet_id, delete this._containerId; } catch (t) { (this._container._leaflet_id = void 0), (this._containerId = void 0); } var t; for (t in (void 0 !== this._locationWatchId && this.stopLocate(), this._stop(), ui(this._mapPane), this._clearControlPos && this._clearControlPos(), this._resizeRequest && (C(this._resizeRequest), (this._resizeRequest = null)), this._clearHandlers(), this._loaded && this.fire("unload"), this._layers)) this._layers[t].remove(); for (t in this._panes) ui(this._panes[t]); return (this._layers = []), (this._panes = []), delete this._mapPane, delete this._renderer, this; }, createPane: function (t, i) { var e = hi("div", "leaflet-pane" + (t ? " leaflet-" + t.replace("Pane", "") + "-pane" : ""), i || this._mapPane); return t && (this._panes[t] = e), e; }, getCenter: function () { return this._checkIfLoaded(), this._lastCenter && !this._moved() ? this._lastCenter : this.layerPointToLatLng(this._getCenterLayerPoint()); }, getZoom: function () { return this._zoom; }, getBounds: function () { var t = this.getPixelBounds(); return new N(this.unproject(t.getBottomLeft()), this.unproject(t.getTopRight())); }, getMinZoom: function () { return void 0 === this.options.minZoom ? this._layersMinZoom || 0 : this.options.minZoom; }, getMaxZoom: function () { return void 0 === this.options.maxZoom ? (void 0 === this._layersMaxZoom ? 1 / 0 : this._layersMaxZoom) : this.options.maxZoom; }, getBoundsZoom: function (t, i, e) { (t = D(t)), (e = I(e || [0, 0])); var n = this.getZoom() || 0, o = this.getMinZoom(), s = this.getMaxZoom(), r = t.getNorthWest(), a = t.getSouthEast(), h = this.getSize().subtract(e), u = R(this.project(a, n), this.project(r, n)).getSize(), l = yt ? this.options.zoomSnap : 1, c = h.x / u.x, _ = h.y / u.y, d = i ? Math.max(c, _) : Math.min(c, _); return (n = this.getScaleZoom(d, n)), l && ((n = Math.round(n / (l / 100)) * (l / 100)), (n = i ? Math.ceil(n / l) * l : Math.floor(n / l) * l)), Math.max(o, Math.min(s, n)); }, getSize: function () { return (this._size && !this._sizeChanged) || ((this._size = new B(this._container.clientWidth || 0, this._container.clientHeight || 0)), (this._sizeChanged = !1)), this._size.clone(); }, getPixelBounds: function (t, i) { var e = this._getTopLeftPoint(t, i); return new O(e, e.add(this.getSize())); }, getPixelOrigin: function () { return this._checkIfLoaded(), this._pixelOrigin; }, getPixelWorldBounds: function (t) { return this.options.crs.getProjectedBounds(void 0 === t ? this.getZoom() : t); }, getPane: function (t) { return "string" == typeof t ? this._panes[t] : t; }, getPanes: function () { return this._panes; }, getContainer: function () { return this._container; }, getZoomScale: function (t, i) { var e = this.options.crs; return (i = void 0 === i ? this._zoom : i), e.scale(t) / e.scale(i); }, getScaleZoom: function (t, i) { var e = this.options.crs; i = void 0 === i ? this._zoom : i; var n = e.zoom(t * e.scale(i)); return isNaN(n) ? 1 / 0 : n; }, project: function (t, i) { return (i = void 0 === i ? this._zoom : i), this.options.crs.latLngToPoint(W(t), i); }, unproject: function (t, i) { return (i = void 0 === i ? this._zoom : i), this.options.crs.pointToLatLng(I(t), i); }, layerPointToLatLng: function (t) { var i = I(t).add(this.getPixelOrigin()); return this.unproject(i); }, latLngToLayerPoint: function (t) { return this.project(W(t))._round()._subtract(this.getPixelOrigin()); }, wrapLatLng: function (t) { return this.options.crs.wrapLatLng(W(t)); }, wrapLatLngBounds: function (t) { return this.options.crs.wrapLatLngBounds(D(t)); }, distance: function (t, i) { return this.options.crs.distance(W(t), W(i)); }, containerPointToLayerPoint: function (t) { return I(t).subtract(this._getMapPanePos()); }, layerPointToContainerPoint: function (t) { return I(t).add(this._getMapPanePos()); }, containerPointToLatLng: function (t) { var i = this.containerPointToLayerPoint(I(t)); return this.layerPointToLatLng(i); }, latLngToContainerPoint: function (t) { return this.layerPointToContainerPoint(this.latLngToLayerPoint(W(t))); }, mouseEventToContainerPoint: function (t) { return Wi(t, this._container); }, mouseEventToLayerPoint: function (t) { return this.containerPointToLayerPoint(this.mouseEventToContainerPoint(t)); }, mouseEventToLatLng: function (t) { return this.layerPointToLatLng(this.mouseEventToLayerPoint(t)); }, _initContainer: function (t) { var i = (this._container = ri(t)); if (!i) throw new Error("Map container not found."); if (i._leaflet_id) throw new Error("Map container is already initialized."); Ei(i, "scroll", this._onScroll, this), (this._containerId = u(i)); }, _initLayout: function () { var t = this._container; (this._fadeAnimated = this.options.fadeAnimation && yt), pi(t, "leaflet-container" + (Tt ? " leaflet-touch" : "") + (Ct ? " leaflet-retina" : "") + (et ? " leaflet-oldie" : "") + (_t ? " leaflet-safari" : "") + (this._fadeAnimated ? " leaflet-fade-anim" : "")); var i = ai(t, "position"); "absolute" !== i && "relative" !== i && "fixed" !== i && (t.style.position = "relative"), this._initPanes(), this._initControlPos && this._initControlPos(); }, _initPanes: function () { var t = (this._panes = {}); (this._paneRenderers = {}), (this._mapPane = this.createPane("mapPane", this._container)), wi(this._mapPane, new B(0, 0)), this.createPane("tilePane"), this.createPane("shadowPane"), this.createPane("overlayPane"), this.createPane("markerPane"), this.createPane("tooltipPane"), this.createPane("popupPane"), this.options.markerZoomAnimation || (pi(t.markerPane, "leaflet-zoom-hide"), pi(t.shadowPane, "leaflet-zoom-hide")); }, _resetView: function (t, i) { wi(this._mapPane, new B(0, 0)); var e = !this._loaded; (this._loaded = !0), (i = this._limitZoom(i)), this.fire("viewprereset"); var n = this._zoom !== i; this._moveStart(n, !1)._move(t, i)._moveEnd(n), this.fire("viewreset"), e && this.fire("load"); }, _moveStart: function (t, i) { return t && this.fire("zoomstart"), i || this.fire("movestart"), this; }, _move: function (t, i, e) { void 0 === i && (i = this._zoom); var n = this._zoom !== i; return (this._zoom = i), (this._lastCenter = t), (this._pixelOrigin = this._getNewPixelOrigin(t)), (n || (e && e.pinch)) && this.fire("zoom", e), this.fire("move", e); }, _moveEnd: function (t) { return t && this.fire("zoomend"), this.fire("moveend"); }, _stop: function () { return C(this._flyToFrame), this._panAnim && this._panAnim.stop(), this; }, _rawPanBy: function (t) { wi(this._mapPane, this._getMapPanePos().subtract(t)); }, _getZoomSpan: function () { return this.getMaxZoom() - this.getMinZoom(); }, _panInsideMaxBounds: function () { this._enforcingBounds || this.panInsideBounds(this.options.maxBounds); }, _checkIfLoaded: function () { if (!this._loaded) throw new Error("Set map center and zoom first."); }, _initEvents: function (t) { this._targets = {}; var i = t ? Bi : Ei; i((this._targets[u(this._container)] = this)._container, "click dblclick mousedown mouseup mouseover mouseout mousemove contextmenu keypress keydown keyup", this._handleDOMEvent, this), this.options.trackResize && i(window, "resize", this._onResize, this), yt && this.options.transform3DLimit && (t ? this.off : this.on).call(this, "moveend", this._onMoveEnd); }, _onResize: function () { C(this._resizeRequest), (this._resizeRequest = M(function () { this.invalidateSize({ debounceMoveend: !0 }); }, this)); }, _onScroll: function () { (this._container.scrollTop = 0), (this._container.scrollLeft = 0); }, _onMoveEnd: function () { var t = this._getMapPanePos(); Math.max(Math.abs(t.x), Math.abs(t.y)) >= this.options.transform3DLimit && this._resetView(this.getCenter(), this.getZoom()); }, _findEventTargets: function (t, i) { for (var e, n = [], o = "mouseout" === i || "mouseover" === i, s = t.target || t.srcElement, r = !1; s; ) { if ((e = this._targets[u(s)]) && ("click" === i || "preclick" === i) && !t._simulated && this._draggableMoved(e)) { r = !0; break; } if (e && e.listens(i, !0)) { if (o && !Ki(s, t)) break; if ((n.push(e), o)) break; } if (s === this._container) break; s = s.parentNode; } return n.length || r || o || !Ki(s, t) || (n = [this]), n; }, _handleDOMEvent: function (t) { if (this._loaded && !Gi(t)) { var i = t.type; ("mousedown" !== i && "keypress" !== i && "keyup" !== i && "keydown" !== i) || zi(t.target || t.srcElement), this._fireDOMEvent(t, i); } }, _mouseEvents: ["click", "dblclick", "mouseover", "mouseout", "contextmenu"], _fireDOMEvent: function (t, i, e) { if ("click" === t.type) { var n = h({}, t); (n.type = "preclick"), this._fireDOMEvent(n, n.type, e); } if (!t._stopped && (e = (e || []).concat(this._findEventTargets(t, i))).length) { var o = e[0]; "contextmenu" === i && o.listens(i, !0) && Di(t); var s = { originalEvent: t }; if ("keypress" !== t.type && "keydown" !== t.type && "keyup" !== t.type) { var r = o.getLatLng && (!o._radius || o._radius <= 10); (s.containerPoint = r ? this.latLngToContainerPoint(o.getLatLng()) : this.mouseEventToContainerPoint(t)), (s.layerPoint = this.containerPointToLayerPoint(s.containerPoint)), (s.latlng = r ? o.getLatLng() : this.layerPointToLatLng(s.layerPoint)); } for (var a = 0; a < e.length; a++) if ((e[a].fire(i, s, !0), s.originalEvent._stopped || (!1 === e[a].options.bubblingMouseEvents && -1 !== y(this._mouseEvents, i)))) return; } }, _draggableMoved: function (t) { return ((t = t.dragging && t.dragging.enabled() ? t : this).dragging && t.dragging.moved()) || (this.boxZoom && this.boxZoom.moved()); }, _clearHandlers: function () { for (var t = 0, i = this._handlers.length; t < i; t++) this._handlers[t].disable(); }, whenReady: function (t, i) { return this._loaded ? t.call(i || this, { target: this }) : this.on("load", t, i), this; }, _getMapPanePos: function () { return Pi(this._mapPane) || new B(0, 0); }, _moved: function () { var t = this._getMapPanePos(); return t && !t.equals([0, 0]); }, _getTopLeftPoint: function (t, i) { return (t && void 0 !== i ? this._getNewPixelOrigin(t, i) : this.getPixelOrigin()).subtract(this._getMapPanePos()); }, _getNewPixelOrigin: function (t, i) { var e = this.getSize()._divideBy(2); return this.project(t, i)._subtract(e)._add(this._getMapPanePos())._round(); }, _latLngToNewLayerPoint: function (t, i, e) { var n = this._getNewPixelOrigin(e, i); return this.project(t, i)._subtract(n); }, _latLngBoundsToNewLayerBounds: function (t, i, e) { var n = this._getNewPixelOrigin(e, i); return R([this.project(t.getSouthWest(), i)._subtract(n), this.project(t.getNorthWest(), i)._subtract(n), this.project(t.getSouthEast(), i)._subtract(n), this.project(t.getNorthEast(), i)._subtract(n)]); }, _getCenterLayerPoint: function () { return this.containerPointToLayerPoint(this.getSize()._divideBy(2)); }, _getCenterOffset: function (t) { return this.latLngToLayerPoint(t).subtract(this._getCenterLayerPoint()); }, _limitCenter: function (t, i, e) { if (!e) return t; var n = this.project(t, i), o = this.getSize().divideBy(2), s = new O(n.subtract(o), n.add(o)), r = this._getBoundsOffset(s, e, i); return r.round().equals([0, 0]) ? t : this.unproject(n.add(r), i); }, _limitOffset: function (t, i) { if (!i) return t; var e = this.getPixelBounds(), n = new O(e.min.add(t), e.max.add(t)); return t.add(this._getBoundsOffset(n, i)); }, _getBoundsOffset: function (t, i, e) { var n = R(this.project(i.getNorthEast(), e), this.project(i.getSouthWest(), e)), o = n.min.subtract(t.min), s = n.max.subtract(t.max); return new B(this._rebound(o.x, -s.x), this._rebound(o.y, -s.y)); }, _rebound: function (t, i) { return 0 < t + i ? Math.round(t - i) / 2 : Math.max(0, Math.ceil(t)) - Math.max(0, Math.floor(i)); }, _limitZoom: function (t) { var i = this.getMinZoom(), e = this.getMaxZoom(), n = yt ? this.options.zoomSnap : 1; return n && (t = Math.round(t / n) * n), Math.max(i, Math.min(e, t)); }, _onPanTransitionStep: function () { this.fire("move"); }, _onPanTransitionEnd: function () { mi(this._mapPane, "leaflet-pan-anim"), this.fire("moveend"); }, _tryAnimatedPan: function (t, i) { var e = this._getCenterOffset(t)._trunc(); return !(!0 !== (i && i.animate) && !this.getSize().contains(e)) && (this.panBy(e, i), !0); }, _createAnimProxy: function () { var t = (this._proxy = hi("div", "leaflet-proxy leaflet-zoom-animated")); this._panes.mapPane.appendChild(t), this.on( "zoomanim", function (t) { var i = ni, e = this._proxy.style[i]; xi(this._proxy, this.project(t.center, t.zoom), this.getZoomScale(t.zoom, 1)), e === this._proxy.style[i] && this._animatingZoom && this._onZoomTransitionEnd(); }, this ), this.on( "load moveend", function () { var t = this.getCenter(), i = this.getZoom(); xi(this._proxy, this.project(t, i), this.getZoomScale(i, 1)); }, this ), this._on("unload", this._destroyAnimProxy, this); }, _destroyAnimProxy: function () { ui(this._proxy), delete this._proxy; }, _catchTransitionEnd: function (t) { this._animatingZoom && 0 <= t.propertyName.indexOf("transform") && this._onZoomTransitionEnd(); }, _nothingToAnimate: function () { return !this._container.getElementsByClassName("leaflet-zoom-animated").length; }, _tryAnimatedZoom: function (t, i, e) { if (this._animatingZoom) return !0; if (((e = e || {}), !this._zoomAnimated || !1 === e.animate || this._nothingToAnimate() || Math.abs(i - this._zoom) > this.options.zoomAnimationThreshold)) return !1; var n = this.getZoomScale(i), o = this._getCenterOffset(t)._divideBy(1 - 1 / n); return ( !(!0 !== e.animate && !this.getSize().contains(o)) && (M(function () { this._moveStart(!0, !1)._animateZoom(t, i, !0); }, this), !0) ); }, _animateZoom: function (t, i, e, n) { this._mapPane && (e && ((this._animatingZoom = !0), (this._animateToCenter = t), (this._animateToZoom = i), pi(this._mapPane, "leaflet-zoom-anim")), this.fire("zoomanim", { center: t, zoom: i, noUpdate: n }), setTimeout(a(this._onZoomTransitionEnd, this), 250)); }, _onZoomTransitionEnd: function () { this._animatingZoom && (this._mapPane && mi(this._mapPane, "leaflet-zoom-anim"), (this._animatingZoom = !1), this._move(this._animateToCenter, this._animateToZoom), M(function () { this._moveEnd(!0); }, this)); }, }); function $i(t) { return new Qi(t); } var Qi = Z.extend({ options: { position: "topright" }, initialize: function (t) { p(this, t); }, getPosition: function () { return this.options.position; }, setPosition: function (t) { var i = this._map; return i && i.removeControl(this), (this.options.position = t), i && i.addControl(this), this; }, getContainer: function () { return this._container; }, addTo: function (t) { this.remove(), (this._map = t); var i = (this._container = this.onAdd(t)), e = this.getPosition(), n = t._controlCorners[e]; return pi(i, "leaflet-control"), -1 !== e.indexOf("bottom") ? n.insertBefore(i, n.firstChild) : n.appendChild(i), this._map.on("unload", this.remove, this), this; }, remove: function () { return this._map && (ui(this._container), this.onRemove && this.onRemove(this._map), this._map.off("unload", this.remove, this), (this._map = null)), this; }, _refocusOnMap: function (t) { this._map && t && 0 < t.screenX && 0 < t.screenY && this._map.getContainer().focus(); }, }); Ji.include({ addControl: function (t) { return t.addTo(this), this; }, removeControl: function (t) { return t.remove(), this; }, _initControlPos: function () { var n = (this._controlCorners = {}), o = "leaflet-", s = (this._controlContainer = hi("div", o + "control-container", this._container)); function t(t, i) { var e = o + t + " " + o + i; n[t + i] = hi("div", e, s); } t("top", "left"), t("top", "right"), t("bottom", "left"), t("bottom", "right"); }, _clearControlPos: function () { for (var t in this._controlCorners) ui(this._controlCorners[t]); ui(this._controlContainer), delete this._controlCorners, delete this._controlContainer; }, }); var te = Qi.extend({ options: { collapsed: !0, position: "topright", autoZIndex: !0, hideSingleBase: !1, sortLayers: !1, sortFunction: function (t, i, e, n) { return e < n ? -1 : n < e ? 1 : 0; }, }, initialize: function (t, i, e) { for (var n in (p(this, e), (this._layerControlInputs = []), (this._layers = []), (this._lastZIndex = 0), (this._handlingClick = !1), t)) this._addLayer(t[n], n); for (n in i) this._addLayer(i[n], n, !0); }, onAdd: function (t) { this._initLayout(), this._update(), (this._map = t).on("zoomend", this._checkDisabledLayers, this); for (var i = 0; i < this._layers.length; i++) this._layers[i].layer.on("add remove", this._onLayerChange, this); return this._container; }, addTo: function (t) { return Qi.prototype.addTo.call(this, t), this._expandIfNotCollapsed(); }, onRemove: function () { this._map.off("zoomend", this._checkDisabledLayers, this); for (var t = 0; t < this._layers.length; t++) this._layers[t].layer.off("add remove", this._onLayerChange, this); }, addBaseLayer: function (t, i) { return this._addLayer(t, i), this._map ? this._update() : this; }, addOverlay: function (t, i) { return this._addLayer(t, i, !0), this._map ? this._update() : this; }, removeLayer: function (t) { t.off("add remove", this._onLayerChange, this); var i = this._getLayer(u(t)); return i && this._layers.splice(this._layers.indexOf(i), 1), this._map ? this._update() : this; }, expand: function () { pi(this._container, "leaflet-control-layers-expanded"), (this._section.style.height = null); var t = this._map.getSize().y - (this._container.offsetTop + 50); return ( t < this._section.clientHeight ? (pi(this._section, "leaflet-control-layers-scrollbar"), (this._section.style.height = t + "px")) : mi(this._section, "leaflet-control-layers-scrollbar"), this._checkDisabledLayers(), this ); }, collapse: function () { return mi(this._container, "leaflet-control-layers-expanded"), this; }, _initLayout: function () { var t = "leaflet-control-layers", i = (this._container = hi("div", t)), e = this.options.collapsed; i.setAttribute("aria-haspopup", !0), Ni(i), Ri(i); var n = (this._section = hi("section", t + "-list")); e && (this._map.on("click", this.collapse, this), st || Ei(i, { mouseenter: this.expand, mouseleave: this.collapse }, this)); var o = (this._layersLink = hi("a", t + "-toggle", i)); (o.href = "#"), (o.title = "Layers"), Tt ? (Ei(o, "click", ji), Ei(o, "click", this.expand, this)) : Ei(o, "focus", this.expand, this), e || this.expand(), (this._baseLayersList = hi("div", t + "-base", n)), (this._separator = hi("div", t + "-separator", n)), (this._overlaysList = hi("div", t + "-overlays", n)), i.appendChild(n); }, _getLayer: function (t) { for (var i = 0; i < this._layers.length; i++) if (this._layers[i] && u(this._layers[i].layer) === t) return this._layers[i]; }, _addLayer: function (t, i, e) { this._map && t.on("add remove", this._onLayerChange, this), this._layers.push({ layer: t, name: i, overlay: e }), this.options.sortLayers && this._layers.sort( a(function (t, i) { return this.options.sortFunction(t.layer, i.layer, t.name, i.name); }, this) ), this.options.autoZIndex && t.setZIndex && (this._lastZIndex++, t.setZIndex(this._lastZIndex)), this._expandIfNotCollapsed(); }, _update: function () { if (!this._container) return this; li(this._baseLayersList), li(this._overlaysList), (this._layerControlInputs = []); var t, i, e, n, o = 0; for (e = 0; e < this._layers.length; e++) (n = this._layers[e]), this._addItem(n), (i = i || n.overlay), (t = t || !n.overlay), (o += n.overlay ? 0 : 1); return this.options.hideSingleBase && ((t = t && 1 < o), (this._baseLayersList.style.display = t ? "" : "none")), (this._separator.style.display = i && t ? "" : "none"), this; }, _onLayerChange: function (t) { this._handlingClick || this._update(); var i = this._getLayer(u(t.target)), e = i.overlay ? ("add" === t.type ? "overlayadd" : "overlayremove") : "add" === t.type ? "baselayerchange" : null; e && this._map.fire(e, i); }, _createRadioElement: function (t, i) { var e = '<input type="radio" class="leaflet-control-layers-selector" name="' + t + '"' + (i ? ' checked="checked"' : "") + "/>", n = document.createElement("div"); return (n.innerHTML = e), n.firstChild; }, _addItem: function (t) { var i, e = document.createElement("label"), n = this._map.hasLayer(t.layer); t.overlay ? (((i = document.createElement("input")).type = "checkbox"), (i.className = "leaflet-control-layers-selector"), (i.defaultChecked = n)) : (i = this._createRadioElement("leaflet-base-layers_" + u(this), n)), this._layerControlInputs.push(i), (i.layerId = u(t.layer)), Ei(i, "click", this._onInputClick, this); var o = document.createElement("span"); o.innerHTML = " " + t.name; var s = document.createElement("div"); return e.appendChild(s), s.appendChild(i), s.appendChild(o), (t.overlay ? this._overlaysList : this._baseLayersList).appendChild(e), this._checkDisabledLayers(), e; }, _onInputClick: function () { var t, i, e = this._layerControlInputs, n = [], o = []; this._handlingClick = !0; for (var s = e.length - 1; 0 <= s; s--) (t = e[s]), (i = this._getLayer(t.layerId).layer), t.checked ? n.push(i) : t.checked || o.push(i); for (s = 0; s < o.length; s++) this._map.hasLayer(o[s]) && this._map.removeLayer(o[s]); for (s = 0; s < n.length; s++) this._map.hasLayer(n[s]) || this._map.addLayer(n[s]); (this._handlingClick = !1), this._refocusOnMap(); }, _checkDisabledLayers: function () { for (var t, i, e = this._layerControlInputs, n = this._map.getZoom(), o = e.length - 1; 0 <= o; o--) (t = e[o]), (i = this._getLayer(t.layerId).layer), (t.disabled = (void 0 !== i.options.minZoom && n < i.options.minZoom) || (void 0 !== i.options.maxZoom && n > i.options.maxZoom)); }, _expandIfNotCollapsed: function () { return this._map && !this.options.collapsed && this.expand(), this; }, _expand: function () { return this.expand(); }, _collapse: function () { return this.collapse(); }, }), ie = Qi.extend({ options: { position: "topleft", zoomInText: "+", zoomInTitle: "Zoom in", zoomOutText: "−", zoomOutTitle: "Zoom out" }, onAdd: function (t) { var i = "leaflet-control-zoom", e = hi("div", i + " leaflet-bar"), n = this.options; return ( (this._zoomInButton = this._createButton(n.zoomInText, n.zoomInTitle, i + "-in", e, this._zoomIn)), (this._zoomOutButton = this._createButton(n.zoomOutText, n.zoomOutTitle, i + "-out", e, this._zoomOut)), this._updateDisabled(), t.on("zoomend zoomlevelschange", this._updateDisabled, this), e ); }, onRemove: function (t) { t.off("zoomend zoomlevelschange", this._updateDisabled, this); }, disable: function () { return (this._disabled = !0), this._updateDisabled(), this; }, enable: function () { return (this._disabled = !1), this._updateDisabled(), this; }, _zoomIn: function (t) { !this._disabled && this._map._zoom < this._map.getMaxZoom() && this._map.zoomIn(this._map.options.zoomDelta * (t.shiftKey ? 3 : 1)); }, _zoomOut: function (t) { !this._disabled && this._map._zoom > this._map.getMinZoom() && this._map.zoomOut(this._map.options.zoomDelta * (t.shiftKey ? 3 : 1)); }, _createButton: function (t, i, e, n, o) { var s = hi("a", e, n); return (s.innerHTML = t), (s.href = "#"), (s.title = i), s.setAttribute("role", "button"), s.setAttribute("aria-label", i), Ni(s), Ei(s, "click", ji), Ei(s, "click", o, this), Ei(s, "click", this._refocusOnMap, this), s; }, _updateDisabled: function () { var t = this._map, i = "leaflet-disabled"; mi(this._zoomInButton, i), mi(this._zoomOutButton, i), (!this._disabled && t._zoom !== t.getMinZoom()) || pi(this._zoomOutButton, i), (!this._disabled && t._zoom !== t.getMaxZoom()) || pi(this._zoomInButton, i); }, }); Ji.mergeOptions({ zoomControl: !0 }), Ji.addInitHook(function () { this.options.zoomControl && ((this.zoomControl = new ie()), this.addControl(this.zoomControl)); }); var ee = Qi.extend({ options: { position: "bottomleft", maxWidth: 100, metric: !0, imperial: !0 }, onAdd: function (t) { var i = "leaflet-control-scale", e = hi("div", i), n = this.options; return this._addScales(n, i + "-line", e), t.on(n.updateWhenIdle ? "moveend" : "move", this._update, this), t.whenReady(this._update, this), e; }, onRemove: function (t) { t.off(this.options.updateWhenIdle ? "moveend" : "move", this._update, this); }, _addScales: function (t, i, e) { t.metric && (this._mScale = hi("div", i, e)), t.imperial && (this._iScale = hi("div", i, e)); }, _update: function () { var t = this._map, i = t.getSize().y / 2, e = t.distance(t.containerPointToLatLng([0, i]), t.containerPointToLatLng([this.options.maxWidth, i])); this._updateScales(e); }, _updateScales: function (t) { this.options.metric && t && this._updateMetric(t), this.options.imperial && t && this._updateImperial(t); }, _updateMetric: function (t) { var i = this._getRoundNum(t), e = i < 1e3 ? i + " m" : i / 1e3 + " km"; this._updateScale(this._mScale, e, i / t); }, _updateImperial: function (t) { var i, e, n, o = 3.2808399 * t; 5280 < o ? ((i = o / 5280), (e = this._getRoundNum(i)), this._updateScale(this._iScale, e + " mi", e / i)) : ((n = this._getRoundNum(o)), this._updateScale(this._iScale, n + " ft", n / o)); }, _updateScale: function (t, i, e) { (t.style.width = Math.round(this.options.maxWidth * e) + "px"), (t.innerHTML = i); }, _getRoundNum: function (t) { var i = Math.pow(10, (Math.floor(t) + "").length - 1), e = t / i; return i * (e = 10 <= e ? 10 : 5 <= e ? 5 : 3 <= e ? 3 : 2 <= e ? 2 : 1); }, }), ne = Qi.extend({ options: { position: "bottomright", prefix: '<a href="https://leafletjs.com" title="A JS library for interactive maps">Leaflet</a>' }, initialize: function (t) { p(this, t), (this._attributions = {}); }, onAdd: function (t) { for (var i in (((t.attributionControl = this)._container = hi("div", "leaflet-control-attribution")), Ni(this._container), t._layers)) t._layers[i].getAttribution && this.addAttribution(t._layers[i].getAttribution()); return this._update(), this._container; }, setPrefix: function (t) { return (this.options.prefix = t), this._update(), this; }, addAttribution: function (t) { return t && (this._attributions[t] || (this._attributions[t] = 0), this._attributions[t]++, this._update()), this; }, removeAttribution: function (t) { return t && this._attributions[t] && (this._attributions[t]--, this._update()), this; }, _update: function () { if (this._map) { var t = []; for (var i in this._attributions) this._attributions[i] && t.push(i); var e = []; this.options.prefix && e.push(this.options.prefix), t.length && e.push(t.join(", ")), (this._container.innerHTML = e.join(" | ")); } }, }); Ji.mergeOptions({ attributionControl: !0 }), Ji.addInitHook(function () { this.options.attributionControl && new ne().addTo(this); }); (Qi.Layers = te), (Qi.Zoom = ie), (Qi.Scale = ee), (Qi.Attribution = ne), ($i.layers = function (t, i, e) { return new te(t, i, e); }), ($i.zoom = function (t) { return new ie(t); }), ($i.scale = function (t) { return new ee(t); }), ($i.attribution = function (t) { return new ne(t); }); var oe = Z.extend({ initialize: function (t) { this._map = t; }, enable: function () { return this._enabled || ((this._enabled = !0), this.addHooks()), this; }, disable: function () { return this._enabled && ((this._enabled = !1), this.removeHooks()), this; }, enabled: function () { return !!this._enabled; }, }); oe.addTo = function (t, i) { return t.addHandler(i, this), this; }; var se, re = { Events: E }, ae = Tt ? "touchstart mousedown" : "mousedown", he = { mousedown: "mouseup", touchstart: "touchend", pointerdown: "touchend", MSPointerDown: "touchend" }, ue = { mousedown: "mousemove", touchstart: "touchmove", pointerdown: "touchmove", MSPointerDown: "touchmove" }, le = k.extend({ options: { clickTolerance: 3 }, initialize: function (t, i, e, n) { p(this, n), (this._element = t), (this._dragStartTarget = i || t), (this._preventOutline = e); }, enable: function () { this._enabled || (Ei(this._dragStartTarget, ae, this._onDown, this), (this._enabled = !0)); }, disable: function () { this._enabled && (le._dragging === this && this.finishDrag(), Bi(this._dragStartTarget, ae, this._onDown, this), (this._enabled = !1), (this._moved = !1)); }, _onDown: function (t) { if ( !t._simulated && this._enabled && ((this._moved = !1), !di(this._element, "leaflet-zoom-anim") && !(le._dragging || t.shiftKey || (1 !== t.which && 1 !== t.button && !t.touches) || ((le._dragging = this)._preventOutline && zi(this._element), Li(), $t(), this._moving))) ) { this.fire("down"); var i = t.touches ? t.touches[0] : t, e = Ci(this._element); (this._startPoint = new B(i.clientX, i.clientY)), (this._parentScale = Si(e)), Ei(document, ue[t.type], this._onMove, this), Ei(document, he[t.type], this._onUp, this); } }, _onMove: function (t) { if (!t._simulated && this._enabled) if (t.touches && 1 < t.touches.length) this._moved = !0; else { var i = t.touches && 1 === t.touches.length ? t.touches[0] : t, e = new B(i.clientX, i.clientY)._subtract(this._startPoint); (e.x || e.y) && (Math.abs(e.x) + Math.abs(e.y) < this.options.clickTolerance || ((e.x /= this._parentScale.x), (e.y /= this._parentScale.y), Di(t), this._moved || (this.fire("dragstart"), (this._moved = !0), (this._startPos = Pi(this._element).subtract(e)), pi(document.body, "leaflet-dragging"), (this._lastTarget = t.target || t.srcElement), window.SVGElementInstance && this._lastTarget instanceof SVGElementInstance && (this._lastTarget = this._lastTarget.correspondingUseElement), pi(this._lastTarget, "leaflet-drag-target")), (this._newPos = this._startPos.add(e)), (this._moving = !0), C(this._animRequest), (this._lastEvent = t), (this._animRequest = M(this._updatePosition, this, !0)))); } }, _updatePosition: function () { var t = { originalEvent: this._lastEvent }; this.fire("predrag", t), wi(this._element, this._newPos), this.fire("drag", t); }, _onUp: function (t) { !t._simulated && this._enabled && this.finishDrag(); }, finishDrag: function () { for (var t in (mi(document.body, "leaflet-dragging"), this._lastTarget && (mi(this._lastTarget, "leaflet-drag-target"), (this._lastTarget = null)), ue)) Bi(document, ue[t], this._onMove, this), Bi(document, he[t], this._onUp, this); Ti(), Qt(), this._moved && this._moving && (C(this._animRequest), this.fire("dragend", { distance: this._newPos.distanceTo(this._startPos) })), (this._moving = !1), (le._dragging = !1); }, }); function ce(t, i) { if (!i || !t.length) return t.slice(); var e = i * i; return (t = (function (t, i) { var e = t.length, n = new (typeof Uint8Array != void 0 + "" ? Uint8Array : Array)(e); (n[0] = n[e - 1] = 1), (function t(i, e, n, o, s) { var r, a, h, u = 0; for (a = o + 1; a <= s - 1; a++) (h = fe(i[a], i[o], i[s], !0)), u < h && ((r = a), (u = h)); n < u && ((e[r] = 1), t(i, e, n, o, r), t(i, e, n, r, s)); })(t, n, i, 0, e - 1); var o, s = []; for (o = 0; o < e; o++) n[o] && s.push(t[o]); return s; })( (t = (function (t, i) { for (var e = [t[0]], n = 1, o = 0, s = t.length; n < s; n++) (r = t[n]), (a = t[o]), void 0, (h = a.x - r.x), (u = a.y - r.y), i < h * h + u * u && (e.push(t[n]), (o = n)); var r, a, h, u; o < s - 1 && e.push(t[s - 1]); return e; })(t, e)), e )); } function _e(t, i, e) { return Math.sqrt(fe(t, i, e, !0)); } function de(t, i, e, n, o) { var s, r, a, h = n ? se : me(t, e), u = me(i, e); for (se = u; ; ) { if (!(h | u)) return [t, i]; if (h & u) return !1; (a = me((r = pe(t, i, (s = h || u), e, o)), e)), s === h ? ((t = r), (h = a)) : ((i = r), (u = a)); } } function pe(t, i, e, n, o) { var s, r, a = i.x - t.x, h = i.y - t.y, u = n.min, l = n.max; return ( 8 & e ? ((s = t.x + (a * (l.y - t.y)) / h), (r = l.y)) : 4 & e ? ((s = t.x + (a * (u.y - t.y)) / h), (r = u.y)) : 2 & e ? ((s = l.x), (r = t.y + (h * (l.x - t.x)) / a)) : 1 & e && ((s = u.x), (r = t.y + (h * (u.x - t.x)) / a)), new B(s, r, o) ); } function me(t, i) { var e = 0; return t.x < i.min.x ? (e |= 1) : t.x > i.max.x && (e |= 2), t.y < i.min.y ? (e |= 4) : t.y > i.max.y && (e |= 8), e; } function fe(t, i, e, n) { var o, s = i.x, r = i.y, a = e.x - s, h = e.y - r, u = a * a + h * h; return 0 < u && (1 < (o = ((t.x - s) * a + (t.y - r) * h) / u) ? ((s = e.x), (r = e.y)) : 0 < o && ((s += a * o), (r += h * o))), (a = t.x - s), (h = t.y - r), n ? a * a + h * h : new B(s, r); } function ge(t) { return !v(t[0]) || ("object" != typeof t[0][0] && void 0 !== t[0][0]); } function ve(t) { return console.warn("Deprecated use of _flat, please use L.LineUtil.isFlat instead."), ge(t); } var ye = (Object.freeze || Object)({ simplify: ce, pointToSegmentDistance: _e, closestPointOnSegment: function (t, i, e) { return fe(t, i, e); }, clipSegment: de, _getEdgeIntersection: pe, _getBitCode: me, _sqClosestPointOnSegment: fe, isFlat: ge, _flat: ve, }); function xe(t, i, e) { var n, o, s, r, a, h, u, l, c, _ = [1, 4, 2, 8]; for (o = 0, u = t.length; o < u; o++) t[o]._code = me(t[o], i); for (r = 0; r < 4; r++) { for (l = _[r], n = [], o = 0, s = (u = t.length) - 1; o < u; s = o++) (a = t[o]), (h = t[s]), a._code & l ? h._code & l || (((c = pe(h, a, l, i, e))._code = me(c, i)), n.push(c)) : (h._code & l && (((c = pe(h, a, l, i, e))._code = me(c, i)), n.push(c)), n.push(a)); t = n; } return t; } var we, Pe = (Object.freeze || Object)({ clipPolygon: xe }), be = { project: function (t) { return new B(t.lng, t.lat); }, unproject: function (t) { return new j(t.y, t.x); }, bounds: new O([-180, -90], [180, 90]), }, Le = { R: 6378137, R_MINOR: 6356752.314245179, bounds: new O([-20037508.34279, -15496570.73972], [20037508.34279, 18764656.23138]), project: function (t) { var i = Math.PI / 180, e = this.R, n = t.lat * i, o = this.R_MINOR / e, s = Math.sqrt(1 - o * o), r = s * Math.sin(n), a = Math.tan(Math.PI / 4 - n / 2) / Math.pow((1 - r) / (1 + r), s / 2); return (n = -e * Math.log(Math.max(a, 1e-10))), new B(t.lng * i * e, n); }, unproject: function (t) { for (var i, e = 180 / Math.PI, n = this.R, o = this.R_MINOR / n, s = Math.sqrt(1 - o * o), r = Math.exp(-t.y / n), a = Math.PI / 2 - 2 * Math.atan(r), h = 0, u = 0.1; h < 15 && 1e-7 < Math.abs(u); h++) (i = s * Math.sin(a)), (i = Math.pow((1 - i) / (1 + i), s / 2)), (a += u = Math.PI / 2 - 2 * Math.atan(r * i) - a); return new j(a * e, (t.x * e) / n); }, }, Te = (Object.freeze || Object)({ LonLat: be, Mercator: Le, SphericalMercator: q }), ze = h({}, U, { code: "EPSG:3395", projection: Le, transformation: ((we = 0.5 / (Math.PI * Le.R)), K(we, 0.5, -we, 0.5)) }), Me = h({}, U, { code: "EPSG:4326", projection: be, transformation: K(1 / 180, 1, -1 / 180, 0.5) }), Ce = h({}, F, { projection: be, transformation: K(1, 0, -1, 0), scale: function (t) { return Math.pow(2, t); }, zoom: function (t) { return Math.log(t) / Math.LN2; }, distance: function (t, i) { var e = i.lng - t.lng, n = i.lat - t.lat; return Math.sqrt(e * e + n * n); }, infinite: !0, }); (F.Earth = U), (F.EPSG3395 = ze), (F.EPSG3857 = X), (F.EPSG900913 = J), (F.EPSG4326 = Me), (F.Simple = Ce); var Se = k.extend({ options: { pane: "overlayPane", attribution: null, bubblingMouseEvents: !0 }, addTo: function (t) { return t.addLayer(this), this; }, remove: function () { return this.removeFrom(this._map || this._mapToAdd); }, removeFrom: function (t) { return t && t.removeLayer(this), this; }, getPane: function (t) { return this._map.getPane(t ? this.options[t] || t : this.options.pane); }, addInteractiveTarget: function (t) { return (this._map._targets[u(t)] = this); }, removeInteractiveTarget: function (t) { return delete this._map._targets[u(t)], this; }, getAttribution: function () { return this.options.attribution; }, _layerAdd: function (t) { var i = t.target; if (i.hasLayer(this)) { if (((this._map = i), (this._zoomAnimated = i._zoomAnimated), this.getEvents)) { var e = this.getEvents(); i.on(e, this), this.once( "remove", function () { i.off(e, this); }, this ); } this.onAdd(i), this.getAttribution && i.attributionControl && i.attributionControl.addAttribution(this.getAttribution()), this.fire("add"), i.fire("layeradd", { layer: this }); } }, }); Ji.include({ addLayer: function (t) { if (!t._layerAdd) throw new Error("The provided object is not a Layer."); var i = u(t); return this._layers[i] || (((this._layers[i] = t)._mapToAdd = this), t.beforeAdd && t.beforeAdd(this), this.whenReady(t._layerAdd, t)), this; }, removeLayer: function (t) { var i = u(t); return ( this._layers[i] && (this._loaded && t.onRemove(this), t.getAttribution && this.attributionControl && this.attributionControl.removeAttribution(t.getAttribution()), delete this._layers[i], this._loaded && (this.fire("layerremove", { layer: t }), t.fire("remove")), (t._map = t._mapToAdd = null)), this ); }, hasLayer: function (t) { return !!t && u(t) in this._layers; }, eachLayer: function (t, i) { for (var e in this._layers) t.call(i, this._layers[e]); return this; }, _addLayers: function (t) { for (var i = 0, e = (t = t ? (v(t) ? t : [t]) : []).length; i < e; i++) this.addLayer(t[i]); }, _addZoomLimit: function (t) { (!isNaN(t.options.maxZoom) && isNaN(t.options.minZoom)) || ((this._zoomBoundLayers[u(t)] = t), this._updateZoomLevels()); }, _removeZoomLimit: function (t) { var i = u(t); this._zoomBoundLayers[i] && (delete this._zoomBoundLayers[i], this._updateZoomLevels()); }, _updateZoomLevels: function () { var t = 1 / 0, i = -1 / 0, e = this._getZoomSpan(); for (var n in this._zoomBoundLayers) { var o = this._zoomBoundLayers[n].options; (t = void 0 === o.minZoom ? t : Math.min(t, o.minZoom)), (i = void 0 === o.maxZoom ? i : Math.max(i, o.maxZoom)); } (this._layersMaxZoom = i === -1 / 0 ? void 0 : i), (this._layersMinZoom = t === 1 / 0 ? void 0 : t), e !== this._getZoomSpan() && this.fire("zoomlevelschange"), void 0 === this.options.maxZoom && this._layersMaxZoom && this.getZoom() > this._layersMaxZoom && this.setZoom(this._layersMaxZoom), void 0 === this.options.minZoom && this._layersMinZoom && this.getZoom() < this._layersMinZoom && this.setZoom(this._layersMinZoom); }, }); var Ze = Se.extend({ initialize: function (t, i) { var e, n; if ((p(this, i), (this._layers = {}), t)) for (e = 0, n = t.length; e < n; e++) this.addLayer(t[e]); }, addLayer: function (t) { var i = this.getLayerId(t); return (this._layers[i] = t), this._map && this._map.addLayer(t), this; }, removeLayer: function (t) { var i = t in this._layers ? t : this.getLayerId(t); return this._map && this._layers[i] && this._map.removeLayer(this._layers[i]), delete this._layers[i], this; }, hasLayer: function (t) { return !!t && (t in this._layers || this.getLayerId(t) in this._layers); }, clearLayers: function () { return this.eachLayer(this.removeLayer, this); }, invoke: function (t) { var i, e, n = Array.prototype.slice.call(arguments, 1); for (i in this._layers) (e = this._layers[i])[t] && e[t].apply(e, n); return this; }, onAdd: function (t) { this.eachLayer(t.addLayer, t); }, onRemove: function (t) { this.eachLayer(t.removeLayer, t); }, eachLayer: function (t, i) { for (var e in this._layers) t.call(i, this._layers[e]); return this; }, getLayer: function (t) { return this._layers[t]; }, getLayers: function () { var t = []; return this.eachLayer(t.push, t), t; }, setZIndex: function (t) { return this.invoke("setZIndex", t); }, getLayerId: function (t) { return u(t); }, }), Ee = Ze.extend({ addLayer: function (t) { return this.hasLayer(t) ? this : (t.addEventParent(this), Ze.prototype.addLayer.call(this, t), this.fire("layeradd", { layer: t })); }, removeLayer: function (t) { return this.hasLayer(t) ? (t in this._layers && (t = this._layers[t]), t.removeEventParent(this), Ze.prototype.removeLayer.call(this, t), this.fire("layerremove", { layer: t })) : this; }, setStyle: function (t) { return this.invoke("setStyle", t); }, bringToFront: function () { return this.invoke("bringToFront"); }, bringToBack: function () { return this.invoke("bringToBack"); }, getBounds: function () { var t = new N(); for (var i in this._layers) { var e = this._layers[i]; t.extend(e.getBounds ? e.getBounds() : e.getLatLng()); } return t; }, }), ke = Z.extend({ options: { popupAnchor: [0, 0], tooltipAnchor: [0, 0] }, initialize: function (t) { p(this, t); }, createIcon: function (t) { return this._createIcon("icon", t); }, createShadow: function (t) { return this._createIcon("shadow", t); }, _createIcon: function (t, i) { var e = this._getIconUrl(t); if (!e) { if ("icon" === t) throw new Error("iconUrl not set in Icon options (see the docs)."); return null; } var n = this._createImg(e, i && "IMG" === i.tagName ? i : null); return this._setIconStyles(n, t), n; }, _setIconStyles: function (t, i) { var e = this.options, n = e[i + "Size"]; "number" == typeof n && (n = [n, n]); var o = I(n), s = I(("shadow" === i && e.shadowAnchor) || e.iconAnchor || (o && o.divideBy(2, !0))); (t.className = "leaflet-marker-" + i + " " + (e.className || "")), s && ((t.style.marginLeft = -s.x + "px"), (t.style.marginTop = -s.y + "px")), o && ((t.style.width = o.x + "px"), (t.style.height = o.y + "px")); }, _createImg: function (t, i) { return ((i = i || document.createElement("img")).src = t), i; }, _getIconUrl: function (t) { return (Ct && this.options[t + "RetinaUrl"]) || this.options[t + "Url"]; }, }); var Be = ke.extend({ options: { iconUrl: "marker-icon.png", iconRetinaUrl: "marker-icon-2x.png", shadowUrl: "marker-shadow.png", iconSize: [25, 41], iconAnchor: [12, 41], popupAnchor: [1, -34], tooltipAnchor: [16, -28], shadowSize: [41, 41] }, _getIconUrl: function (t) { return Be.imagePath || (Be.imagePath = this._detectIconPath()), (this.options.imagePath || Be.imagePath) + ke.prototype._getIconUrl.call(this, t); }, _detectIconPath: function () { var t = hi("div", "leaflet-default-icon-path", document.body), i = ai(t, "background-image") || ai(t, "backgroundImage"); return document.body.removeChild(t), (i = null === i || 0 !== i.indexOf("url") ? "" : i.replace(/^url\(["']?/, "").replace(/marker-icon\.png["']?\)$/, "")); }, }), Ae = oe.extend({ initialize: function (t) { this._marker = t; }, addHooks: function () { var t = this._marker._icon; this._draggable || (this._draggable = new le(t, t, !0)), this._draggable.on({ dragstart: this._onDragStart, predrag: this._onPreDrag, drag: this._onDrag, dragend: this._onDragEnd }, this).enable(), pi(t, "leaflet-marker-draggable"); }, removeHooks: function () { this._draggable.off({ dragstart: this._onDragStart, predrag: this._onPreDrag, drag: this._onDrag, dragend: this._onDragEnd }, this).disable(), this._marker._icon && mi(this._marker._icon, "leaflet-marker-draggable"); }, moved: function () { return this._draggable && this._draggable._moved; }, _adjustPan: function (t) { var i = this._marker, e = i._map, n = this._marker.options.autoPanSpeed, o = this._marker.options.autoPanPadding, s = Pi(i._icon), r = e.getPixelBounds(), a = e.getPixelOrigin(), h = R(r.min._subtract(a).add(o), r.max._subtract(a).subtract(o)); if (!h.contains(s)) { var u = I( (Math.max(h.max.x, s.x) - h.max.x) / (r.max.x - h.max.x) - (Math.min(h.min.x, s.x) - h.min.x) / (r.min.x - h.min.x), (Math.max(h.max.y, s.y) - h.max.y) / (r.max.y - h.max.y) - (Math.min(h.min.y, s.y) - h.min.y) / (r.min.y - h.min.y) ).multiplyBy(n); e.panBy(u, { animate: !1 }), this._draggable._newPos._add(u), this._draggable._startPos._add(u), wi(i._icon, this._draggable._newPos), this._onDrag(t), (this._panRequest = M(this._adjustPan.bind(this, t))); } }, _onDragStart: function () { (this._oldLatLng = this._marker.getLatLng()), this._marker.closePopup().fire("movestart").fire("dragstart"); }, _onPreDrag: function (t) { this._marker.options.autoPan && (C(this._panRequest), (this._panRequest = M(this._adjustPan.bind(this, t)))); }, _onDrag: function (t) { var i = this._marker, e = i._shadow, n = Pi(i._icon), o = i._map.layerPointToLatLng(n); e && wi(e, n), (i._latlng = o), (t.latlng = o), (t.oldLatLng = this._oldLatLng), i.fire("move", t).fire("drag", t); }, _onDragEnd: function (t) { C(this._panRequest), delete this._oldLatLng, this._marker.fire("moveend").fire("dragend", t); }, }), Ie = Se.extend({ options: { icon: new Be(), interactive: !0, keyboard: !0, title: "", alt: "", zIndexOffset: 0, opacity: 1, riseOnHover: !1, riseOffset: 250, pane: "markerPane", shadowPane: "shadowPane", bubblingMouseEvents: !1, draggable: !1, autoPan: !1, autoPanPadding: [50, 50], autoPanSpeed: 10, }, initialize: function (t, i) { p(this, i), (this._latlng = W(t)); }, onAdd: function (t) { (this._zoomAnimated = this._zoomAnimated && t.options.markerZoomAnimation), this._zoomAnimated && t.on("zoomanim", this._animateZoom, this), this._initIcon(), this.update(); }, onRemove: function (t) { this.dragging && this.dragging.enabled() && ((this.options.draggable = !0), this.dragging.removeHooks()), delete this.dragging, this._zoomAnimated && t.off("zoomanim", this._animateZoom, this), this._removeIcon(), this._removeShadow(); }, getEvents: function () { return { zoom: this.update, viewreset: this.update }; }, getLatLng: function () { return this._latlng; }, setLatLng: function (t) { var i = this._latlng; return (this._latlng = W(t)), this.update(), this.fire("move", { oldLatLng: i, latlng: this._latlng }); }, setZIndexOffset: function (t) { return (this.options.zIndexOffset = t), this.update(); }, getIcon: function () { return this.options.icon; }, setIcon: function (t) { return (this.options.icon = t), this._map && (this._initIcon(), this.update()), this._popup && this.bindPopup(this._popup, this._popup.options), this; }, getElement: function () { return this._icon; }, update: function () { if (this._icon && this._map) { var t = this._map.latLngToLayerPoint(this._latlng).round(); this._setPos(t); } return this; }, _initIcon: function () { var t = this.options, i = "leaflet-zoom-" + (this._zoomAnimated ? "animated" : "hide"), e = t.icon.createIcon(this._icon), n = !1; e !== this._icon && (this._icon && this._removeIcon(), (n = !0), t.title && (e.title = t.title), "IMG" === e.tagName && (e.alt = t.alt || "")), pi(e, i), t.keyboard && (e.tabIndex = "0"), (this._icon = e), t.riseOnHover && this.on({ mouseover: this._bringToFront, mouseout: this._resetZIndex }); var o = t.icon.createShadow(this._shadow), s = !1; o !== this._shadow && (this._removeShadow(), (s = !0)), o && (pi(o, i), (o.alt = "")), (this._shadow = o), t.opacity < 1 && this._updateOpacity(), n && this.getPane().appendChild(this._icon), this._initInteraction(), o && s && this.getPane(t.shadowPane).appendChild(this._shadow); }, _removeIcon: function () { this.options.riseOnHover && this.off({ mouseover: this._bringToFront, mouseout: this._resetZIndex }), ui(this._icon), this.removeInteractiveTarget(this._icon), (this._icon = null); }, _removeShadow: function () { this._shadow && ui(this._shadow), (this._shadow = null); }, _setPos: function (t) { wi(this._icon, t), this._shadow && wi(this._shadow, t), (this._zIndex = t.y + this.options.zIndexOffset), this._resetZIndex(); }, _updateZIndex: function (t) { this._icon.style.zIndex = this._zIndex + t; }, _animateZoom: function (t) { var i = this._map._latLngToNewLayerPoint(this._latlng, t.zoom, t.center).round(); this._setPos(i); }, _initInteraction: function () { if (this.options.interactive && (pi(this._icon, "leaflet-interactive"), this.addInteractiveTarget(this._icon), Ae)) { var t = this.options.draggable; this.dragging && ((t = this.dragging.enabled()), this.dragging.disable()), (this.dragging = new Ae(this)), t && this.dragging.enable(); } }, setOpacity: function (t) { return (this.options.opacity = t), this._map && this._updateOpacity(), this; }, _updateOpacity: function () { var t = this.options.opacity; this._icon && vi(this._icon, t), this._shadow && vi(this._shadow, t); }, _bringToFront: function () { this._updateZIndex(this.options.riseOffset); }, _resetZIndex: function () { this._updateZIndex(0); }, _getPopupAnchor: function () { return this.options.icon.options.popupAnchor; }, _getTooltipAnchor: function () { return this.options.icon.options.tooltipAnchor; }, }); var Oe = Se.extend({ options: { stroke: !0, color: "#3388ff", weight: 3, opacity: 1, lineCap: "round", lineJoin: "round", dashArray: null, dashOffset: null, fill: !1, fillColor: null, fillOpacity: 0.2, fillRule: "evenodd", interactive: !0, bubblingMouseEvents: !0, }, beforeAdd: function (t) { this._renderer = t.getRenderer(this); }, onAdd: function () { this._renderer._initPath(this), this._reset(), this._renderer._addPath(this); }, onRemove: function () { this._renderer._removePath(this); }, redraw: function () { return this._map && this._renderer._updatePath(this), this; }, setStyle: function (t) { return p(this, t), this._renderer && (this._renderer._updateStyle(this), this.options.stroke && t.hasOwnProperty("weight") && this._updateBounds()), this; }, bringToFront: function () { return this._renderer && this._renderer._bringToFront(this), this; }, bringToBack: function () { return this._renderer && this._renderer._bringToBack(this), this; }, getElement: function () { return this._path; }, _reset: function () { this._project(), this._update(); }, _clickTolerance: function () { return (this.options.stroke ? this.options.weight / 2 : 0) + this._renderer.options.tolerance; }, }), Re = Oe.extend({ options: { fill: !0, radius: 10 }, initialize: function (t, i) { p(this, i), (this._latlng = W(t)), (this._radius = this.options.radius); }, setLatLng: function (t) { return (this._latlng = W(t)), this.redraw(), this.fire("move", { latlng: this._latlng }); }, getLatLng: function () { return this._latlng; }, setRadius: function (t) { return (this.options.radius = this._radius = t), this.redraw(); }, getRadius: function () { return this._radius; }, setStyle: function (t) { var i = (t && t.radius) || this._radius; return Oe.prototype.setStyle.call(this, t), this.setRadius(i), this; }, _project: function () { (this._point = this._map.latLngToLayerPoint(this._latlng)), this._updateBounds(); }, _updateBounds: function () { var t = this._radius, i = this._radiusY || t, e = this._clickTolerance(), n = [t + e, i + e]; this._pxBounds = new O(this._point.subtract(n), this._point.add(n)); }, _update: function () { this._map && this._updatePath(); }, _updatePath: function () { this._renderer._updateCircle(this); }, _empty: function () { return this._radius && !this._renderer._bounds.intersects(this._pxBounds); }, _containsPoint: function (t) { return t.distanceTo(this._point) <= this._radius + this._clickTolerance(); }, }); var Ne = Re.extend({ initialize: function (t, i, e) { if (("number" == typeof i && (i = h({}, e, { radius: i })), p(this, i), (this._latlng = W(t)), isNaN(this.options.radius))) throw new Error("Circle radius cannot be NaN"); this._mRadius = this.options.radius; }, setRadius: function (t) { return (this._mRadius = t), this.redraw(); }, getRadius: function () { return this._mRadius; }, getBounds: function () { var t = [this._radius, this._radiusY || this._radius]; return new N(this._map.layerPointToLatLng(this._point.subtract(t)), this._map.layerPointToLatLng(this._point.add(t))); }, setStyle: Oe.prototype.setStyle, _project: function () { var t = this._latlng.lng, i = this._latlng.lat, e = this._map, n = e.options.crs; if (n.distance === U.distance) { var o = Math.PI / 180, s = this._mRadius / U.R / o, r = e.project([i + s, t]), a = e.project([i - s, t]), h = r.add(a).divideBy(2), u = e.unproject(h).lat, l = Math.acos((Math.cos(s * o) - Math.sin(i * o) * Math.sin(u * o)) / (Math.cos(i * o) * Math.cos(u * o))) / o; (!isNaN(l) && 0 !== l) || (l = s / Math.cos((Math.PI / 180) * i)), (this._point = h.subtract(e.getPixelOrigin())), (this._radius = isNaN(l) ? 0 : h.x - e.project([u, t - l]).x), (this._radiusY = h.y - r.y); } else { var c = n.unproject(n.project(this._latlng).subtract([this._mRadius, 0])); (this._point = e.latLngToLayerPoint(this._latlng)), (this._radius = this._point.x - e.latLngToLayerPoint(c).x); } this._updateBounds(); }, }); var De = Oe.extend({ options: { smoothFactor: 1, noClip: !1 }, initialize: function (t, i) { p(this, i), this._setLatLngs(t); }, getLatLngs: function () { return this._latlngs; }, setLatLngs: function (t) { return this._setLatLngs(t), this.redraw(); }, isEmpty: function () { return !this._latlngs.length; }, closestLayerPoint: function (t) { for (var i, e, n = 1 / 0, o = null, s = fe, r = 0, a = this._parts.length; r < a; r++) for (var h = this._parts[r], u = 1, l = h.length; u < l; u++) { var c = s(t, (i = h[u - 1]), (e = h[u]), !0); c < n && ((n = c), (o = s(t, i, e))); } return o && (o.distance = Math.sqrt(n)), o; }, getCenter: function () { if (!this._map) throw new Error("Must add layer to map before using getCenter()"); var t, i, e, n, o, s, r, a = this._rings[0], h = a.length; if (!h) return null; for (i = t = 0; t < h - 1; t++) i += a[t].distanceTo(a[t + 1]) / 2; if (0 === i) return this._map.layerPointToLatLng(a[0]); for (n = t = 0; t < h - 1; t++) if (((o = a[t]), (s = a[t + 1]), i < (n += e = o.distanceTo(s)))) return (r = (n - i) / e), this._map.layerPointToLatLng([s.x - r * (s.x - o.x), s.y - r * (s.y - o.y)]); }, getBounds: function () { return this._bounds; }, addLatLng: function (t, i) { return (i = i || this._defaultShape()), (t = W(t)), i.push(t), this._bounds.extend(t), this.redraw(); }, _setLatLngs: function (t) { (this._bounds = new N()), (this._latlngs = this._convertLatLngs(t)); }, _defaultShape: function () { return ge(this._latlngs) ? this._latlngs : this._latlngs[0]; }, _convertLatLngs: function (t) { for (var i = [], e = ge(t), n = 0, o = t.length; n < o; n++) e ? ((i[n] = W(t[n])), this._bounds.extend(i[n])) : (i[n] = this._convertLatLngs(t[n])); return i; }, _project: function () { var t = new O(); (this._rings = []), this._projectLatlngs(this._latlngs, this._rings, t), this._bounds.isValid() && t.isValid() && ((this._rawPxBounds = t), this._updateBounds()); }, _updateBounds: function () { var t = this._clickTolerance(), i = new B(t, t); this._pxBounds = new O([this._rawPxBounds.min.subtract(i), this._rawPxBounds.max.add(i)]); }, _projectLatlngs: function (t, i, e) { var n, o, s = t[0] instanceof j, r = t.length; if (s) { for (o = [], n = 0; n < r; n++) (o[n] = this._map.latLngToLayerPoint(t[n])), e.extend(o[n]); i.push(o); } else for (n = 0; n < r; n++) this._projectLatlngs(t[n], i, e); }, _clipPoints: function () { var t = this._renderer._bounds; if (((this._parts = []), this._pxBounds && this._pxBounds.intersects(t))) if (this.options.noClip) this._parts = this._rings; else { var i, e, n, o, s, r, a, h = this._parts; for (n = i = 0, o = this._rings.length; i < o; i++) for (e = 0, s = (a = this._rings[i]).length; e < s - 1; e++) (r = de(a[e], a[e + 1], t, e, !0)) && ((h[n] = h[n] || []), h[n].push(r[0]), (r[1] === a[e + 1] && e !== s - 2) || (h[n].push(r[1]), n++)); } }, _simplifyPoints: function () { for (var t = this._parts, i = this.options.smoothFactor, e = 0, n = t.length; e < n; e++) t[e] = ce(t[e], i); }, _update: function () { this._map && (this._clipPoints(), this._simplifyPoints(), this._updatePath()); }, _updatePath: function () { this._renderer._updatePoly(this); }, _containsPoint: function (t, i) { var e, n, o, s, r, a, h = this._clickTolerance(); if (!this._pxBounds || !this._pxBounds.contains(t)) return !1; for (e = 0, s = this._parts.length; e < s; e++) for (n = 0, o = (r = (a = this._parts[e]).length) - 1; n < r; o = n++) if ((i || 0 !== n) && _e(t, a[o], a[n]) <= h) return !0; return !1; }, }); De._flat = ve; var je = De.extend({ options: { fill: !0 }, isEmpty: function () { return !this._latlngs.length || !this._latlngs[0].length; }, getCenter: function () { if (!this._map) throw new Error("Must add layer to map before using getCenter()"); var t, i, e, n, o, s, r, a, h, u = this._rings[0], l = u.length; if (!l) return null; for (s = r = a = 0, t = 0, i = l - 1; t < l; i = t++) (e = u[t]), (n = u[i]), (o = e.y * n.x - n.y * e.x), (r += (e.x + n.x) * o), (a += (e.y + n.y) * o), (s += 3 * o); return (h = 0 === s ? u[0] : [r / s, a / s]), this._map.layerPointToLatLng(h); }, _convertLatLngs: function (t) { var i = De.prototype._convertLatLngs.call(this, t), e = i.length; return 2 <= e && i[0] instanceof j && i[0].equals(i[e - 1]) && i.pop(), i; }, _setLatLngs: function (t) { De.prototype._setLatLngs.call(this, t), ge(this._latlngs) && (this._latlngs = [this._latlngs]); }, _defaultShape: function () { return ge(this._latlngs[0]) ? this._latlngs[0] : this._latlngs[0][0]; }, _clipPoints: function () { var t = this._renderer._bounds, i = this.options.weight, e = new B(i, i); if (((t = new O(t.min.subtract(e), t.max.add(e))), (this._parts = []), this._pxBounds && this._pxBounds.intersects(t))) if (this.options.noClip) this._parts = this._rings; else for (var n, o = 0, s = this._rings.length; o < s; o++) (n = xe(this._rings[o], t, !0)).length && this._parts.push(n); }, _updatePath: function () { this._renderer._updatePoly(this, !0); }, _containsPoint: function (t) { var i, e, n, o, s, r, a, h, u = !1; if (!this._pxBounds || !this._pxBounds.contains(t)) return !1; for (o = 0, a = this._parts.length; o < a; o++) for (s = 0, r = (h = (i = this._parts[o]).length) - 1; s < h; r = s++) (e = i[s]), (n = i[r]), e.y > t.y != n.y > t.y && t.x < ((n.x - e.x) * (t.y - e.y)) / (n.y - e.y) + e.x && (u = !u); return u || De.prototype._containsPoint.call(this, t, !0); }, }); var We = Ee.extend({ initialize: function (t, i) { p(this, i), (this._layers = {}), t && this.addData(t); }, addData: function (t) { var i, e, n, o = v(t) ? t : t.features; if (o) { for (i = 0, e = o.length; i < e; i++) ((n = o[i]).geometries || n.geometry || n.features || n.coordinates) && this.addData(n); return this; } var s = this.options; if (s.filter && !s.filter(t)) return this; var r = He(t, s); return r ? ((r.feature = Ke(t)), (r.defaultOptions = r.options), this.resetStyle(r), s.onEachFeature && s.onEachFeature(t, r), this.addLayer(r)) : this; }, resetStyle: function (t) { return (t.options = h({}, t.defaultOptions)), this._setLayerStyle(t, this.options.style), this; }, setStyle: function (i) { return this.eachLayer(function (t) { this._setLayerStyle(t, i); }, this); }, _setLayerStyle: function (t, i) { t.setStyle && ("function" == typeof i && (i = i(t.feature)), t.setStyle(i)); }, }); function He(t, i) { var e, n, o, s, r = "Feature" === t.type ? t.geometry : t, a = r ? r.coordinates : null, h = [], u = i && i.pointToLayer, l = (i && i.coordsToLatLng) || Fe; if (!a && !r) return null; switch (r.type) { case "Point": return (e = l(a)), u ? u(t, e) : new Ie(e); case "MultiPoint": for (o = 0, s = a.length; o < s; o++) (e = l(a[o])), h.push(u ? u(t, e) : new Ie(e)); return new Ee(h); case "LineString": case "MultiLineString": return (n = Ue(a, "LineString" === r.type ? 0 : 1, l)), new De(n, i); case "Polygon": case "MultiPolygon": return (n = Ue(a, "Polygon" === r.type ? 1 : 2, l)), new je(n, i); case "GeometryCollection": for (o = 0, s = r.geometries.length; o < s; o++) { var c = He({ geometry: r.geometries[o], type: "Feature", properties: t.properties }, i); c && h.push(c); } return new Ee(h); default: throw new Error("Invalid GeoJSON object."); } } function Fe(t) { return new j(t[1], t[0], t[2]); } function Ue(t, i, e) { for (var n, o = [], s = 0, r = t.length; s < r; s++) (n = i ? Ue(t[s], i - 1, e) : (e || Fe)(t[s])), o.push(n); return o; } function Ve(t, i) { return (i = "number" == typeof i ? i : 6), void 0 !== t.alt ? [c(t.lng, i), c(t.lat, i), c(t.alt, i)] : [c(t.lng, i), c(t.lat, i)]; } function qe(t, i, e, n) { for (var o = [], s = 0, r = t.length; s < r; s++) o.push(i ? qe(t[s], i - 1, e, n) : Ve(t[s], n)); return !i && e && o.push(o[0]), o; } function Ge(t, i) { return t.feature ? h({}, t.feature, { geometry: i }) : Ke(i); } function Ke(t) { return "Feature" === t.type || "FeatureCollection" === t.type ? t : { type: "Feature", properties: {}, geometry: t }; } var Ye = { toGeoJSON: function (t) { return Ge(this, { type: "Point", coordinates: Ve(this.getLatLng(), t) }); }, }; function Xe(t, i) { return new We(t, i); } Ie.include(Ye), Ne.include(Ye), Re.include(Ye), De.include({ toGeoJSON: function (t) { var i = !ge(this._latlngs); return Ge(this, { type: (i ? "Multi" : "") + "LineString", coordinates: qe(this._latlngs, i ? 1 : 0, !1, t) }); }, }), je.include({ toGeoJSON: function (t) { var i = !ge(this._latlngs), e = i && !ge(this._latlngs[0]), n = qe(this._latlngs, e ? 2 : i ? 1 : 0, !0, t); return i || (n = [n]), Ge(this, { type: (e ? "Multi" : "") + "Polygon", coordinates: n }); }, }), Ze.include({ toMultiPoint: function (i) { var e = []; return ( this.eachLayer(function (t) { e.push(t.toGeoJSON(i).geometry.coordinates); }), Ge(this, { type: "MultiPoint", coordinates: e }) ); }, toGeoJSON: function (n) { var t = this.feature && this.feature.geometry && this.feature.geometry.type; if ("MultiPoint" === t) return this.toMultiPoint(n); var o = "GeometryCollection" === t, s = []; return ( this.eachLayer(function (t) { if (t.toGeoJSON) { var i = t.toGeoJSON(n); if (o) s.push(i.geometry); else { var e = Ke(i); "FeatureCollection" === e.type ? s.push.apply(s, e.features) : s.push(e); } } }), o ? Ge(this, { geometries: s, type: "GeometryCollection" }) : { type: "FeatureCollection", features: s } ); }, }); var Je = Xe, $e = Se.extend({ options: { opacity: 1, alt: "", interactive: !1, crossOrigin: !1, errorOverlayUrl: "", zIndex: 1, className: "" }, initialize: function (t, i, e) { (this._url = t), (this._bounds = D(i)), p(this, e); }, onAdd: function () { this._image || (this._initImage(), this.options.opacity < 1 && this._updateOpacity()), this.options.interactive && (pi(this._image, "leaflet-interactive"), this.addInteractiveTarget(this._image)), this.getPane().appendChild(this._image), this._reset(); }, onRemove: function () { ui(this._image), this.options.interactive && this.removeInteractiveTarget(this._image); }, setOpacity: function (t) { return (this.options.opacity = t), this._image && this._updateOpacity(), this; }, setStyle: function (t) { return t.opacity && this.setOpacity(t.opacity), this; }, bringToFront: function () { return this._map && ci(this._image), this; }, bringToBack: function () { return this._map && _i(this._image), this; }, setUrl: function (t) { return (this._url = t), this._image && (this._image.src = t), this; }, setBounds: function (t) { return (this._bounds = D(t)), this._map && this._reset(), this; }, getEvents: function () { var t = { zoom: this._reset, viewreset: this._reset }; return this._zoomAnimated && (t.zoomanim = this._animateZoom), t; }, setZIndex: function (t) { return (this.options.zIndex = t), this._updateZIndex(), this; }, getBounds: function () { return this._bounds; }, getElement: function () { return this._image; }, _initImage: function () { var t = "IMG" === this._url.tagName, i = (this._image = t ? this._url : hi("img")); pi(i, "leaflet-image-layer"), this._zoomAnimated && pi(i, "leaflet-zoom-animated"), this.options.className && pi(i, this.options.className), (i.onselectstart = l), (i.onmousemove = l), (i.onload = a(this.fire, this, "load")), (i.onerror = a(this._overlayOnError, this, "error")), (!this.options.crossOrigin && "" !== this.options.crossOrigin) || (i.crossOrigin = !0 === this.options.crossOrigin ? "" : this.options.crossOrigin), this.options.zIndex && this._updateZIndex(), t ? (this._url = i.src) : ((i.src = this._url), (i.alt = this.options.alt)); }, _animateZoom: function (t) { var i = this._map.getZoomScale(t.zoom), e = this._map._latLngBoundsToNewLayerBounds(this._bounds, t.zoom, t.center).min; xi(this._image, e, i); }, _reset: function () { var t = this._image, i = new O(this._map.latLngToLayerPoint(this._bounds.getNorthWest()), this._map.latLngToLayerPoint(this._bounds.getSouthEast())), e = i.getSize(); wi(t, i.min), (t.style.width = e.x + "px"), (t.style.height = e.y + "px"); }, _updateOpacity: function () { vi(this._image, this.options.opacity); }, _updateZIndex: function () { this._image && void 0 !== this.options.zIndex && null !== this.options.zIndex && (this._image.style.zIndex = this.options.zIndex); }, _overlayOnError: function () { this.fire("error"); var t = this.options.errorOverlayUrl; t && this._url !== t && ((this._url = t), (this._image.src = t)); }, }), Qe = $e.extend({ options: { autoplay: !0, loop: !0, keepAspectRatio: !0 }, _initImage: function () { var t = "VIDEO" === this._url.tagName, i = (this._image = t ? this._url : hi("video")); if ((pi(i, "leaflet-image-layer"), this._zoomAnimated && pi(i, "leaflet-zoom-animated"), (i.onselectstart = l), (i.onmousemove = l), (i.onloadeddata = a(this.fire, this, "load")), t)) { for (var e = i.getElementsByTagName("source"), n = [], o = 0; o < e.length; o++) n.push(e[o].src); this._url = 0 < e.length ? n : [i.src]; } else { v(this._url) || (this._url = [this._url]), !this.options.keepAspectRatio && i.style.hasOwnProperty("objectFit") && (i.style.objectFit = "fill"), (i.autoplay = !!this.options.autoplay), (i.loop = !!this.options.loop); for (var s = 0; s < this._url.length; s++) { var r = hi("source"); (r.src = this._url[s]), i.appendChild(r); } } }, }); var tn = $e.extend({ _initImage: function () { var t = (this._image = this._url); pi(t, "leaflet-image-layer"), this._zoomAnimated && pi(t, "leaflet-zoom-animated"), (t.onselectstart = l), (t.onmousemove = l); }, }); var en = Se.extend({ options: { offset: [0, 7], className: "", pane: "popupPane" }, initialize: function (t, i) { p(this, t), (this._source = i); }, onAdd: function (t) { (this._zoomAnimated = t._zoomAnimated), this._container || this._initLayout(), t._fadeAnimated && vi(this._container, 0), clearTimeout(this._removeTimeout), this.getPane().appendChild(this._container), this.update(), t._fadeAnimated && vi(this._container, 1), this.bringToFront(); }, onRemove: function (t) { t._fadeAnimated ? (vi(this._container, 0), (this._removeTimeout = setTimeout(a(ui, void 0, this._container), 200))) : ui(this._container); }, getLatLng: function () { return this._latlng; }, setLatLng: function (t) { return (this._latlng = W(t)), this._map && (this._updatePosition(), this._adjustPan()), this; }, getContent: function () { return this._content; }, setContent: function (t) { return (this._content = t), this.update(), this; }, getElement: function () { return this._container; }, update: function () { this._map && ((this._container.style.visibility = "hidden"), this._updateContent(), this._updateLayout(), this._updatePosition(), (this._container.style.visibility = ""), this._adjustPan()); }, getEvents: function () { var t = { zoom: this._updatePosition, viewreset: this._updatePosition }; return this._zoomAnimated && (t.zoomanim = this._animateZoom), t; }, isOpen: function () { return !!this._map && this._map.hasLayer(this); }, bringToFront: function () { return this._map && ci(this._container), this; }, bringToBack: function () { return this._map && _i(this._container), this; }, _prepareOpen: function (t, i, e) { if ((i instanceof Se || ((e = i), (i = t)), i instanceof Ee)) for (var n in t._layers) { i = t._layers[n]; break; } if (!e) if (i.getCenter) e = i.getCenter(); else { if (!i.getLatLng) throw new Error("Unable to get source layer LatLng."); e = i.getLatLng(); } return (this._source = i), this.update(), e; }, _updateContent: function () { if (this._content) { var t = this._contentNode, i = "function" == typeof this._content ? this._content(this._source || this) : this._content; if ("string" == typeof i) t.innerHTML = i; else { for (; t.hasChildNodes(); ) t.removeChild(t.firstChild); t.appendChild(i); } this.fire("contentupdate"); } }, _updatePosition: function () { if (this._map) { var t = this._map.latLngToLayerPoint(this._latlng), i = I(this.options.offset), e = this._getAnchor(); this._zoomAnimated ? wi(this._container, t.add(e)) : (i = i.add(t).add(e)); var n = (this._containerBottom = -i.y), o = (this._containerLeft = -Math.round(this._containerWidth / 2) + i.x); (this._container.style.bottom = n + "px"), (this._container.style.left = o + "px"); } }, _getAnchor: function () { return [0, 0]; }, }), nn = en.extend({ options: { maxWidth: 300, minWidth: 50, maxHeight: null, autoPan: !0, autoPanPaddingTopLeft: null, autoPanPaddingBottomRight: null, autoPanPadding: [5, 5], keepInView: !1, closeButton: !0, autoClose: !0, closeOnEscapeKey: !0, className: "", }, openOn: function (t) { return t.openPopup(this), this; }, onAdd: function (t) { en.prototype.onAdd.call(this, t), t.fire("popupopen", { popup: this }), this._source && (this._source.fire("popupopen", { popup: this }, !0), this._source instanceof Oe || this._source.on("preclick", Oi)); }, onRemove: function (t) { en.prototype.onRemove.call(this, t), t.fire("popupclose", { popup: this }), this._source && (this._source.fire("popupclose", { popup: this }, !0), this._source instanceof Oe || this._source.off("preclick", Oi)); }, getEvents: function () { var t = en.prototype.getEvents.call(this); return (void 0 !== this.options.closeOnClick ? this.options.closeOnClick : this._map.options.closePopupOnClick) && (t.preclick = this._close), this.options.keepInView && (t.moveend = this._adjustPan), t; }, _close: function () { this._map && this._map.closePopup(this); }, _initLayout: function () { var t = "leaflet-popup", i = (this._container = hi("div", t + " " + (this.options.className || "") + " leaflet-zoom-animated")), e = (this._wrapper = hi("div", t + "-content-wrapper", i)); if ( ((this._contentNode = hi("div", t + "-content", e)), Ni(e), Ri(this._contentNode), Ei(e, "contextmenu", Oi), (this._tipContainer = hi("div", t + "-tip-container", i)), (this._tip = hi("div", t + "-tip", this._tipContainer)), this.options.closeButton) ) { var n = (this._closeButton = hi("a", t + "-close-button", i)); (n.href = "#close"), (n.innerHTML = "×"), Ei(n, "click", this._onCloseButtonClick, this); } }, _updateLayout: function () { var t = this._contentNode, i = t.style; (i.width = ""), (i.whiteSpace = "nowrap"); var e = t.offsetWidth; (e = Math.min(e, this.options.maxWidth)), (e = Math.max(e, this.options.minWidth)), (i.width = e + 1 + "px"), (i.whiteSpace = ""), (i.height = ""); var n = t.offsetHeight, o = this.options.maxHeight, s = "leaflet-popup-scrolled"; o && o < n ? ((i.height = o + "px"), pi(t, s)) : mi(t, s), (this._containerWidth = this._container.offsetWidth); }, _animateZoom: function (t) { var i = this._map._latLngToNewLayerPoint(this._latlng, t.zoom, t.center), e = this._getAnchor(); wi(this._container, i.add(e)); }, _adjustPan: function () { if (this.options.autoPan) { this._map._panAnim && this._map._panAnim.stop(); var t = this._map, i = parseInt(ai(this._container, "marginBottom"), 10) || 0, e = this._container.offsetHeight + i, n = this._containerWidth, o = new B(this._containerLeft, -e - this._containerBottom); o._add(Pi(this._container)); var s = t.layerPointToContainerPoint(o), r = I(this.options.autoPanPadding), a = I(this.options.autoPanPaddingTopLeft || r), h = I(this.options.autoPanPaddingBottomRight || r), u = t.getSize(), l = 0, c = 0; s.x + n + h.x > u.x && (l = s.x + n - u.x + h.x), s.x - l - a.x < 0 && (l = s.x - a.x), s.y + e + h.y > u.y && (c = s.y + e - u.y + h.y), s.y - c - a.y < 0 && (c = s.y - a.y), (l || c) && t.fire("autopanstart").panBy([l, c]); } }, _onCloseButtonClick: function (t) { this._close(), ji(t); }, _getAnchor: function () { return I(this._source && this._source._getPopupAnchor ? this._source._getPopupAnchor() : [0, 0]); }, }); Ji.mergeOptions({ closePopupOnClick: !0 }), Ji.include({ openPopup: function (t, i, e) { return t instanceof nn || (t = new nn(e).setContent(t)), i && t.setLatLng(i), this.hasLayer(t) ? this : (this._popup && this._popup.options.autoClose && this.closePopup(), (this._popup = t), this.addLayer(t)); }, closePopup: function (t) { return (t && t !== this._popup) || ((t = this._popup), (this._popup = null)), t && this.removeLayer(t), this; }, }), Se.include({ bindPopup: function (t, i) { return ( t instanceof nn ? (p(t, i), ((this._popup = t)._source = this)) : ((this._popup && !i) || (this._popup = new nn(i, this)), this._popup.setContent(t)), this._popupHandlersAdded || (this.on({ click: this._openPopup, keypress: this._onKeyPress, remove: this.closePopup, move: this._movePopup }), (this._popupHandlersAdded = !0)), this ); }, unbindPopup: function () { return this._popup && (this.off({ click: this._openPopup, keypress: this._onKeyPress, remove: this.closePopup, move: this._movePopup }), (this._popupHandlersAdded = !1), (this._popup = null)), this; }, openPopup: function (t, i) { return this._popup && this._map && ((i = this._popup._prepareOpen(this, t, i)), this._map.openPopup(this._popup, i)), this; }, closePopup: function () { return this._popup && this._popup._close(), this; }, togglePopup: function (t) { return this._popup && (this._popup._map ? this.closePopup() : this.openPopup(t)), this; }, isPopupOpen: function () { return !!this._popup && this._popup.isOpen(); }, setPopupContent: function (t) { return this._popup && this._popup.setContent(t), this; }, getPopup: function () { return this._popup; }, _openPopup: function (t) { var i = t.layer || t.target; this._popup && this._map && (ji(t), i instanceof Oe ? this.openPopup(t.layer || t.target, t.latlng) : this._map.hasLayer(this._popup) && this._popup._source === i ? this.closePopup() : this.openPopup(i, t.latlng)); }, _movePopup: function (t) { this._popup.setLatLng(t.latlng); }, _onKeyPress: function (t) { 13 === t.originalEvent.keyCode && this._openPopup(t); }, }); var on = en.extend({ options: { pane: "tooltipPane", offset: [0, 0], direction: "auto", permanent: !1, sticky: !1, interactive: !1, opacity: 0.9 }, onAdd: function (t) { en.prototype.onAdd.call(this, t), this.setOpacity(this.options.opacity), t.fire("tooltipopen", { tooltip: this }), this._source && this._source.fire("tooltipopen", { tooltip: this }, !0); }, onRemove: function (t) { en.prototype.onRemove.call(this, t), t.fire("tooltipclose", { tooltip: this }), this._source && this._source.fire("tooltipclose", { tooltip: this }, !0); }, getEvents: function () { var t = en.prototype.getEvents.call(this); return Tt && !this.options.permanent && (t.preclick = this._close), t; }, _close: function () { this._map && this._map.closeTooltip(this); }, _initLayout: function () { var t = "leaflet-tooltip " + (this.options.className || "") + " leaflet-zoom-" + (this._zoomAnimated ? "animated" : "hide"); this._contentNode = this._container = hi("div", t); }, _updateLayout: function () {}, _adjustPan: function () {}, _setPosition: function (t) { var i = this._map, e = this._container, n = i.latLngToContainerPoint(i.getCenter()), o = i.layerPointToContainerPoint(t), s = this.options.direction, r = e.offsetWidth, a = e.offsetHeight, h = I(this.options.offset), u = this._getAnchor(); (t = "top" === s ? t.add(I(-r / 2 + h.x, -a + h.y + u.y, !0)) : "bottom" === s ? t.subtract(I(r / 2 - h.x, -h.y, !0)) : "center" === s ? t.subtract(I(r / 2 + h.x, a / 2 - u.y + h.y, !0)) : "right" === s || ("auto" === s && o.x < n.x) ? ((s = "right"), t.add(I(h.x + u.x, u.y - a / 2 + h.y, !0))) : ((s = "left"), t.subtract(I(r + u.x - h.x, a / 2 - u.y - h.y, !0)))), mi(e, "leaflet-tooltip-right"), mi(e, "leaflet-tooltip-left"), mi(e, "leaflet-tooltip-top"), mi(e, "leaflet-tooltip-bottom"), pi(e, "leaflet-tooltip-" + s), wi(e, t); }, _updatePosition: function () { var t = this._map.latLngToLayerPoint(this._latlng); this._setPosition(t); }, setOpacity: function (t) { (this.options.opacity = t), this._container && vi(this._container, t); }, _animateZoom: function (t) { var i = this._map._latLngToNewLayerPoint(this._latlng, t.zoom, t.center); this._setPosition(i); }, _getAnchor: function () { return I(this._source && this._source._getTooltipAnchor && !this.options.sticky ? this._source._getTooltipAnchor() : [0, 0]); }, }); Ji.include({ openTooltip: function (t, i, e) { return t instanceof on || (t = new on(e).setContent(t)), i && t.setLatLng(i), this.hasLayer(t) ? this : this.addLayer(t); }, closeTooltip: function (t) { return t && this.removeLayer(t), this; }, }), Se.include({ bindTooltip: function (t, i) { return ( t instanceof on ? (p(t, i), ((this._tooltip = t)._source = this)) : ((this._tooltip && !i) || (this._tooltip = new on(i, this)), this._tooltip.setContent(t)), this._initTooltipInteractions(), this._tooltip.options.permanent && this._map && this._map.hasLayer(this) && this.openTooltip(), this ); }, unbindTooltip: function () { return this._tooltip && (this._initTooltipInteractions(!0), this.closeTooltip(), (this._tooltip = null)), this; }, _initTooltipInteractions: function (t) { if (t || !this._tooltipHandlersAdded) { var i = t ? "off" : "on", e = { remove: this.closeTooltip, move: this._moveTooltip }; this._tooltip.options.permanent ? (e.add = this._openTooltip) : ((e.mouseover = this._openTooltip), (e.mouseout = this.closeTooltip), this._tooltip.options.sticky && (e.mousemove = this._moveTooltip), Tt && (e.click = this._openTooltip)), this[i](e), (this._tooltipHandlersAdded = !t); } }, openTooltip: function (t, i) { return ( this._tooltip && this._map && ((i = this._tooltip._prepareOpen(this, t, i)), this._map.openTooltip(this._tooltip, i), this._tooltip.options.interactive && this._tooltip._container && (pi(this._tooltip._container, "leaflet-clickable"), this.addInteractiveTarget(this._tooltip._container))), this ); }, closeTooltip: function () { return ( this._tooltip && (this._tooltip._close(), this._tooltip.options.interactive && this._tooltip._container && (mi(this._tooltip._container, "leaflet-clickable"), this.removeInteractiveTarget(this._tooltip._container))), this ); }, toggleTooltip: function (t) { return this._tooltip && (this._tooltip._map ? this.closeTooltip() : this.openTooltip(t)), this; }, isTooltipOpen: function () { return this._tooltip.isOpen(); }, setTooltipContent: function (t) { return this._tooltip && this._tooltip.setContent(t), this; }, getTooltip: function () { return this._tooltip; }, _openTooltip: function (t) { var i = t.layer || t.target; this._tooltip && this._map && this.openTooltip(i, this._tooltip.options.sticky ? t.latlng : void 0); }, _moveTooltip: function (t) { var i, e, n = t.latlng; this._tooltip.options.sticky && t.originalEvent && ((i = this._map.mouseEventToContainerPoint(t.originalEvent)), (e = this._map.containerPointToLayerPoint(i)), (n = this._map.layerPointToLatLng(e))), this._tooltip.setLatLng(n); }, }); var sn = ke.extend({ options: { iconSize: [12, 12], html: !1, bgPos: null, className: "leaflet-div-icon" }, createIcon: function (t) { var i = t && "DIV" === t.tagName ? t : document.createElement("div"), e = this.options; if ((e.html instanceof Element ? (li(i), i.appendChild(e.html)) : (i.innerHTML = !1 !== e.html ? e.html : ""), e.bgPos)) { var n = I(e.bgPos); i.style.backgroundPosition = -n.x + "px " + -n.y + "px"; } return this._setIconStyles(i, "icon"), i; }, createShadow: function () { return null; }, }); ke.Default = Be; var rn = Se.extend({ options: { tileSize: 256, opacity: 1, updateWhenIdle: xt, updateWhenZooming: !0, updateInterval: 200, zIndex: 1, bounds: null, minZoom: 0, maxZoom: void 0, maxNativeZoom: void 0, minNativeZoom: void 0, noWrap: !1, pane: "tilePane", className: "", keepBuffer: 2, }, initialize: function (t) { p(this, t); }, onAdd: function () { this._initContainer(), (this._levels = {}), (this._tiles = {}), this._resetView(), this._update(); }, beforeAdd: function (t) { t._addZoomLimit(this); }, onRemove: function (t) { this._removeAllTiles(), ui(this._container), t._removeZoomLimit(this), (this._container = null), (this._tileZoom = void 0); }, bringToFront: function () { return this._map && (ci(this._container), this._setAutoZIndex(Math.max)), this; }, bringToBack: function () { return this._map && (_i(this._container), this._setAutoZIndex(Math.min)), this; }, getContainer: function () { return this._container; }, setOpacity: function (t) { return (this.options.opacity = t), this._updateOpacity(), this; }, setZIndex: function (t) { return (this.options.zIndex = t), this._updateZIndex(), this; }, isLoading: function () { return this._loading; }, redraw: function () { return this._map && (this._removeAllTiles(), this._update()), this; }, getEvents: function () { var t = { viewprereset: this._invalidateAll, viewreset: this._resetView, zoom: this._resetView, moveend: this._onMoveEnd }; return this.options.updateWhenIdle || (this._onMove || (this._onMove = o(this._onMoveEnd, this.options.updateInterval, this)), (t.move = this._onMove)), this._zoomAnimated && (t.zoomanim = this._animateZoom), t; }, createTile: function () { return document.createElement("div"); }, getTileSize: function () { var t = this.options.tileSize; return t instanceof B ? t : new B(t, t); }, _updateZIndex: function () { this._container && void 0 !== this.options.zIndex && null !== this.options.zIndex && (this._container.style.zIndex = this.options.zIndex); }, _setAutoZIndex: function (t) { for (var i, e = this.getPane().children, n = -t(-1 / 0, 1 / 0), o = 0, s = e.length; o < s; o++) (i = e[o].style.zIndex), e[o] !== this._container && i && (n = t(n, +i)); isFinite(n) && ((this.options.zIndex = n + t(-1, 1)), this._updateZIndex()); }, _updateOpacity: function () { if (this._map && !et) { vi(this._container, this.options.opacity); var t = +new Date(), i = !1, e = !1; for (var n in this._tiles) { var o = this._tiles[n]; if (o.current && o.loaded) { var s = Math.min(1, (t - o.loaded) / 200); vi(o.el, s), s < 1 ? (i = !0) : (o.active ? (e = !0) : this._onOpaqueTile(o), (o.active = !0)); } } e && !this._noPrune && this._pruneTiles(), i && (C(this._fadeFrame), (this._fadeFrame = M(this._updateOpacity, this))); } }, _onOpaqueTile: l, _initContainer: function () { this._container || ((this._container = hi("div", "leaflet-layer " + (this.options.className || ""))), this._updateZIndex(), this.options.opacity < 1 && this._updateOpacity(), this.getPane().appendChild(this._container)); }, _updateLevels: function () { var t = this._tileZoom, i = this.options.maxZoom; if (void 0 !== t) { for (var e in this._levels) this._levels[e].el.children.length || e === t ? ((this._levels[e].el.style.zIndex = i - Math.abs(t - e)), this._onUpdateLevel(e)) : (ui(this._levels[e].el), this._removeTilesAtZoom(e), this._onRemoveLevel(e), delete this._levels[e]); var n = this._levels[t], o = this._map; return ( n || (((n = this._levels[t] = {}).el = hi("div", "leaflet-tile-container leaflet-zoom-animated", this._container)), (n.el.style.zIndex = i), (n.origin = o.project(o.unproject(o.getPixelOrigin()), t).round()), (n.zoom = t), this._setZoomTransform(n, o.getCenter(), o.getZoom()), n.el.offsetWidth, this._onCreateLevel(n)), (this._level = n) ); } }, _onUpdateLevel: l, _onRemoveLevel: l, _onCreateLevel: l, _pruneTiles: function () { if (this._map) { var t, i, e = this._map.getZoom(); if (e > this.options.maxZoom || e < this.options.minZoom) this._removeAllTiles(); else { for (t in this._tiles) (i = this._tiles[t]).retain = i.current; for (t in this._tiles) if ((i = this._tiles[t]).current && !i.active) { var n = i.coords; this._retainParent(n.x, n.y, n.z, n.z - 5) || this._retainChildren(n.x, n.y, n.z, n.z + 2); } for (t in this._tiles) this._tiles[t].retain || this._removeTile(t); } } }, _removeTilesAtZoom: function (t) { for (var i in this._tiles) this._tiles[i].coords.z === t && this._removeTile(i); }, _removeAllTiles: function () { for (var t in this._tiles) this._removeTile(t); }, _invalidateAll: function () { for (var t in this._levels) ui(this._levels[t].el), this._onRemoveLevel(t), delete this._levels[t]; this._removeAllTiles(), (this._tileZoom = void 0); }, _retainParent: function (t, i, e, n) { var o = Math.floor(t / 2), s = Math.floor(i / 2), r = e - 1, a = new B(+o, +s); a.z = +r; var h = this._tileCoordsToKey(a), u = this._tiles[h]; return u && u.active ? (u.retain = !0) : (u && u.loaded && (u.retain = !0), n < r && this._retainParent(o, s, r, n)); }, _retainChildren: function (t, i, e, n) { for (var o = 2 * t; o < 2 * t + 2; o++) for (var s = 2 * i; s < 2 * i + 2; s++) { var r = new B(o, s); r.z = e + 1; var a = this._tileCoordsToKey(r), h = this._tiles[a]; h && h.active ? (h.retain = !0) : (h && h.loaded && (h.retain = !0), e + 1 < n && this._retainChildren(o, s, e + 1, n)); } }, _resetView: function (t) { var i = t && (t.pinch || t.flyTo); this._setView(this._map.getCenter(), this._map.getZoom(), i, i); }, _animateZoom: function (t) { this._setView(t.center, t.zoom, !0, t.noUpdate); }, _clampZoom: function (t) { var i = this.options; return void 0 !== i.minNativeZoom && t < i.minNativeZoom ? i.minNativeZoom : void 0 !== i.maxNativeZoom && i.maxNativeZoom < t ? i.maxNativeZoom : t; }, _setView: function (t, i, e, n) { var o = this._clampZoom(Math.round(i)); ((void 0 !== this.options.maxZoom && o > this.options.maxZoom) || (void 0 !== this.options.minZoom && o < this.options.minZoom)) && (o = void 0); var s = this.options.updateWhenZooming && o !== this._tileZoom; (n && !s) || ((this._tileZoom = o), this._abortLoading && this._abortLoading(), this._updateLevels(), this._resetGrid(), void 0 !== o && this._update(t), e || this._pruneTiles(), (this._noPrune = !!e)), this._setZoomTransforms(t, i); }, _setZoomTransforms: function (t, i) { for (var e in this._levels) this._setZoomTransform(this._levels[e], t, i); }, _setZoomTransform: function (t, i, e) { var n = this._map.getZoomScale(e, t.zoom), o = t.origin.multiplyBy(n).subtract(this._map._getNewPixelOrigin(i, e)).round(); yt ? xi(t.el, o, n) : wi(t.el, o); }, _resetGrid: function () { var t = this._map, i = t.options.crs, e = (this._tileSize = this.getTileSize()), n = this._tileZoom, o = this._map.getPixelWorldBounds(this._tileZoom); o && (this._globalTileRange = this._pxBoundsToTileRange(o)), (this._wrapX = i.wrapLng && !this.options.noWrap && [Math.floor(t.project([0, i.wrapLng[0]], n).x / e.x), Math.ceil(t.project([0, i.wrapLng[1]], n).x / e.y)]), (this._wrapY = i.wrapLat && !this.options.noWrap && [Math.floor(t.project([i.wrapLat[0], 0], n).y / e.x), Math.ceil(t.project([i.wrapLat[1], 0], n).y / e.y)]); }, _onMoveEnd: function () { this._map && !this._map._animatingZoom && this._update(); }, _getTiledPixelBounds: function (t) { var i = this._map, e = i._animatingZoom ? Math.max(i._animateToZoom, i.getZoom()) : i.getZoom(), n = i.getZoomScale(e, this._tileZoom), o = i.project(t, this._tileZoom).floor(), s = i.getSize().divideBy(2 * n); return new O(o.subtract(s), o.add(s)); }, _update: function (t) { var i = this._map; if (i) { var e = this._clampZoom(i.getZoom()); if ((void 0 === t && (t = i.getCenter()), void 0 !== this._tileZoom)) { var n = this._getTiledPixelBounds(t), o = this._pxBoundsToTileRange(n), s = o.getCenter(), r = [], a = this.options.keepBuffer, h = new O(o.getBottomLeft().subtract([a, -a]), o.getTopRight().add([a, -a])); if (!(isFinite(o.min.x) && isFinite(o.min.y) && isFinite(o.max.x) && isFinite(o.max.y))) throw new Error("Attempted to load an infinite number of tiles"); for (var u in this._tiles) { var l = this._tiles[u].coords; (l.z === this._tileZoom && h.contains(new B(l.x, l.y))) || (this._tiles[u].current = !1); } if (1 < Math.abs(e - this._tileZoom)) this._setView(t, e); else { for (var c = o.min.y; c <= o.max.y; c++) for (var _ = o.min.x; _ <= o.max.x; _++) { var d = new B(_, c); if (((d.z = this._tileZoom), this._isValidTile(d))) { var p = this._tiles[this._tileCoordsToKey(d)]; p ? (p.current = !0) : r.push(d); } } if ( (r.sort(function (t, i) { return t.distanceTo(s) - i.distanceTo(s); }), 0 !== r.length) ) { this._loading || ((this._loading = !0), this.fire("loading")); var m = document.createDocumentFragment(); for (_ = 0; _ < r.length; _++) this._addTile(r[_], m); this._level.el.appendChild(m); } } } } }, _isValidTile: function (t) { var i = this._map.options.crs; if (!i.infinite) { var e = this._globalTileRange; if ((!i.wrapLng && (t.x < e.min.x || t.x > e.max.x)) || (!i.wrapLat && (t.y < e.min.y || t.y > e.max.y))) return !1; } if (!this.options.bounds) return !0; var n = this._tileCoordsToBounds(t); return D(this.options.bounds).overlaps(n); }, _keyToBounds: function (t) { return this._tileCoordsToBounds(this._keyToTileCoords(t)); }, _tileCoordsToNwSe: function (t) { var i = this._map, e = this.getTileSize(), n = t.scaleBy(e), o = n.add(e); return [i.unproject(n, t.z), i.unproject(o, t.z)]; }, _tileCoordsToBounds: function (t) { var i = this._tileCoordsToNwSe(t), e = new N(i[0], i[1]); return this.options.noWrap || (e = this._map.wrapLatLngBounds(e)), e; }, _tileCoordsToKey: function (t) { return t.x + ":" + t.y + ":" + t.z; }, _keyToTileCoords: function (t) { var i = t.split(":"), e = new B(+i[0], +i[1]); return (e.z = +i[2]), e; }, _removeTile: function (t) { var i = this._tiles[t]; i && (ui(i.el), delete this._tiles[t], this.fire("tileunload", { tile: i.el, coords: this._keyToTileCoords(t) })); }, _initTile: function (t) { pi(t, "leaflet-tile"); var i = this.getTileSize(); (t.style.width = i.x + "px"), (t.style.height = i.y + "px"), (t.onselectstart = l), (t.onmousemove = l), et && this.options.opacity < 1 && vi(t, this.options.opacity), st && !rt && (t.style.WebkitBackfaceVisibility = "hidden"); }, _addTile: function (t, i) { var e = this._getTilePos(t), n = this._tileCoordsToKey(t), o = this.createTile(this._wrapCoords(t), a(this._tileReady, this, t)); this._initTile(o), this.createTile.length < 2 && M(a(this._tileReady, this, t, null, o)), wi(o, e), (this._tiles[n] = { el: o, coords: t, current: !0 }), i.appendChild(o), this.fire("tileloadstart", { tile: o, coords: t }); }, _tileReady: function (t, i, e) { i && this.fire("tileerror", { error: i, tile: e, coords: t }); var n = this._tileCoordsToKey(t); (e = this._tiles[n]) && ((e.loaded = +new Date()), this._map._fadeAnimated ? (vi(e.el, 0), C(this._fadeFrame), (this._fadeFrame = M(this._updateOpacity, this))) : ((e.active = !0), this._pruneTiles()), i || (pi(e.el, "leaflet-tile-loaded"), this.fire("tileload", { tile: e.el, coords: t })), this._noTilesToLoad() && ((this._loading = !1), this.fire("load"), et || !this._map._fadeAnimated ? M(this._pruneTiles, this) : setTimeout(a(this._pruneTiles, this), 250))); }, _getTilePos: function (t) { return t.scaleBy(this.getTileSize()).subtract(this._level.origin); }, _wrapCoords: function (t) { var i = new B(this._wrapX ? r(t.x, this._wrapX) : t.x, this._wrapY ? r(t.y, this._wrapY) : t.y); return (i.z = t.z), i; }, _pxBoundsToTileRange: function (t) { var i = this.getTileSize(); return new O(t.min.unscaleBy(i).floor(), t.max.unscaleBy(i).ceil().subtract([1, 1])); }, _noTilesToLoad: function () { for (var t in this._tiles) if (!this._tiles[t].loaded) return !1; return !0; }, }); var an = rn.extend({ options: { minZoom: 0, maxZoom: 18, subdomains: "abc", errorTileUrl: "", zoomOffset: 0, tms: !1, zoomReverse: !1, detectRetina: !1, crossOrigin: !1 }, initialize: function (t, i) { (this._url = t), (i = p(this, i)).detectRetina && Ct && 0 < i.maxZoom && ((i.tileSize = Math.floor(i.tileSize / 2)), i.zoomReverse ? (i.zoomOffset--, i.minZoom++) : (i.zoomOffset++, i.maxZoom--), (i.minZoom = Math.max(0, i.minZoom))), "string" == typeof i.subdomains && (i.subdomains = i.subdomains.split("")), st || this.on("tileunload", this._onTileRemove); }, setUrl: function (t, i) { return this._url === t && void 0 === i && (i = !0), (this._url = t), i || this.redraw(), this; }, createTile: function (t, i) { var e = document.createElement("img"); return ( Ei(e, "load", a(this._tileOnLoad, this, i, e)), Ei(e, "error", a(this._tileOnError, this, i, e)), (!this.options.crossOrigin && "" !== this.options.crossOrigin) || (e.crossOrigin = !0 === this.options.crossOrigin ? "" : this.options.crossOrigin), (e.alt = ""), e.setAttribute("role", "presentation"), (e.src = this.getTileUrl(t)), e ); }, getTileUrl: function (t) { var i = { r: Ct ? "@2x" : "", s: this._getSubdomain(t), x: t.x, y: t.y, z: this._getZoomForUrl() }; if (this._map && !this._map.options.crs.infinite) { var e = this._globalTileRange.max.y - t.y; this.options.tms && (i.y = e), (i["-y"] = e); } return g(this._url, h(i, this.options)); }, _tileOnLoad: function (t, i) { et ? setTimeout(a(t, this, null, i), 0) : t(null, i); }, _tileOnError: function (t, i, e) { var n = this.options.errorTileUrl; n && i.getAttribute("src") !== n && (i.src = n), t(e, i); }, _onTileRemove: function (t) { t.tile.onload = null; }, _getZoomForUrl: function () { var t = this._tileZoom, i = this.options.maxZoom; return this.options.zoomReverse && (t = i - t), t + this.options.zoomOffset; }, _getSubdomain: function (t) { var i = Math.abs(t.x + t.y) % this.options.subdomains.length; return this.options.subdomains[i]; }, _abortLoading: function () { var t, i; for (t in this._tiles) this._tiles[t].coords.z !== this._tileZoom && (((i = this._tiles[t].el).onload = l), (i.onerror = l), i.complete || ((i.src = x), ui(i), delete this._tiles[t])); }, _removeTile: function (t) { var i = this._tiles[t]; if (i) return ht || i.el.setAttribute("src", x), rn.prototype._removeTile.call(this, t); }, _tileReady: function (t, i, e) { if (this._map && (!e || e.getAttribute("src") !== x)) return rn.prototype._tileReady.call(this, t, i, e); }, }); function hn(t, i) { return new an(t, i); } var un = an.extend({ defaultWmsParams: { service: "WMS", request: "GetMap", layers: "", styles: "", format: "image/jpeg", transparent: !1, version: "1.1.1" }, options: { crs: null, uppercase: !1 }, initialize: function (t, i) { this._url = t; var e = h({}, this.defaultWmsParams); for (var n in i) n in this.options || (e[n] = i[n]); var o = (i = p(this, i)).detectRetina && Ct ? 2 : 1, s = this.getTileSize(); (e.width = s.x * o), (e.height = s.y * o), (this.wmsParams = e); }, onAdd: function (t) { (this._crs = this.options.crs || t.options.crs), (this._wmsVersion = parseFloat(this.wmsParams.version)); var i = 1.3 <= this._wmsVersion ? "crs" : "srs"; (this.wmsParams[i] = this._crs.code), an.prototype.onAdd.call(this, t); }, getTileUrl: function (t) { var i = this._tileCoordsToNwSe(t), e = this._crs, n = R(e.project(i[0]), e.project(i[1])), o = n.min, s = n.max, r = (1.3 <= this._wmsVersion && this._crs === Me ? [o.y, o.x, s.y, s.x] : [o.x, o.y, s.x, s.y]).join(","), a = an.prototype.getTileUrl.call(this, t); return a + m(this.wmsParams, a, this.options.uppercase) + (this.options.uppercase ? "&BBOX=" : "&bbox=") + r; }, setParams: function (t, i) { return h(this.wmsParams, t), i || this.redraw(), this; }, }); (an.WMS = un), (hn.wms = function (t, i) { return new un(t, i); }); var ln = Se.extend({ options: { padding: 0.1, tolerance: 0 }, initialize: function (t) { p(this, t), u(this), (this._layers = this._layers || {}); }, onAdd: function () { this._container || (this._initContainer(), this._zoomAnimated && pi(this._container, "leaflet-zoom-animated")), this.getPane().appendChild(this._container), this._update(), this.on("update", this._updatePaths, this); }, onRemove: function () { this.off("update", this._updatePaths, this), this._destroyContainer(); }, getEvents: function () { var t = { viewreset: this._reset, zoom: this._onZoom, moveend: this._update, zoomend: this._onZoomEnd }; return this._zoomAnimated && (t.zoomanim = this._onAnimZoom), t; }, _onAnimZoom: function (t) { this._updateTransform(t.center, t.zoom); }, _onZoom: function () { this._updateTransform(this._map.getCenter(), this._map.getZoom()); }, _updateTransform: function (t, i) { var e = this._map.getZoomScale(i, this._zoom), n = Pi(this._container), o = this._map.getSize().multiplyBy(0.5 + this.options.padding), s = this._map.project(this._center, i), r = this._map.project(t, i).subtract(s), a = o.multiplyBy(-e).add(n).add(o).subtract(r); yt ? xi(this._container, a, e) : wi(this._container, a); }, _reset: function () { for (var t in (this._update(), this._updateTransform(this._center, this._zoom), this._layers)) this._layers[t]._reset(); }, _onZoomEnd: function () { for (var t in this._layers) this._layers[t]._project(); }, _updatePaths: function () { for (var t in this._layers) this._layers[t]._update(); }, _update: function () { var t = this.options.padding, i = this._map.getSize(), e = this._map.containerPointToLayerPoint(i.multiplyBy(-t)).round(); (this._bounds = new O(e, e.add(i.multiplyBy(1 + 2 * t)).round())), (this._center = this._map.getCenter()), (this._zoom = this._map.getZoom()); }, }), cn = ln.extend({ getEvents: function () { var t = ln.prototype.getEvents.call(this); return (t.viewprereset = this._onViewPreReset), t; }, _onViewPreReset: function () { this._postponeUpdatePaths = !0; }, onAdd: function () { ln.prototype.onAdd.call(this), this._draw(); }, _initContainer: function () { var t = (this._container = document.createElement("canvas")); Ei(t, "mousemove", o(this._onMouseMove, 32, this), this), Ei(t, "click dblclick mousedown mouseup contextmenu", this._onClick, this), Ei(t, "mouseout", this._handleMouseOut, this), (this._ctx = t.getContext("2d")); }, _destroyContainer: function () { C(this._redrawRequest), delete this._ctx, ui(this._container), Bi(this._container), delete this._container; }, _updatePaths: function () { if (!this._postponeUpdatePaths) { for (var t in ((this._redrawBounds = null), this._layers)) this._layers[t]._update(); this._redraw(); } }, _update: function () { if (!this._map._animatingZoom || !this._bounds) { ln.prototype._update.call(this); var t = this._bounds, i = this._container, e = t.getSize(), n = Ct ? 2 : 1; wi(i, t.min), (i.width = n * e.x), (i.height = n * e.y), (i.style.width = e.x + "px"), (i.style.height = e.y + "px"), Ct && this._ctx.scale(2, 2), this._ctx.translate(-t.min.x, -t.min.y), this.fire("update"); } }, _reset: function () { ln.prototype._reset.call(this), this._postponeUpdatePaths && ((this._postponeUpdatePaths = !1), this._updatePaths()); }, _initPath: function (t) { this._updateDashArray(t); var i = ((this._layers[u(t)] = t)._order = { layer: t, prev: this._drawLast, next: null }); this._drawLast && (this._drawLast.next = i), (this._drawLast = i), (this._drawFirst = this._drawFirst || this._drawLast); }, _addPath: function (t) { this._requestRedraw(t); }, _removePath: function (t) { var i = t._order, e = i.next, n = i.prev; e ? (e.prev = n) : (this._drawLast = n), n ? (n.next = e) : (this._drawFirst = e), delete t._order, delete this._layers[u(t)], this._requestRedraw(t); }, _updatePath: function (t) { this._extendRedrawBounds(t), t._project(), t._update(), this._requestRedraw(t); }, _updateStyle: function (t) { this._updateDashArray(t), this._requestRedraw(t); }, _updateDashArray: function (t) { if ("string" == typeof t.options.dashArray) { var i, e, n = t.options.dashArray.split(/[, ]+/), o = []; for (e = 0; e < n.length; e++) { if (((i = Number(n[e])), isNaN(i))) return; o.push(i); } t.options._dashArray = o; } else t.options._dashArray = t.options.dashArray; }, _requestRedraw: function (t) { this._map && (this._extendRedrawBounds(t), (this._redrawRequest = this._redrawRequest || M(this._redraw, this))); }, _extendRedrawBounds: function (t) { if (t._pxBounds) { var i = (t.options.weight || 0) + 1; (this._redrawBounds = this._redrawBounds || new O()), this._redrawBounds.extend(t._pxBounds.min.subtract([i, i])), this._redrawBounds.extend(t._pxBounds.max.add([i, i])); } }, _redraw: function () { (this._redrawRequest = null), this._redrawBounds && (this._redrawBounds.min._floor(), this._redrawBounds.max._ceil()), this._clear(), this._draw(), (this._redrawBounds = null); }, _clear: function () { var t = this._redrawBounds; if (t) { var i = t.getSize(); this._ctx.clearRect(t.min.x, t.min.y, i.x, i.y); } else this._ctx.clearRect(0, 0, this._container.width, this._container.height); }, _draw: function () { var t, i = this._redrawBounds; if ((this._ctx.save(), i)) { var e = i.getSize(); this._ctx.beginPath(), this._ctx.rect(i.min.x, i.min.y, e.x, e.y), this._ctx.clip(); } this._drawing = !0; for (var n = this._drawFirst; n; n = n.next) (t = n.layer), (!i || (t._pxBounds && t._pxBounds.intersects(i))) && t._updatePath(); (this._drawing = !1), this._ctx.restore(); }, _updatePoly: function (t, i) { if (this._drawing) { var e, n, o, s, r = t._parts, a = r.length, h = this._ctx; if (a) { for (h.beginPath(), e = 0; e < a; e++) { for (n = 0, o = r[e].length; n < o; n++) (s = r[e][n]), h[n ? "lineTo" : "moveTo"](s.x, s.y); i && h.closePath(); } this._fillStroke(h, t); } } }, _updateCircle: function (t) { if (this._drawing && !t._empty()) { var i = t._point, e = this._ctx, n = Math.max(Math.round(t._radius), 1), o = (Math.max(Math.round(t._radiusY), 1) || n) / n; 1 != o && (e.save(), e.scale(1, o)), e.beginPath(), e.arc(i.x, i.y / o, n, 0, 2 * Math.PI, !1), 1 != o && e.restore(), this._fillStroke(e, t); } }, _fillStroke: function (t, i) { var e = i.options; e.fill && ((t.globalAlpha = e.fillOpacity), (t.fillStyle = e.fillColor || e.color), t.fill(e.fillRule || "evenodd")), e.stroke && 0 !== e.weight && (t.setLineDash && t.setLineDash((i.options && i.options._dashArray) || []), (t.globalAlpha = e.opacity), (t.lineWidth = e.weight), (t.strokeStyle = e.color), (t.lineCap = e.lineCap), (t.lineJoin = e.lineJoin), t.stroke()); }, _onClick: function (t) { for (var i, e, n = this._map.mouseEventToLayerPoint(t), o = this._drawFirst; o; o = o.next) (i = o.layer).options.interactive && i._containsPoint(n) && !this._map._draggableMoved(i) && (e = i); e && (qi(t), this._fireEvent([e], t)); }, _onMouseMove: function (t) { if (this._map && !this._map.dragging.moving() && !this._map._animatingZoom) { var i = this._map.mouseEventToLayerPoint(t); this._handleMouseHover(t, i); } }, _handleMouseOut: function (t) { var i = this._hoveredLayer; i && (mi(this._container, "leaflet-interactive"), this._fireEvent([i], t, "mouseout"), (this._hoveredLayer = null)); }, _handleMouseHover: function (t, i) { for (var e, n, o = this._drawFirst; o; o = o.next) (e = o.layer).options.interactive && e._containsPoint(i) && (n = e); n !== this._hoveredLayer && (this._handleMouseOut(t), n && (pi(this._container, "leaflet-interactive"), this._fireEvent([n], t, "mouseover"), (this._hoveredLayer = n))), this._hoveredLayer && this._fireEvent([this._hoveredLayer], t); }, _fireEvent: function (t, i, e) { this._map._fireDOMEvent(i, e || i.type, t); }, _bringToFront: function (t) { var i = t._order; if (i) { var e = i.next, n = i.prev; e && ((e.prev = n) ? (n.next = e) : e && (this._drawFirst = e), (i.prev = this._drawLast), ((this._drawLast.next = i).next = null), (this._drawLast = i), this._requestRedraw(t)); } }, _bringToBack: function (t) { var i = t._order; if (i) { var e = i.next, n = i.prev; n && ((n.next = e) ? (e.prev = n) : n && (this._drawLast = n), (i.prev = null), (i.next = this._drawFirst), (this._drawFirst.prev = i), (this._drawFirst = i), this._requestRedraw(t)); } }, }); function _n(t) { return St ? new cn(t) : null; } var dn = (function () { try { return ( document.namespaces.add("lvml", "urn:schemas-microsoft-com:vml"), function (t) { return document.createElement("<lvml:" + t + ' class="lvml">'); } ); } catch (t) { return function (t) { return document.createElement("<" + t + ' xmlns="urn:schemas-microsoft.com:vml" class="lvml">'); }; } })(), pn = { _initContainer: function () { this._container = hi("div", "leaflet-vml-container"); }, _update: function () { this._map._animatingZoom || (ln.prototype._update.call(this), this.fire("update")); }, _initPath: function (t) { var i = (t._container = dn("shape")); pi(i, "leaflet-vml-shape " + (this.options.className || "")), (i.coordsize = "1 1"), (t._path = dn("path")), i.appendChild(t._path), this._updateStyle(t), (this._layers[u(t)] = t); }, _addPath: function (t) { var i = t._container; this._container.appendChild(i), t.options.interactive && t.addInteractiveTarget(i); }, _removePath: function (t) { var i = t._container; ui(i), t.removeInteractiveTarget(i), delete this._layers[u(t)]; }, _updateStyle: function (t) { var i = t._stroke, e = t._fill, n = t.options, o = t._container; (o.stroked = !!n.stroke), (o.filled = !!n.fill), n.stroke ? (i || (i = t._stroke = dn("stroke")), o.appendChild(i), (i.weight = n.weight + "px"), (i.color = n.color), (i.opacity = n.opacity), n.dashArray ? (i.dashStyle = v(n.dashArray) ? n.dashArray.join(" ") : n.dashArray.replace(/( *, *)/g, " ")) : (i.dashStyle = ""), (i.endcap = n.lineCap.replace("butt", "flat")), (i.joinstyle = n.lineJoin)) : i && (o.removeChild(i), (t._stroke = null)), n.fill ? (e || (e = t._fill = dn("fill")), o.appendChild(e), (e.color = n.fillColor || n.color), (e.opacity = n.fillOpacity)) : e && (o.removeChild(e), (t._fill = null)); }, _updateCircle: function (t) { var i = t._point.round(), e = Math.round(t._radius), n = Math.round(t._radiusY || e); this._setPath(t, t._empty() ? "M0 0" : "AL " + i.x + "," + i.y + " " + e + "," + n + " 0,23592600"); }, _setPath: function (t, i) { t._path.v = i; }, _bringToFront: function (t) { ci(t._container); }, _bringToBack: function (t) { _i(t._container); }, }, mn = Et ? dn : $, fn = ln.extend({ getEvents: function () { var t = ln.prototype.getEvents.call(this); return (t.zoomstart = this._onZoomStart), t; }, _initContainer: function () { (this._container = mn("svg")), this._container.setAttribute("pointer-events", "none"), (this._rootGroup = mn("g")), this._container.appendChild(this._rootGroup); }, _destroyContainer: function () { ui(this._container), Bi(this._container), delete this._container, delete this._rootGroup, delete this._svgSize; }, _onZoomStart: function () { this._update(); }, _update: function () { if (!this._map._animatingZoom || !this._bounds) { ln.prototype._update.call(this); var t = this._bounds, i = t.getSize(), e = this._container; (this._svgSize && this._svgSize.equals(i)) || ((this._svgSize = i), e.setAttribute("width", i.x), e.setAttribute("height", i.y)), wi(e, t.min), e.setAttribute("viewBox", [t.min.x, t.min.y, i.x, i.y].join(" ")), this.fire("update"); } }, _initPath: function (t) { var i = (t._path = mn("path")); t.options.className && pi(i, t.options.className), t.options.interactive && pi(i, "leaflet-interactive"), this._updateStyle(t), (this._layers[u(t)] = t); }, _addPath: function (t) { this._rootGroup || this._initContainer(), this._rootGroup.appendChild(t._path), t.addInteractiveTarget(t._path); }, _removePath: function (t) { ui(t._path), t.removeInteractiveTarget(t._path), delete this._layers[u(t)]; }, _updatePath: function (t) { t._project(), t._update(); }, _updateStyle: function (t) { var i = t._path, e = t.options; i && (e.stroke ? (i.setAttribute("stroke", e.color), i.setAttribute("stroke-opacity", e.opacity), i.setAttribute("stroke-width", e.weight), i.setAttribute("stroke-linecap", e.lineCap), i.setAttribute("stroke-linejoin", e.lineJoin), e.dashArray ? i.setAttribute("stroke-dasharray", e.dashArray) : i.removeAttribute("stroke-dasharray"), e.dashOffset ? i.setAttribute("stroke-dashoffset", e.dashOffset) : i.removeAttribute("stroke-dashoffset")) : i.setAttribute("stroke", "none"), e.fill ? (i.setAttribute("fill", e.fillColor || e.color), i.setAttribute("fill-opacity", e.fillOpacity), i.setAttribute("fill-rule", e.fillRule || "evenodd")) : i.setAttribute("fill", "none")); }, _updatePoly: function (t, i) { this._setPath(t, Q(t._parts, i)); }, _updateCircle: function (t) { var i = t._point, e = Math.max(Math.round(t._radius), 1), n = "a" + e + "," + (Math.max(Math.round(t._radiusY), 1) || e) + " 0 1,0 ", o = t._empty() ? "M0 0" : "M" + (i.x - e) + "," + i.y + n + 2 * e + ",0 " + n + 2 * -e + ",0 "; this._setPath(t, o); }, _setPath: function (t, i) { t._path.setAttribute("d", i); }, _bringToFront: function (t) { ci(t._path); }, _bringToBack: function (t) { _i(t._path); }, }); function gn(t) { return Zt || Et ? new fn(t) : null; } Et && fn.include(pn), Ji.include({ getRenderer: function (t) { var i = t.options.renderer || this._getPaneRenderer(t.options.pane) || this.options.renderer || this._renderer; return i || (i = this._renderer = this._createRenderer()), this.hasLayer(i) || this.addLayer(i), i; }, _getPaneRenderer: function (t) { if ("overlayPane" === t || void 0 === t) return !1; var i = this._paneRenderers[t]; return void 0 === i && ((i = this._createRenderer({ pane: t })), (this._paneRenderers[t] = i)), i; }, _createRenderer: function (t) { return (this.options.preferCanvas && _n(t)) || gn(t); }, }); var vn = je.extend({ initialize: function (t, i) { je.prototype.initialize.call(this, this._boundsToLatLngs(t), i); }, setBounds: function (t) { return this.setLatLngs(this._boundsToLatLngs(t)); }, _boundsToLatLngs: function (t) { return [(t = D(t)).getSouthWest(), t.getNorthWest(), t.getNorthEast(), t.getSouthEast()]; }, }); (fn.create = mn), (fn.pointsToPath = Q), (We.geometryToLayer = He), (We.coordsToLatLng = Fe), (We.coordsToLatLngs = Ue), (We.latLngToCoords = Ve), (We.latLngsToCoords = qe), (We.getFeature = Ge), (We.asFeature = Ke), Ji.mergeOptions({ boxZoom: !0 }); var yn = oe.extend({ initialize: function (t) { (this._map = t), (this._container = t._container), (this._pane = t._panes.overlayPane), (this._resetStateTimeout = 0), t.on("unload", this._destroy, this); }, addHooks: function () { Ei(this._container, "mousedown", this._onMouseDown, this); }, removeHooks: function () { Bi(this._container, "mousedown", this._onMouseDown, this); }, moved: function () { return this._moved; }, _destroy: function () { ui(this._pane), delete this._pane; }, _resetState: function () { (this._resetStateTimeout = 0), (this._moved = !1); }, _clearDeferredResetState: function () { 0 !== this._resetStateTimeout && (clearTimeout(this._resetStateTimeout), (this._resetStateTimeout = 0)); }, _onMouseDown: function (t) { if (!t.shiftKey || (1 !== t.which && 1 !== t.button)) return !1; this._clearDeferredResetState(), this._resetState(), $t(), Li(), (this._startPoint = this._map.mouseEventToContainerPoint(t)), Ei(document, { contextmenu: ji, mousemove: this._onMouseMove, mouseup: this._onMouseUp, keydown: this._onKeyDown }, this); }, _onMouseMove: function (t) { this._moved || ((this._moved = !0), (this._box = hi("div", "leaflet-zoom-box", this._container)), pi(this._container, "leaflet-crosshair"), this._map.fire("boxzoomstart")), (this._point = this._map.mouseEventToContainerPoint(t)); var i = new O(this._point, this._startPoint), e = i.getSize(); wi(this._box, i.min), (this._box.style.width = e.x + "px"), (this._box.style.height = e.y + "px"); }, _finish: function () { this._moved && (ui(this._box), mi(this._container, "leaflet-crosshair")), Qt(), Ti(), Bi(document, { contextmenu: ji, mousemove: this._onMouseMove, mouseup: this._onMouseUp, keydown: this._onKeyDown }, this); }, _onMouseUp: function (t) { if ((1 === t.which || 1 === t.button) && (this._finish(), this._moved)) { this._clearDeferredResetState(), (this._resetStateTimeout = setTimeout(a(this._resetState, this), 0)); var i = new N(this._map.containerPointToLatLng(this._startPoint), this._map.containerPointToLatLng(this._point)); this._map.fitBounds(i).fire("boxzoomend", { boxZoomBounds: i }); } }, _onKeyDown: function (t) { 27 === t.keyCode && this._finish(); }, }); Ji.addInitHook("addHandler", "boxZoom", yn), Ji.mergeOptions({ doubleClickZoom: !0 }); var xn = oe.extend({ addHooks: function () { this._map.on("dblclick", this._onDoubleClick, this); }, removeHooks: function () { this._map.off("dblclick", this._onDoubleClick, this); }, _onDoubleClick: function (t) { var i = this._map, e = i.getZoom(), n = i.options.zoomDelta, o = t.originalEvent.shiftKey ? e - n : e + n; "center" === i.options.doubleClickZoom ? i.setZoom(o) : i.setZoomAround(t.containerPoint, o); }, }); Ji.addInitHook("addHandler", "doubleClickZoom", xn), Ji.mergeOptions({ dragging: !0, inertia: !rt, inertiaDeceleration: 3400, inertiaMaxSpeed: 1 / 0, easeLinearity: 0.2, worldCopyJump: !1, maxBoundsViscosity: 0 }); var wn = oe.extend({ addHooks: function () { if (!this._draggable) { var t = this._map; (this._draggable = new le(t._mapPane, t._container)), this._draggable.on({ dragstart: this._onDragStart, drag: this._onDrag, dragend: this._onDragEnd }, this), this._draggable.on("predrag", this._onPreDragLimit, this), t.options.worldCopyJump && (this._draggable.on("predrag", this._onPreDragWrap, this), t.on("zoomend", this._onZoomEnd, this), t.whenReady(this._onZoomEnd, this)); } pi(this._map._container, "leaflet-grab leaflet-touch-drag"), this._draggable.enable(), (this._positions = []), (this._times = []); }, removeHooks: function () { mi(this._map._container, "leaflet-grab"), mi(this._map._container, "leaflet-touch-drag"), this._draggable.disable(); }, moved: function () { return this._draggable && this._draggable._moved; }, moving: function () { return this._draggable && this._draggable._moving; }, _onDragStart: function () { var t = this._map; if ((t._stop(), this._map.options.maxBounds && this._map.options.maxBoundsViscosity)) { var i = D(this._map.options.maxBounds); (this._offsetLimit = R(this._map.latLngToContainerPoint(i.getNorthWest()).multiplyBy(-1), this._map.latLngToContainerPoint(i.getSouthEast()).multiplyBy(-1).add(this._map.getSize()))), (this._viscosity = Math.min(1, Math.max(0, this._map.options.maxBoundsViscosity))); } else this._offsetLimit = null; t.fire("movestart").fire("dragstart"), t.options.inertia && ((this._positions = []), (this._times = [])); }, _onDrag: function (t) { if (this._map.options.inertia) { var i = (this._lastTime = +new Date()), e = (this._lastPos = this._draggable._absPos || this._draggable._newPos); this._positions.push(e), this._times.push(i), this._prunePositions(i); } this._map.fire("move", t).fire("drag", t); }, _prunePositions: function (t) { for (; 1 < this._positions.length && 50 < t - this._times[0]; ) this._positions.shift(), this._times.shift(); }, _onZoomEnd: function () { var t = this._map.getSize().divideBy(2), i = this._map.latLngToLayerPoint([0, 0]); (this._initialWorldOffset = i.subtract(t).x), (this._worldWidth = this._map.getPixelWorldBounds().getSize().x); }, _viscousLimit: function (t, i) { return t - (t - i) * this._viscosity; }, _onPreDragLimit: function () { if (this._viscosity && this._offsetLimit) { var t = this._draggable._newPos.subtract(this._draggable._startPos), i = this._offsetLimit; t.x < i.min.x && (t.x = this._viscousLimit(t.x, i.min.x)), t.y < i.min.y && (t.y = this._viscousLimit(t.y, i.min.y)), t.x > i.max.x && (t.x = this._viscousLimit(t.x, i.max.x)), t.y > i.max.y && (t.y = this._viscousLimit(t.y, i.max.y)), (this._draggable._newPos = this._draggable._startPos.add(t)); } }, _onPreDragWrap: function () { var t = this._worldWidth, i = Math.round(t / 2), e = this._initialWorldOffset, n = this._draggable._newPos.x, o = ((n - i + e) % t) + i - e, s = ((n + i + e) % t) - i - e, r = Math.abs(o + e) < Math.abs(s + e) ? o : s; (this._draggable._absPos = this._draggable._newPos.clone()), (this._draggable._newPos.x = r); }, _onDragEnd: function (t) { var i = this._map, e = i.options, n = !e.inertia || this._times.length < 2; if ((i.fire("dragend", t), n)) i.fire("moveend"); else { this._prunePositions(+new Date()); var o = this._lastPos.subtract(this._positions[0]), s = (this._lastTime - this._times[0]) / 1e3, r = e.easeLinearity, a = o.multiplyBy(r / s), h = a.distanceTo([0, 0]), u = Math.min(e.inertiaMaxSpeed, h), l = a.multiplyBy(u / h), c = u / (e.inertiaDeceleration * r), _ = l.multiplyBy(-c / 2).round(); _.x || _.y ? ((_ = i._limitOffset(_, i.options.maxBounds)), M(function () { i.panBy(_, { duration: c, easeLinearity: r, noMoveStart: !0, animate: !0 }); })) : i.fire("moveend"); } }, }); Ji.addInitHook("addHandler", "dragging", wn), Ji.mergeOptions({ keyboard: !0, keyboardPanDelta: 80 }); var Pn = oe.extend({ keyCodes: { left: [37], right: [39], down: [40], up: [38], zoomIn: [187, 107, 61, 171], zoomOut: [189, 109, 54, 173] }, initialize: function (t) { (this._map = t), this._setPanDelta(t.options.keyboardPanDelta), this._setZoomDelta(t.options.zoomDelta); }, addHooks: function () { var t = this._map._container; t.tabIndex <= 0 && (t.tabIndex = "0"), Ei(t, { focus: this._onFocus, blur: this._onBlur, mousedown: this._onMouseDown }, this), this._map.on({ focus: this._addHooks, blur: this._removeHooks }, this); }, removeHooks: function () { this._removeHooks(), Bi(this._map._container, { focus: this._onFocus, blur: this._onBlur, mousedown: this._onMouseDown }, this), this._map.off({ focus: this._addHooks, blur: this._removeHooks }, this); }, _onMouseDown: function () { if (!this._focused) { var t = document.body, i = document.documentElement, e = t.scrollTop || i.scrollTop, n = t.scrollLeft || i.scrollLeft; this._map._container.focus(), window.scrollTo(n, e); } }, _onFocus: function () { (this._focused = !0), this._map.fire("focus"); }, _onBlur: function () { (this._focused = !1), this._map.fire("blur"); }, _setPanDelta: function (t) { var i, e, n = (this._panKeys = {}), o = this.keyCodes; for (i = 0, e = o.left.length; i < e; i++) n[o.left[i]] = [-1 * t, 0]; for (i = 0, e = o.right.length; i < e; i++) n[o.right[i]] = [t, 0]; for (i = 0, e = o.down.length; i < e; i++) n[o.down[i]] = [0, t]; for (i = 0, e = o.up.length; i < e; i++) n[o.up[i]] = [0, -1 * t]; }, _setZoomDelta: function (t) { var i, e, n = (this._zoomKeys = {}), o = this.keyCodes; for (i = 0, e = o.zoomIn.length; i < e; i++) n[o.zoomIn[i]] = t; for (i = 0, e = o.zoomOut.length; i < e; i++) n[o.zoomOut[i]] = -t; }, _addHooks: function () { Ei(document, "keydown", this._onKeyDown, this); }, _removeHooks: function () { Bi(document, "keydown", this._onKeyDown, this); }, _onKeyDown: function (t) { if (!(t.altKey || t.ctrlKey || t.metaKey)) { var i, e = t.keyCode, n = this._map; if (e in this._panKeys) (n._panAnim && n._panAnim._inProgress) || ((i = this._panKeys[e]), t.shiftKey && (i = I(i).multiplyBy(3)), n.panBy(i), n.options.maxBounds && n.panInsideBounds(n.options.maxBounds)); else if (e in this._zoomKeys) n.setZoom(n.getZoom() + (t.shiftKey ? 3 : 1) * this._zoomKeys[e]); else { if (27 !== e || !n._popup || !n._popup.options.closeOnEscapeKey) return; n.closePopup(); } ji(t); } }, }); Ji.addInitHook("addHandler", "keyboard", Pn), Ji.mergeOptions({ scrollWheelZoom: !0, wheelDebounceTime: 40, wheelPxPerZoomLevel: 60 }); var bn = oe.extend({ addHooks: function () { Ei(this._map._container, "mousewheel", this._onWheelScroll, this), (this._delta = 0); }, removeHooks: function () { Bi(this._map._container, "mousewheel", this._onWheelScroll, this); }, _onWheelScroll: function (t) { var i = Fi(t), e = this._map.options.wheelDebounceTime; (this._delta += i), (this._lastMousePos = this._map.mouseEventToContainerPoint(t)), this._startTime || (this._startTime = +new Date()); var n = Math.max(e - (+new Date() - this._startTime), 0); clearTimeout(this._timer), (this._timer = setTimeout(a(this._performZoom, this), n)), ji(t); }, _performZoom: function () { var t = this._map, i = t.getZoom(), e = this._map.options.zoomSnap || 0; t._stop(); var n = this._delta / (4 * this._map.options.wheelPxPerZoomLevel), o = (4 * Math.log(2 / (1 + Math.exp(-Math.abs(n))))) / Math.LN2, s = e ? Math.ceil(o / e) * e : o, r = t._limitZoom(i + (0 < this._delta ? s : -s)) - i; (this._delta = 0), (this._startTime = null), r && ("center" === t.options.scrollWheelZoom ? t.setZoom(i + r) : t.setZoomAround(this._lastMousePos, i + r)); }, }); Ji.addInitHook("addHandler", "scrollWheelZoom", bn), Ji.mergeOptions({ tap: !0, tapTolerance: 15 }); var Ln = oe.extend({ addHooks: function () { Ei(this._map._container, "touchstart", this._onDown, this); }, removeHooks: function () { Bi(this._map._container, "touchstart", this._onDown, this); }, _onDown: function (t) { if (t.touches) { if ((Di(t), (this._fireClick = !0), 1 < t.touches.length)) return (this._fireClick = !1), void clearTimeout(this._holdTimeout); var i = t.touches[0], e = i.target; (this._startPos = this._newPos = new B(i.clientX, i.clientY)), e.tagName && "a" === e.tagName.toLowerCase() && pi(e, "leaflet-active"), (this._holdTimeout = setTimeout( a(function () { this._isTapValid() && ((this._fireClick = !1), this._onUp(), this._simulateEvent("contextmenu", i)); }, this), 1e3 )), this._simulateEvent("mousedown", i), Ei(document, { touchmove: this._onMove, touchend: this._onUp }, this); } }, _onUp: function (t) { if ((clearTimeout(this._holdTimeout), Bi(document, { touchmove: this._onMove, touchend: this._onUp }, this), this._fireClick && t && t.changedTouches)) { var i = t.changedTouches[0], e = i.target; e && e.tagName && "a" === e.tagName.toLowerCase() && mi(e, "leaflet-active"), this._simulateEvent("mouseup", i), this._isTapValid() && this._simulateEvent("click", i); } }, _isTapValid: function () { return this._newPos.distanceTo(this._startPos) <= this._map.options.tapTolerance; }, _onMove: function (t) { var i = t.touches[0]; (this._newPos = new B(i.clientX, i.clientY)), this._simulateEvent("mousemove", i); }, _simulateEvent: function (t, i) { var e = document.createEvent("MouseEvents"); (e._simulated = !0), (i.target._simulatedClick = !0), e.initMouseEvent(t, !0, !0, window, 1, i.screenX, i.screenY, i.clientX, i.clientY, !1, !1, !1, !1, 0, null), i.target.dispatchEvent(e); }, }); Tt && !Lt && Ji.addInitHook("addHandler", "tap", Ln), Ji.mergeOptions({ touchZoom: Tt && !rt, bounceAtZoomLimits: !0 }); var Tn = oe.extend({ addHooks: function () { pi(this._map._container, "leaflet-touch-zoom"), Ei(this._map._container, "touchstart", this._onTouchStart, this); }, removeHooks: function () { mi(this._map._container, "leaflet-touch-zoom"), Bi(this._map._container, "touchstart", this._onTouchStart, this); }, _onTouchStart: function (t) { var i = this._map; if (t.touches && 2 === t.touches.length && !i._animatingZoom && !this._zooming) { var e = i.mouseEventToContainerPoint(t.touches[0]), n = i.mouseEventToContainerPoint(t.touches[1]); (this._centerPoint = i.getSize()._divideBy(2)), (this._startLatLng = i.containerPointToLatLng(this._centerPoint)), "center" !== i.options.touchZoom && (this._pinchStartLatLng = i.containerPointToLatLng(e.add(n)._divideBy(2))), (this._startDist = e.distanceTo(n)), (this._startZoom = i.getZoom()), (this._moved = !1), (this._zooming = !0), i._stop(), Ei(document, "touchmove", this._onTouchMove, this), Ei(document, "touchend", this._onTouchEnd, this), Di(t); } }, _onTouchMove: function (t) { if (t.touches && 2 === t.touches.length && this._zooming) { var i = this._map, e = i.mouseEventToContainerPoint(t.touches[0]), n = i.mouseEventToContainerPoint(t.touches[1]), o = e.distanceTo(n) / this._startDist; if ( ((this._zoom = i.getScaleZoom(o, this._startZoom)), !i.options.bounceAtZoomLimits && ((this._zoom < i.getMinZoom() && o < 1) || (this._zoom > i.getMaxZoom() && 1 < o)) && (this._zoom = i._limitZoom(this._zoom)), "center" === i.options.touchZoom) ) { if (((this._center = this._startLatLng), 1 == o)) return; } else { var s = e._add(n)._divideBy(2)._subtract(this._centerPoint); if (1 == o && 0 === s.x && 0 === s.y) return; this._center = i.unproject(i.project(this._pinchStartLatLng, this._zoom).subtract(s), this._zoom); } this._moved || (i._moveStart(!0, !1), (this._moved = !0)), C(this._animRequest); var r = a(i._move, i, this._center, this._zoom, { pinch: !0, round: !1 }); (this._animRequest = M(r, this, !0)), Di(t); } }, _onTouchEnd: function () { this._moved && this._zooming ? ((this._zooming = !1), C(this._animRequest), Bi(document, "touchmove", this._onTouchMove), Bi(document, "touchend", this._onTouchEnd), this._map.options.zoomAnimation ? this._map._animateZoom(this._center, this._map._limitZoom(this._zoom), !0, this._map.options.zoomSnap) : this._map._resetView(this._center, this._map._limitZoom(this._zoom))) : (this._zooming = !1); }, }); Ji.addInitHook("addHandler", "touchZoom", Tn), (Ji.BoxZoom = yn), (Ji.DoubleClickZoom = xn), (Ji.Drag = wn), (Ji.Keyboard = Pn), (Ji.ScrollWheelZoom = bn), (Ji.Tap = Ln), (Ji.TouchZoom = Tn), (Object.freeze = i), (t.version = "1.5.1+build.2e3e0ffb"), (t.Control = Qi), (t.control = $i), (t.Browser = Bt), (t.Evented = k), (t.Mixin = re), (t.Util = S), (t.Class = Z), (t.Handler = oe), (t.extend = h), (t.bind = a), (t.stamp = u), (t.setOptions = p), (t.DomEvent = Yi), (t.DomUtil = Zi), (t.PosAnimation = Xi), (t.Draggable = le), (t.LineUtil = ye), (t.PolyUtil = Pe), (t.Point = B), (t.point = I), (t.Bounds = O), (t.bounds = R), (t.Transformation = G), (t.transformation = K), (t.Projection = Te), (t.LatLng = j), (t.latLng = W), (t.LatLngBounds = N), (t.latLngBounds = D), (t.CRS = F), (t.GeoJSON = We), (t.geoJSON = Xe), (t.geoJson = Je), (t.Layer = Se), (t.LayerGroup = Ze), (t.layerGroup = function (t, i) { return new Ze(t, i); }), (t.FeatureGroup = Ee), (t.featureGroup = function (t) { return new Ee(t); }), (t.ImageOverlay = $e), (t.imageOverlay = function (t, i, e) { return new $e(t, i, e); }), (t.VideoOverlay = Qe), (t.videoOverlay = function (t, i, e) { return new Qe(t, i, e); }), (t.SVGOverlay = tn), (t.svgOverlay = function (t, i, e) { return new tn(t, i, e); }), (t.DivOverlay = en), (t.Popup = nn), (t.popup = function (t, i) { return new nn(t, i); }), (t.Tooltip = on), (t.tooltip = function (t, i) { return new on(t, i); }), (t.Icon = ke), (t.icon = function (t) { return new ke(t); }), (t.DivIcon = sn), (t.divIcon = function (t) { return new sn(t); }), (t.Marker = Ie), (t.marker = function (t, i) { return new Ie(t, i); }), (t.TileLayer = an), (t.tileLayer = hn), (t.GridLayer = rn), (t.gridLayer = function (t) { return new rn(t); }), (t.SVG = fn), (t.svg = gn), (t.Renderer = ln), (t.Canvas = cn), (t.canvas = _n), (t.Path = Oe), (t.CircleMarker = Re), (t.circleMarker = function (t, i) { return new Re(t, i); }), (t.Circle = Ne), (t.circle = function (t, i, e) { return new Ne(t, i, e); }), (t.Polyline = De), (t.polyline = function (t, i) { return new De(t, i); }), (t.Polygon = je), (t.polygon = function (t, i) { return new je(t, i); }), (t.Rectangle = vn), (t.rectangle = function (t, i) { return new vn(t, i); }), (t.Map = Ji), (t.map = function (t, i) { return new Ji(t, i); }); var zn = window.L; (t.noConflict = function () { return (window.L = zn), this; }), (window.L = t); });