/* @preserve
* Leaflet 1.6.0, a JS library for interactive maps. http://leafletjs.com
* (c) 2010-2019 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) {
var e = Math.pow(10, void 0 === i ? 6 : i);
return Math.round(t * e) / e
}
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 E() {}
E.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
}, E.include = function(t) {
return h(this.prototype, t), this
}, E.mergeOptions = function(t) {
return h(this.prototype.options, t), this
}, E.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 Z = {
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)
}
};
Z.addEventListener = Z.on, Z.removeEventListener = Z.clearAllEventListeners = Z.off, Z.addOneTimeEventListener = Z.once, Z.fireEvent = Z.fire, Z.hasEventListeners = Z.listens;
var k = E.extend(Z);
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 = .5 / (Math.PI * q.R), K(Y, .5, -Y, .5))
}),
J = h({}, X, {
code: "EPSG:900913"
});
function $(t) {
return document.createElementNS("http://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 = Bt("webkit"),
st = Bt("android"),
rt = Bt("android 2") || Bt("android 3"),
at = parseInt(/WebKit\/([0-9]+)|$/.exec(navigator.userAgent)[1], 10),
ht = st && Bt("Google") && at < 537 && !("AudioNode" in window),
ut = !!window.opera,
lt = Bt("chrome"),
ct = Bt("gecko") && !ot && !ut && !it,
_t = !lt && Bt("safari"),
dt = Bt("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 || Bt("mobile"),
wt = xt && ot,
Pt = xt && gt,
Lt = !window.PointerEvent && window.MSPointerEvent,
bt = !(ot || !window.PointerEvent && !Lt),
Tt = !window.L_NO_TOUCH && (bt || "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 = function() {
var t = !1;
try {
var i = Object.defineProperty({}, "passive", {
get: function() {
t = !0
}
});
window.addEventListener("testPassiveEventSupport", l, i), window.removeEventListener("testPassiveEventSupport", l, i)
} catch (t) {}
return t
},
Et = !!document.createElement("canvas").getContext,
Zt = !(!document.createElementNS || !$("svg").createSVGRect),
kt = !Zt && function() {
try {
var t = document.createElement("div");
t.innerHTML = '';
var i = t.firstChild;
return i.style.behavior = "url(#default#VML)", i && "object" == typeof i.adj
} catch (t) {
return !1
}
}();
function Bt(t) {
return 0 <= navigator.userAgent.toLowerCase().indexOf(t)
}
var At = (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: Lt,
pointer: bt,
touch: Tt,
mobileOpera: zt,
mobileGecko: Mt,
retina: Ct,
passiveEvents: St,
canvas: Et,
svg: Zt,
vml: kt
}),
It = Lt ? "MSPointerDown" : "pointerdown",
Ot = Lt ? "MSPointerMove" : "pointermove",
Rt = Lt ? "MSPointerUp" : "pointerup",
Nt = Lt ? "MSPointerCancel" : "pointercancel",
Dt = ["INPUT", "SELECT", "OPTION"],
jt = {},
Wt = !1,
Ht = 0;
function Ft(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 (!(Dt.indexOf(t.target.tagName) < 0)) return;
ji(t)
}
Gt(t, i)
});
t["_leaflet_touchstart" + e] = n, t.addEventListener(It, n, !1), Wt || (document.documentElement.addEventListener(It, Ut, !0), document.documentElement.addEventListener(Ot, Vt, !0), document.documentElement.addEventListener(Rt, qt, !0), document.documentElement.addEventListener(Nt, qt, !0), Wt = !0)
}(t, e, n) : "touchmove" === i ? function(t, i, e) {
function n(t) {
(t.pointerType !== t.MSPOINTER_TYPE_MOUSE && "mouse" !== t.pointerType || 0 !== t.buttons) && Gt(t, i)
}
t["_leaflet_touchmove" + e] = n, t.addEventListener(Ot, n, !1)
}(t, e, n) : "touchend" === i && function(t, i, e) {
function n(t) {
Gt(t, i)
}
t["_leaflet_touchend" + e] = n, t.addEventListener(Rt, n, !1), t.addEventListener(Nt, n, !1)
}(t, e, n), this
}
function Ut(t) {
jt[t.pointerId] = t, Ht++
}
function Vt(t) {
jt[t.pointerId] && (jt[t.pointerId] = t)
}
function qt(t) {
delete jt[t.pointerId], Ht--
}
function Gt(t, i) {
for (var e in t.touches = [], jt) t.touches.push(jt[e]);
t.changedTouches = [t], i(t)
}
var Kt = Lt ? "MSPointerDown" : bt ? "pointerdown" : "touchstart",
Yt = Lt ? "MSPointerUp" : bt ? "pointerup" : "touchend",
Xt = "_leaflet_";
function Jt(t, o, i) {
var s, r, a = !1;
function e(t) {
var i;
if (bt) {
if (!nt || "mouse" === t.pointerType) return;
i = Ht
} 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 (bt) {
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[Xt + Kt + i] = e, t[Xt + Yt + i] = n, t[Xt + "dblclick" + i] = o, t.addEventListener(Kt, e, !!St && {
passive: !1
}), t.addEventListener(Yt, n, !!St && {
passive: !1
}), t.addEventListener("dblclick", o, !1), this
}
function $t(t, i) {
var e = t[Xt + Kt + i],
n = t[Xt + Yt + i],
o = t[Xt + "dblclick" + i];
return t.removeEventListener(Kt, e, !!St && {
passive: !1
}), t.removeEventListener(Yt, n, !!St && {
passive: !1
}), nt || t.removeEventListener("dblclick", o, !1), this
}
var Qt, ti, ii, ei, ni, oi = xi(["transform", "webkitTransform", "OTransform", "MozTransform", "msTransform"]),
si = xi(["webkitTransition", "transition", "OTransition", "MozTransition", "msTransition"]),
ri = "webkitTransition" === si || "OTransition" === si ? si + "End" : "transitionend";
function ai(t) {
return "string" == typeof t ? document.getElementById(t) : t
}
function hi(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 ui(t, i, e) {
var n = document.createElement(t);
return n.className = i || "", e && e.appendChild(n), n
}
function li(t) {
var i = t.parentNode;
i && i.removeChild(t)
}
function ci(t) {
for (; t.firstChild;) t.removeChild(t.firstChild)
}
function _i(t) {
var i = t.parentNode;
i && i.lastChild !== t && i.appendChild(t)
}
function di(t) {
var i = t.parentNode;
i && i.firstChild !== t && i.insertBefore(t, i.firstChild)
}
function pi(t, i) {
if (void 0 !== t.classList) return t.classList.contains(i);
var e = vi(t);
return 0 < e.length && new RegExp("(^|\\s)" + i + "(\\s|$)").test(e)
}
function mi(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 (!pi(t, i)) {
var s = vi(t);
gi(t, (s ? s + " " : "") + i)
}
}
function fi(t, i) {
void 0 !== t.classList ? t.classList.remove(i) : gi(t, _((" " + vi(t) + " ").replace(" " + i + " ", " ")))
}
function gi(t, i) {
void 0 === t.className.baseVal ? t.className = i : t.className.baseVal = i
}
function vi(t) {
return t.correspondingElement && (t = t.correspondingElement), void 0 === t.className.baseVal ? t.className : t.className.baseVal
}
function yi(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 xi(t) {
for (var i = document.documentElement.style, e = 0; e < t.length; e++)
if (t[e] in i) return t[e];
return !1
}
function wi(t, i, e) {
var n = i || new B(0, 0);
t.style[oi] = (ft ? "translate(" + n.x + "px," + n.y + "px)" : "translate3d(" + n.x + "px," + n.y + "px,0)") + (e ? " scale(" + e + ")" : "")
}
function Pi(t, i) {
t._leaflet_pos = i, yt ? wi(t, i) : (t.style.left = i.x + "px", t.style.top = i.y + "px")
}
function Li(t) {
return t._leaflet_pos || new B(0, 0)
}
if ("onselectstart" in document) Qt = function() {
ki(window, "selectstart", ji)
}, ti = function() {
Ai(window, "selectstart", ji)
};
else {
var bi = xi(["userSelect", "WebkitUserSelect", "OUserSelect", "MozUserSelect", "msUserSelect"]);
Qt = function() {
if (bi) {
var t = document.documentElement.style;
ii = t[bi], t[bi] = "none"
}
}, ti = function() {
bi && (document.documentElement.style[bi] = ii, ii = void 0)
}
}
function Ti() {
ki(window, "dragstart", ji)
}
function zi() {
Ai(window, "dragstart", ji)
}
function Mi(t) {
for (; - 1 === t.tabIndex;) t = t.parentNode;
t.style && (Ci(), ni = (ei = t).style.outline, t.style.outline = "none", ki(window, "keydown", Ci))
}
function Ci() {
ei && (ei.style.outline = ni, ni = ei = void 0, Ai(window, "keydown", Ci))
}
function Si(t) {
for (; !((t = t.parentNode).offsetWidth && t.offsetHeight || t === document.body););
return t
}
function Ei(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: oi,
TRANSITION: si,
TRANSITION_END: ri,
get: ai,
getStyle: hi,
create: ui,
remove: li,
empty: ci,
toFront: _i,
toBack: di,
hasClass: pi,
addClass: mi,
removeClass: fi,
setClass: gi,
getClass: vi,
setOpacity: yi,
testProp: xi,
setTransform: wi,
setPosition: Pi,
getPosition: Li,
disableTextSelection: Qt,
enableTextSelection: ti,
disableImageDrag: Ti,
enableImageDrag: zi,
preventOutline: Mi,
restoreOutline: Ci,
getSizedParentNode: Si,
getScale: Ei
});
function ki(t, i, e, n) {
if ("object" == typeof i)
for (var o in i) Ii(t, o, i[o], e);
else
for (var s = 0, r = (i = d(i)).length; s < r; s++) Ii(t, i[s], e, n);
return this
}
var Bi = "_leaflet_events";
function Ai(t, i, e, n) {
if ("object" == typeof i)
for (var o in i) Oi(t, o, i[o], e);
else if (i)
for (var s = 0, r = (i = d(i)).length; s < r; s++) Oi(t, i[s], e, n);
else {
for (var a in t[Bi]) Oi(t, a, t[Bi][a]);
delete t[Bi]
}
return this
}
function Ii(i, t, e, n) {
var o = t + u(e) + (n ? "_" + u(n) : "");
if (i[Bi] && i[Bi][o]) return this;
var s = function(t) {
return e.call(n || i, t || window.event)
},
r = s;
bt && 0 === t.indexOf("touch") ? Ft(i, t, s, o) : !Tt || "dblclick" !== t || bt && lt ? "addEventListener" in i ? "mousewheel" === t ? i.addEventListener("onwheel" in i ? "wheel" : "mousewheel", s, !!St && {
passive: !1
}) : "mouseenter" === t || "mouseleave" === t ? (s = function(t) {
t = t || window.event, Yi(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 = Vi && e - Vi;
if (n && 100 < n && n < 500 || t.target._simulatedClick && !t._simulated) return Wi(t);
Vi = e, i(t)
}(t, r)
}), i.addEventListener(t, s, !1)) : "attachEvent" in i && i.attachEvent("on" + t, s) : Jt(i, s, o), i[Bi] = i[Bi] || {}, i[Bi][o] = s
}
function Oi(t, i, e, n) {
var o = i + u(e) + (n ? "_" + u(n) : ""),
s = t[Bi] && t[Bi][o];
if (!s) return this;
bt && 0 === i.indexOf("touch") ? function(t, i, e) {
var n = t["_leaflet_" + i + e];
"touchstart" === i ? t.removeEventListener(It, n, !1) : "touchmove" === i ? t.removeEventListener(Ot, n, !1) : "touchend" === i && (t.removeEventListener(Rt, n, !1), t.removeEventListener(Nt, n, !1))
}(t, i, o) : !Tt || "dblclick" !== i || bt && lt ? "removeEventListener" in t ? "mousewheel" === i ? t.removeEventListener("onwheel" in t ? "wheel" : "mousewheel", s, !!St && {
passive: !1
}) : t.removeEventListener("mouseenter" === i ? "mouseover" : "mouseleave" === i ? "mouseout" : i, s, !1) : "detachEvent" in t && t.detachEvent("on" + i, s) : $t(t, o), t[Bi][o] = null
}
function Ri(t) {
return t.stopPropagation ? t.stopPropagation() : t.originalEvent ? t.originalEvent._stopped = !0 : t.cancelBubble = !0, Ki(t), this
}
function Ni(t) {
return Ii(t, "mousewheel", Ri), this
}
function Di(t) {
return ki(t, "mousedown touchstart dblclick", Ri), Ii(t, "click", Gi), this
}
function ji(t) {
return t.preventDefault ? t.preventDefault() : t.returnValue = !1, this
}
function Wi(t) {
return ji(t), Ri(t), this
}
function Hi(t, i) {
if (!i) return new B(t.clientX, t.clientY);
var e = Ei(i),
n = e.boundingClientRect;
return new B((t.clientX - n.left) / e.x - i.clientLeft, (t.clientY - n.top) / e.y - i.clientTop)
}
var Fi = mt && lt ? 2 * window.devicePixelRatio : ct ? window.devicePixelRatio : 1;
function Ui(t) {
return nt ? t.wheelDeltaY / 2 : t.deltaY && 0 === t.deltaMode ? -t.deltaY / Fi : 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 Vi, qi = {};
function Gi(t) {
qi[t.type] = !0
}
function Ki(t) {
var i = qi[t.type];
return qi[t.type] = !1, i
}
function Yi(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 Xi = (Object.freeze || Object)({
on: ki,
off: Ai,
stopPropagation: Ri,
disableScrollPropagation: Ni,
disableClickPropagation: Di,
preventDefault: ji,
stop: Wi,
getMousePosition: Hi,
getWheelDelta: Ui,
fakeStop: Gi,
skipped: Ki,
isExternalTarget: Yi,
addListener: ki,
removeListener: Ai
}),
Ji = k.extend({
run: function(t, i, e, n) {
this.stop(), this._el = t, this._inProgress = !0, this._duration = e || .25, this._easeOutPower = 1 / Math.max(n || .5, .2), this._startPos = Li(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(), Pi(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)
}
}),
$i = 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 = si && yt && !zt && this.options.zoomAnimation, this._zoomAnimated && (this._createAnimProxy(), ki(this._proxy, ri, 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 Ji, this._panAnim.on({
step: this._onPanTransitionStep,
end: this._onPanTransitionEnd
}, this)), i.noMoveStart || this.fire("movestart"), !1 !== i.animate) {
mi(this._mapPane, "leaflet-pan-anim");
var e = this._getMapPanePos().subtract(t).round();
this._panAnim.run(this._mapPane, e, i.duration || .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 * .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(), li(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) li(this._panes[t]);
return this._layers = [], this._panes = [], delete this._mapPane, delete this._renderer, this
},
createPane: function(t, i) {
var e = ui("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 Hi(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 = ai(t);
if (!i) throw new Error("Map container not found.");
if (i._leaflet_id) throw new Error("Map container is already initialized.");
ki(i, "scroll", this._onScroll, this), this._containerId = u(i)
},
_initLayout: function() {
var t = this._container;
this._fadeAnimated = this.options.fadeAnimation && yt, mi(t, "leaflet-container" + (Tt ? " leaflet-touch" : "") + (Ct ? " leaflet-retina" : "") + (et ? " leaflet-oldie" : "") + (_t ? " leaflet-safari" : "") + (this._fadeAnimated ? " leaflet-fade-anim" : ""));
var i = hi(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), Pi(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 || (mi(t.markerPane, "leaflet-zoom-hide"), mi(t.shadowPane, "leaflet-zoom-hide"))
},
_resetView: function(t, i) {
Pi(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) {
Pi(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 ? Ai : ki;
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 && !Yi(s, t)) break;
if (n.push(e), o) break
}
if (s === this._container) break;
s = s.parentNode
}
return n.length || r || o || !Yi(s, t) || (n = [this]), n
},
_handleDOMEvent: function(t) {
if (this._loaded && !Ki(t)) {
var i = t.type;
"mousedown" !== i && "keypress" !== i && "keyup" !== i && "keydown" !== i || Mi(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) && ji(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 Li(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() {
fi(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 = ui("div", "leaflet-proxy leaflet-zoom-animated");
this._panes.mapPane.appendChild(t), this.on("zoomanim", function(t) {
var i = oi,
e = this._proxy.style[i];
wi(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", this._animMoveEnd, this), this._on("unload", this._destroyAnimProxy, this)
},
_destroyAnimProxy: function() {
li(this._proxy), this.off("load moveend", this._animMoveEnd, this), delete this._proxy
},
_animMoveEnd: function() {
var t = this.getCenter(),
i = this.getZoom();
wi(this._proxy, this.project(t, i), this.getZoomScale(i, 1))
},
_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, mi(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 && fi(this._mapPane, "leaflet-zoom-anim"), this._animatingZoom = !1, this._move(this._animateToCenter, this._animateToZoom), M(function() {
this._moveEnd(!0)
}, this))
}
});
function Qi(t) {
return new te(t)
}
var te = E.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 mi(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 && (li(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()
}
});
$i.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 = ui("div", o + "control-container", this._container);
function t(t, i) {
var e = o + t + " " + o + i;
n[t + i] = ui("div", e, s)
}
t("top", "left"), t("top", "right"), t("bottom", "left"), t("bottom", "right")
},
_clearControlPos: function() {
for (var t in this._controlCorners) li(this._controlCorners[t]);
li(this._controlContainer), delete this._controlCorners, delete this._controlContainer
}
});
var ie = te.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 te.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() {
mi(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 ? (mi(this._section, "leaflet-control-layers-scrollbar"), this._section.style.height = t + "px") : fi(this._section, "leaflet-control-layers-scrollbar"), this._checkDisabledLayers(), this
},
collapse: function() {
return fi(this._container, "leaflet-control-layers-expanded"), this
},
_initLayout: function() {
var t = "leaflet-control-layers",
i = this._container = ui("div", t),
e = this.options.collapsed;
i.setAttribute("aria-haspopup", !0), Di(i), Ni(i);
var n = this._section = ui("section", t + "-list");
e && (this._map.on("click", this.collapse, this), st || ki(i, {
mouseenter: this.expand,
mouseleave: this.collapse
}, this));
var o = this._layersLink = ui("a", t + "-toggle", i);
o.href = "#", o.title = "Layers", Tt ? (ki(o, "click", Wi), ki(o, "click", this.expand, this)) : ki(o, "focus", this.expand, this), e || this.expand(), this._baseLayersList = ui("div", t + "-base", n), this._separator = ui("div", t + "-separator", n), this._overlaysList = ui("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;
ci(this._baseLayersList), ci(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 = '",
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), ki(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()
}
}),
ee = te.extend({
options: {
position: "topleft",
zoomInText: "+",
zoomInTitle: "Zoom in",
zoomOutText: "−",
zoomOutTitle: "Zoom out"
},
onAdd: function(t) {
var i = "leaflet-control-zoom",
e = ui("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 = ui("a", e, n);
return s.innerHTML = t, s.href = "#", s.title = i, s.setAttribute("role", "button"), s.setAttribute("aria-label", i), Di(s), ki(s, "click", Wi), ki(s, "click", o, this), ki(s, "click", this._refocusOnMap, this), s
},
_updateDisabled: function() {
var t = this._map,
i = "leaflet-disabled";
fi(this._zoomInButton, i), fi(this._zoomOutButton, i), !this._disabled && t._zoom !== t.getMinZoom() || mi(this._zoomOutButton, i), !this._disabled && t._zoom !== t.getMaxZoom() || mi(this._zoomInButton, i)
}
});
$i.mergeOptions({
zoomControl: !0
}), $i.addInitHook(function() {
this.options.zoomControl && (this.zoomControl = new ee, this.addControl(this.zoomControl))
});
var ne = te.extend({
options: {
position: "bottomleft",
maxWidth: 100,
metric: !0,
imperial: !0
},
onAdd: function(t) {
var i = "leaflet-control-scale",
e = ui("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 = ui("div", i, e)), t.imperial && (this._iScale = ui("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)
}
}),
oe = te.extend({
options: {
position: "bottomright",
prefix: 'Leaflet'
},
initialize: function(t) {
p(this, t), this._attributions = {}
},
onAdd: function(t) {
for (var i in (t.attributionControl = this)._container = ui("div", "leaflet-control-attribution"), Di(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(" | ")
}
}
});
$i.mergeOptions({
attributionControl: !0
}), $i.addInitHook(function() {
this.options.attributionControl && (new oe).addTo(this)
});
te.Layers = ie, te.Zoom = ee, te.Scale = ne, te.Attribution = oe, Qi.layers = function(t, i, e) {
return new ie(t, i, e)
}, Qi.zoom = function(t) {
return new ee(t)
}, Qi.scale = function(t) {
return new ne(t)
}, Qi.attribution = function(t) {
return new oe(t)
};
var se = E.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
}
});
se.addTo = function(t, i) {
return t.addHandler(i, this), this
};
var re, ae = {
Events: Z
},
he = Tt ? "touchstart mousedown" : "mousedown",
ue = {
mousedown: "mouseup",
touchstart: "touchend",
pointerdown: "touchend",
MSPointerDown: "touchend"
},
le = {
mousedown: "mousemove",
touchstart: "touchmove",
pointerdown: "touchmove",
MSPointerDown: "touchmove"
},
ce = 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 || (ki(this._dragStartTarget, he, this._onDown, this), this._enabled = !0)
},
disable: function() {
this._enabled && (ce._dragging === this && this.finishDrag(), Ai(this._dragStartTarget, he, this._onDown, this), this._enabled = !1, this._moved = !1)
},
_onDown: function(t) {
if (!t._simulated && this._enabled && (this._moved = !1, !pi(this._element, "leaflet-zoom-anim") && !(ce._dragging || t.shiftKey || 1 !== t.which && 1 !== t.button && !t.touches || ((ce._dragging = this)._preventOutline && Mi(this._element), Ti(), Qt(), this._moving)))) {
this.fire("down");
var i = t.touches ? t.touches[0] : t,
e = Si(this._element);
this._startPoint = new B(i.clientX, i.clientY), this._parentScale = Ei(e), ki(document, le[t.type], this._onMove, this), ki(document, ue[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, ji(t), this._moved || (this.fire("dragstart"), this._moved = !0, this._startPos = Li(this._element).subtract(e), mi(document.body, "leaflet-dragging"), this._lastTarget = t.target || t.srcElement, window.SVGElementInstance && this._lastTarget instanceof SVGElementInstance && (this._lastTarget = this._lastTarget.correspondingUseElement), mi(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), Pi(this._element, this._newPos), this.fire("drag", t)
},
_onUp: function(t) {
!t._simulated && this._enabled && this.finishDrag()
},
finishDrag: function() {
for (var t in fi(document.body, "leaflet-dragging"), this._lastTarget && (fi(this._lastTarget, "leaflet-drag-target"), this._lastTarget = null), le) Ai(document, le[t], this._onMove, this), Ai(document, ue[t], this._onUp, this);
zi(), ti(), this._moved && this._moving && (C(this._animRequest), this.fire("dragend", {
distance: this._newPos.distanceTo(this._startPos)
})), this._moving = !1, ce._dragging = !1
}
});
function _e(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 = ge(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 de(t, i, e) {
return Math.sqrt(ge(t, i, e, !0))
}
function pe(t, i, e, n, o) {
var s, r, a, h = n ? re : fe(t, e),
u = fe(i, e);
for (re = u;;) {
if (!(h | u)) return [t, i];
if (h & u) return !1;
a = fe(r = me(t, i, s = h || u, e, o), e), s === h ? (t = r, h = a) : (i = r, u = a)
}
}
function me(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 fe(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 ge(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 ve(t) {
return !v(t[0]) || "object" != typeof t[0][0] && void 0 !== t[0][0]
}
function ye(t) {
return console.warn("Deprecated use of _flat, please use L.LineUtil.isFlat instead."), ve(t)
}
var xe = (Object.freeze || Object)({
simplify: _e,
pointToSegmentDistance: de,
closestPointOnSegment: function(t, i, e) {
return ge(t, i, e)
},
clipSegment: pe,
_getEdgeIntersection: me,
_getBitCode: fe,
_sqClosestPointOnSegment: ge,
isFlat: ve,
_flat: ye
});
function we(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 = fe(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 = me(h, a, l, i, e))._code = fe(c, i), n.push(c)) : (h._code & l && ((c = me(h, a, l, i, e))._code = fe(c, i), n.push(c)), n.push(a));
t = n
}
return t
}
var Pe, Le = (Object.freeze || Object)({
clipPolygon: we
}),
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])
},
Te = {
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 = .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)
}
},
ze = (Object.freeze || Object)({
LonLat: be,
Mercator: Te,
SphericalMercator: q
}),
Me = h({}, U, {
code: "EPSG:3395",
projection: Te,
transformation: (Pe = .5 / (Math.PI * Te.R), K(Pe, .5, -Pe, .5))
}),
Ce = h({}, U, {
code: "EPSG:4326",
projection: be,
transformation: K(1 / 180, 1, -1 / 180, .5)
}),
Se = 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 = Me, F.EPSG3857 = X, F.EPSG900913 = J, F.EPSG4326 = Ce, F.Simple = Se;
var Ee = 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
})
}
}
});
$i.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 = Ee.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)
}
}),
ke = 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
}
}),
Be = E.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 Ae = Be.extend({
options: {
iconUrl: "marker-icon.png",
iconRetinaUrl: "marker-icon-2x.png",
shadowUrl: "marker-shadow.png",
iconSize: [64, 64],
iconAnchor: [32, 32],
popupAnchor: [1, -34],
tooltipAnchor: [16, -28],
shadowSize: [41, 41]
},
_getIconUrl: function(t) {
return Ae.imagePath || (Ae.imagePath = this._detectIconPath()), (this.options.imagePath || Ae.imagePath) + Be.prototype._getIconUrl.call(this, t)
},
_detectIconPath: function() {
var t = ui("div", "leaflet-default-icon-path", document.body),
i = hi(t, "background-image") || hi(t, "backgroundImage");
return document.body.removeChild(t), i = null === i || 0 !== i.indexOf("url") ? "" : i.replace(/^url\(["']?/, "").replace(/marker-icon\.png["']?\)$/, "")
}
}),
Ie = se.extend({
initialize: function(t) {
this._marker = t
},
addHooks: function() {
var t = this._marker._icon;
this._draggable || (this._draggable = new ce(t, t, !0)), this._draggable.on({
dragstart: this._onDragStart,
predrag: this._onPreDrag,
drag: this._onDrag,
dragend: this._onDragEnd
}, this).enable(), mi(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 && fi(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 = Li(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), Pi(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 = Li(i._icon),
o = i._map.layerPointToLatLng(n);
e && Pi(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)
}
}),
Oe = Ee.extend({
options: {
icon: new Ae,
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 || "")), mi(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 && (mi(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
}), li(this._icon), this.removeInteractiveTarget(this._icon), this._icon = null
},
_removeShadow: function() {
this._shadow && li(this._shadow), this._shadow = null
},
_setPos: function(t) {
this._icon && Pi(this._icon, t), this._shadow && Pi(this._shadow, t), this._zIndex = t.y + this.options.zIndexOffset, this._resetZIndex()
},
_updateZIndex: function(t) {
this._icon && (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 && (mi(this._icon, "leaflet-interactive"), this.addInteractiveTarget(this._icon), Ie)) {
var t = this.options.draggable;
this.dragging && (t = this.dragging.enabled(), this.dragging.disable()), this.dragging = new Ie(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 && yi(this._icon, t), this._shadow && yi(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 Re = Ee.extend({
options: {
stroke: !0,
color: "#3388ff",
weight: 3,
opacity: 1,
lineCap: "round",
lineJoin: "round",
dashArray: null,
dashOffset: null,
fill: !1,
fillColor: null,
fillOpacity: .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 && 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
}
}),
Ne = Re.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) {
var i = this._latlng;
return this._latlng = W(t), this.redraw(), this.fire("move", {
oldLatLng: i,
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 Re.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 De = Ne.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: Re.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 je = Re.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 = ge, 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 ve(this._latlngs) ? this._latlngs : this._latlngs[0]
},
_convertLatLngs: function(t) {
for (var i = [], e = ve(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 = pe(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] = _e(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) && de(t, a[o], a[n]) <= h) return !0;
return !1
}
});
je._flat = ye;
var We = je.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 = je.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) {
je.prototype._setLatLngs.call(this, t), ve(this._latlngs) && (this._latlngs = [this._latlngs])
},
_defaultShape: function() {
return ve(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 = we(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 || je.prototype._containsPoint.call(this, t, !0)
}
});
var He = ke.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 = Fe(t, s);
return r ? (r.feature = Xe(t), r.defaultOptions = r.options, this.resetStyle(r), s.onEachFeature && s.onEachFeature(t, r), this.addLayer(r)) : this
},
resetStyle: function(t) {
return void 0 === t ? this.eachLayer(this.resetStyle, this) : (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 Fe(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 || Ve;
if (!a && !r) return null;
switch (r.type) {
case "Point":
return Ue(u, t, e = l(a), i);
case "MultiPoint":
for (o = 0, s = a.length; o < s; o++) e = l(a[o]), h.push(Ue(u, t, e, i));
return new ke(h);
case "LineString":
case "MultiLineString":
return n = qe(a, "LineString" === r.type ? 0 : 1, l), new je(n, i);
case "Polygon":
case "MultiPolygon":
return n = qe(a, "Polygon" === r.type ? 1 : 2, l), new We(n, i);
case "GeometryCollection":
for (o = 0, s = r.geometries.length; o < s; o++) {
var c = Fe({
geometry: r.geometries[o],
type: "Feature",
properties: t.properties
}, i);
c && h.push(c)
}
return new ke(h);
default:
throw new Error("Invalid GeoJSON object.")
}
}
function Ue(t, i, e, n) {
return t ? t(i, e) : new Oe(e, n && n.markersInheritOptions && n)
}
function Ve(t) {
return new j(t[1], t[0], t[2])
}
function qe(t, i, e) {
for (var n, o = [], s = 0, r = t.length; s < r; s++) n = i ? qe(t[s], i - 1, e) : (e || Ve)(t[s]), o.push(n);
return o
}
function Ge(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 Ke(t, i, e, n) {
for (var o = [], s = 0, r = t.length; s < r; s++) o.push(i ? Ke(t[s], i - 1, e, n) : Ge(t[s], n));
return !i && e && o.push(o[0]), o
}
function Ye(t, i) {
return t.feature ? h({}, t.feature, {
geometry: i
}) : Xe(i)
}
function Xe(t) {
return "Feature" === t.type || "FeatureCollection" === t.type ? t : {
type: "Feature",
properties: {},
geometry: t
}
}
var Je = {
toGeoJSON: function(t) {
return Ye(this, {
type: "Point",
coordinates: Ge(this.getLatLng(), t)
})
}
};
function $e(t, i) {
return new He(t, i)
}
Oe.include(Je), De.include(Je), Ne.include(Je), je.include({
toGeoJSON: function(t) {
var i = !ve(this._latlngs);
return Ye(this, {
type: (i ? "Multi" : "") + "LineString",
coordinates: Ke(this._latlngs, i ? 1 : 0, !1, t)
})
}
}), We.include({
toGeoJSON: function(t) {
var i = !ve(this._latlngs),
e = i && !ve(this._latlngs[0]),
n = Ke(this._latlngs, e ? 2 : i ? 1 : 0, !0, t);
return i || (n = [n]), Ye(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)
}), Ye(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 = Xe(i);
"FeatureCollection" === e.type ? s.push.apply(s, e.features) : s.push(e)
}
}
}), o ? Ye(this, {
geometries: s,
type: "GeometryCollection"
}) : {
type: "FeatureCollection",
features: s
}
}
});
var Qe = $e,
tn = Ee.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 && (mi(this._image, "leaflet-interactive"), this.addInteractiveTarget(this._image)), this.getPane().appendChild(this._image), this._reset()
},
onRemove: function() {
li(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 && _i(this._image), this
},
bringToBack: function() {
return this._map && di(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 : ui("img");
mi(i, "leaflet-image-layer"), this._zoomAnimated && mi(i, "leaflet-zoom-animated"), this.options.className && mi(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;
wi(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();
Pi(t, i.min), t.style.width = e.x + "px", t.style.height = e.y + "px"
},
_updateOpacity: function() {
yi(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)
}
}),
en = tn.extend({
options: {
autoplay: !0,
loop: !0,
keepAspectRatio: !0
},
_initImage: function() {
var t = "VIDEO" === this._url.tagName,
i = this._image = t ? this._url : ui("video");
if (mi(i, "leaflet-image-layer"), this._zoomAnimated && mi(i, "leaflet-zoom-animated"), this.options.className && mi(i, this.options.className), 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 = ui("source");
r.src = this._url[s], i.appendChild(r)
}
}
}
});
var nn = tn.extend({
_initImage: function() {
var t = this._image = this._url;
mi(t, "leaflet-image-layer"), this._zoomAnimated && mi(t, "leaflet-zoom-animated"), this.options.className && mi(t, this.options.className), t.onselectstart = l, t.onmousemove = l
}
});
var on = Ee.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 && yi(this._container, 0), clearTimeout(this._removeTimeout), this.getPane().appendChild(this._container), this.update(), t._fadeAnimated && yi(this._container, 1), this.bringToFront()
},
onRemove: function(t) {
t._fadeAnimated ? (yi(this._container, 0), this._removeTimeout = setTimeout(a(li, void 0, this._container), 200)) : li(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 && _i(this._container), this
},
bringToBack: function() {
return this._map && di(this._container), this
},
_prepareOpen: function(t, i, e) {
if (i instanceof Ee || (e = i, i = t), i instanceof ke)
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 ? Pi(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]
}
}),
sn = on.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) {
on.prototype.onAdd.call(this, t), t.fire("popupopen", {
popup: this
}), this._source && (this._source.fire("popupopen", {
popup: this
}, !0), this._source instanceof Re || this._source.on("preclick", Ri))
},
onRemove: function(t) {
on.prototype.onRemove.call(this, t), t.fire("popupclose", {
popup: this
}), this._source && (this._source.fire("popupclose", {
popup: this
}, !0), this._source instanceof Re || this._source.off("preclick", Ri))
},
getEvents: function() {
var t = on.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 = ui("div", t + " " + (this.options.className || "") + " leaflet-zoom-animated"),
e = this._wrapper = ui("div", t + "-content-wrapper", i);
if (this._contentNode = ui("div", t + "-content", e), Di(e), Ni(this._contentNode), ki(e, "contextmenu", Ri), this._tipContainer = ui("div", t + "-tip-container", i), this._tip = ui("div", t + "-tip", this._tipContainer), this.options.closeButton) {
var n = this._closeButton = ui("a", t + "-close-button", i);
n.href = "#close", n.innerHTML = "×", ki(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", mi(t, s)) : fi(t, s), this._containerWidth = this._container.offsetWidth
},
_animateZoom: function(t) {
var i = this._map._latLngToNewLayerPoint(this._latlng, t.zoom, t.center),
e = this._getAnchor();
Pi(this._container, i.add(e))
},
_adjustPan: function() {
if (this.options.autoPan) {
this._map._panAnim && this._map._panAnim.stop();
var t = this._map,
i = parseInt(hi(this._container, "marginBottom"), 10) || 0,
e = this._container.offsetHeight + i,
n = this._containerWidth,
o = new B(this._containerLeft, -e - this._containerBottom);
o._add(Li(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(), Wi(t)
},
_getAnchor: function() {
return I(this._source && this._source._getPopupAnchor ? this._source._getPopupAnchor() : [0, 0])
}
});
$i.mergeOptions({
closePopupOnClick: !0
}), $i.include({
openPopup: function(t, i, e) {
return t instanceof sn || (t = new sn(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
}
}), Ee.include({
bindPopup: function(t, i) {
return t instanceof sn ? (p(t, i), (this._popup = t)._source = this) : (this._popup && !i || (this._popup = new sn(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 && (Wi(t), i instanceof Re ? 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 rn = on.extend({
options: {
pane: "tooltipPane",
offset: [0, 0],
direction: "auto",
permanent: !1,
sticky: !1,
interactive: !1,
opacity: .9
},
onAdd: function(t) {
on.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) {
on.prototype.onRemove.call(this, t), t.fire("tooltipclose", {
tooltip: this
}), this._source && this._source.fire("tooltipclose", {
tooltip: this
}, !0)
},
getEvents: function() {
var t = on.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 = ui("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))), fi(e, "leaflet-tooltip-right"), fi(e, "leaflet-tooltip-left"), fi(e, "leaflet-tooltip-top"), fi(e, "leaflet-tooltip-bottom"), mi(e, "leaflet-tooltip-" + s), Pi(e, t)
},
_updatePosition: function() {
var t = this._map.latLngToLayerPoint(this._latlng);
this._setPosition(t)
},
setOpacity: function(t) {
this.options.opacity = t, this._container && yi(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])
}
});
$i.include({
openTooltip: function(t, i, e) {
return t instanceof rn || (t = new rn(e).setContent(t)), i && t.setLatLng(i), this.hasLayer(t) ? this : this.addLayer(t)
},
closeTooltip: function(t) {
return t && this.removeLayer(t), this
}
}), Ee.include({
bindTooltip: function(t, i) {
return t instanceof rn ? (p(t, i), (this._tooltip = t)._source = this) : (this._tooltip && !i || (this._tooltip = new rn(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 && (mi(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 && (fi(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 an = Be.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 ? (ci(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
}
});
Be.Default = Ae;
var hn = Ee.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(), li(this._container), t._removeZoomLimit(this), this._container = null, this._tileZoom = void 0
},
bringToFront: function() {
return this._map && (_i(this._container), this._setAutoZIndex(Math.max)), this
},
bringToBack: function() {
return this._map && (di(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) {
yi(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);
yi(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 = ui("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)) : (li(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 = ui("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) li(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 ? wi(t.el, o, n) : Pi(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 && (li(i.el), delete this._tiles[t], this.fire("tileunload", {
tile: i.el,
coords: this._keyToTileCoords(t)
}))
},
_initTile: function(t) {
mi(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 && yi(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)), Pi(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 ? (yi(e.el, 0), C(this._fadeFrame), this._fadeFrame = M(this._updateOpacity, this)) : (e.active = !0, this._pruneTiles()), i || (mi(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 un = hn.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 ki(e, "load", a(this._tileOnLoad, this, i, e)), ki(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, li(i), delete this._tiles[t]))
},
_removeTile: function(t) {
var i = this._tiles[t];
if (i) return ht || i.el.setAttribute("src", x), hn.prototype._removeTile.call(this, t)
},
_tileReady: function(t, i, e) {
if (this._map && (!e || e.getAttribute("src") !== x)) return hn.prototype._tileReady.call(this, t, i, e)
}
});
function ln(t, i) {
return new un(t, i)
}
var cn = un.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, un.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 === Ce ? [o.y, o.x, s.y, s.x] : [o.x, o.y, s.x, s.y]).join(","),
a = un.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
}
});
un.WMS = cn, ln.wms = function(t, i) {
return new cn(t, i)
};
var _n = Ee.extend({
options: {
padding: .1,
tolerance: 0
},
initialize: function(t) {
p(this, t), u(this), this._layers = this._layers || {}
},
onAdd: function() {
this._container || (this._initContainer(), this._zoomAnimated && mi(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 = Li(this._container),
o = this._map.getSize().multiplyBy(.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 ? wi(this._container, a, e) : Pi(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()
}
}),
dn = _n.extend({
getEvents: function() {
var t = _n.prototype.getEvents.call(this);
return t.viewprereset = this._onViewPreReset, t
},
_onViewPreReset: function() {
this._postponeUpdatePaths = !0
},
onAdd: function() {
_n.prototype.onAdd.call(this), this._draw()
},
_initContainer: function() {
var t = this._container = document.createElement("canvas");
ki(t, "mousemove", this._onMouseMove, this), ki(t, "click dblclick mousedown mouseup contextmenu", this._onClick, this), ki(t, "mouseout", this._handleMouseOut, this), this._ctx = t.getContext("2d")
},
_destroyContainer: function() {
C(this._redrawRequest), delete this._ctx, li(this._container), Ai(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) {
_n.prototype._update.call(this);
var t = this._bounds,
i = this._container,
e = t.getSize(),
n = Ct ? 2 : 1;
Pi(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() {
_n.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 && (Gi(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 && (fi(this._container, "leaflet-interactive"), this._fireEvent([i], t, "mouseout"), this._hoveredLayer = null, this._mouseHoverThrottled = !1)
},
_handleMouseHover: function(t, i) {
if (!this._mouseHoverThrottled) {
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 && (mi(this._container, "leaflet-interactive"), this._fireEvent([n], t, "mouseover"), this._hoveredLayer = n)), this._hoveredLayer && this._fireEvent([this._hoveredLayer], t), this._mouseHoverThrottled = !0, setTimeout(L.bind(function() {
this._mouseHoverThrottled = !1
}, this), 32)
}
},
_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 pn(t) {
return Et ? new dn(t) : null
}
var mn = function() {
try {
return document.namespaces.add("lvml", "urn:schemas-microsoft-com:vml"),
function(t) {
return document.createElement("')
}
} catch (t) {
return function(t) {
return document.createElement("<" + t + ' xmlns="urn:schemas-microsoft.com:vml" class="lvml">')
}
}
}(),
fn = {
_initContainer: function() {
this._container = ui("div", "leaflet-vml-container")
},
_update: function() {
this._map._animatingZoom || (_n.prototype._update.call(this), this.fire("update"))
},
_initPath: function(t) {
var i = t._container = mn("shape");
mi(i, "leaflet-vml-shape " + (this.options.className || "")), i.coordsize = "1 1", t._path = mn("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;
li(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 = mn("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 = mn("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) {
_i(t._container)
},
_bringToBack: function(t) {
di(t._container)
}
},
gn = kt ? mn : $,
vn = _n.extend({
getEvents: function() {
var t = _n.prototype.getEvents.call(this);
return t.zoomstart = this._onZoomStart, t
},
_initContainer: function() {
this._container = gn("svg"), this._container.setAttribute("pointer-events", "none"), this._rootGroup = gn("g"), this._container.appendChild(this._rootGroup)
},
_destroyContainer: function() {
li(this._container), Ai(this._container), delete this._container, delete this._rootGroup, delete this._svgSize
},
_onZoomStart: function() {
this._update()
},
_update: function() {
if (!this._map._animatingZoom || !this._bounds) {
_n.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)), Pi(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 = gn("path");
t.options.className && mi(i, t.options.className), t.options.interactive && mi(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) {
li(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) {
_i(t._path)
},
_bringToBack: function(t) {
di(t._path)
}
});
function yn(t) {
return Zt || kt ? new vn(t) : null
}
kt && vn.include(fn), $i.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 && pn(t) || yn(t)
}
});
var xn = We.extend({
initialize: function(t, i) {
We.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()]
}
});
vn.create = gn, vn.pointsToPath = Q, He.geometryToLayer = Fe, He.coordsToLatLng = Ve, He.coordsToLatLngs = qe, He.latLngToCoords = Ge, He.latLngsToCoords = Ke, He.getFeature = Ye, He.asFeature = Xe, $i.mergeOptions({
boxZoom: !0
});
var wn = se.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() {
ki(this._container, "mousedown", this._onMouseDown, this)
},
removeHooks: function() {
Ai(this._container, "mousedown", this._onMouseDown, this)
},
moved: function() {
return this._moved
},
_destroy: function() {
li(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(), Qt(), Ti(), this._startPoint = this._map.mouseEventToContainerPoint(t), ki(document, {
contextmenu: Wi,
mousemove: this._onMouseMove,
mouseup: this._onMouseUp,
keydown: this._onKeyDown
}, this)
},
_onMouseMove: function(t) {
this._moved || (this._moved = !0, this._box = ui("div", "leaflet-zoom-box", this._container), mi(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();
Pi(this._box, i.min), this._box.style.width = e.x + "px", this._box.style.height = e.y + "px"
},
_finish: function() {
this._moved && (li(this._box), fi(this._container, "leaflet-crosshair")), ti(), zi(), Ai(document, {
contextmenu: Wi,
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()
}
});
$i.addInitHook("addHandler", "boxZoom", wn), $i.mergeOptions({
doubleClickZoom: !0
});
var Pn = se.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)
}
});
$i.addInitHook("addHandler", "doubleClickZoom", Pn), $i.mergeOptions({
dragging: !0,
inertia: !rt,
inertiaDeceleration: 3400,
inertiaMaxSpeed: 1 / 0,
easeLinearity: .2,
worldCopyJump: !1,
maxBoundsViscosity: 0
});
var Ln = se.extend({
addHooks: function() {
if (!this._draggable) {
var t = this._map;
this._draggable = new ce(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))
}
mi(this._map._container, "leaflet-grab leaflet-touch-drag"), this._draggable.enable(), this._positions = [], this._times = []
},
removeHooks: function() {
fi(this._map._container, "leaflet-grab"), fi(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")
}
}
});
$i.addInitHook("addHandler", "dragging", Ln), $i.mergeOptions({
keyboard: !0,
keyboardPanDelta: 80
});
var bn = se.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"), ki(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(), Ai(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() {
ki(document, "keydown", this._onKeyDown, this)
},
_removeHooks: function() {
Ai(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()
}
Wi(t)
}
}
});
$i.addInitHook("addHandler", "keyboard", bn), $i.mergeOptions({
scrollWheelZoom: !0,
wheelDebounceTime: 40,
wheelPxPerZoomLevel: 60
});
var Tn = se.extend({
addHooks: function() {
ki(this._map._container, "mousewheel", this._onWheelScroll, this), this._delta = 0
},
removeHooks: function() {
Ai(this._map._container, "mousewheel", this._onWheelScroll, this)
},
_onWheelScroll: function(t) {
var i = Ui(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), Wi(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))
}
});
$i.addInitHook("addHandler", "scrollWheelZoom", Tn), $i.mergeOptions({
tap: !0,
tapTolerance: 15
});
var zn = se.extend({
addHooks: function() {
ki(this._map._container, "touchstart", this._onDown, this)
},
removeHooks: function() {
Ai(this._map._container, "touchstart", this._onDown, this)
},
_onDown: function(t) {
if (t.touches) {
if (ji(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() && mi(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), ki(document, {
touchmove: this._onMove,
touchend: this._onUp
}, this)
}
},
_onUp: function(t) {
if (clearTimeout(this._holdTimeout), Ai(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() && fi(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 && !bt && $i.addInitHook("addHandler", "tap", zn), $i.mergeOptions({
touchZoom: Tt && !rt,
bounceAtZoomLimits: !0
});
var Mn = se.extend({
addHooks: function() {
mi(this._map._container, "leaflet-touch-zoom"), ki(this._map._container, "touchstart", this._onTouchStart, this)
},
removeHooks: function() {
fi(this._map._container, "leaflet-touch-zoom"), Ai(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(), ki(document, "touchmove", this._onTouchMove, this), ki(document, "touchend", this._onTouchEnd, this), ji(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), ji(t)
}
},
_onTouchEnd: function() {
this._moved && this._zooming ? (this._zooming = !1, C(this._animRequest), Ai(document, "touchmove", this._onTouchMove), Ai(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
}
});
$i.addInitHook("addHandler", "touchZoom", Mn), $i.BoxZoom = wn, $i.DoubleClickZoom = Pn, $i.Drag = Ln, $i.Keyboard = bn, $i.ScrollWheelZoom = Tn, $i.Tap = zn, $i.TouchZoom = Mn, Object.freeze = i, t.version = "1.6.0", t.Control = te, t.control = Qi, t.Browser = At, t.Evented = k, t.Mixin = ae, t.Util = S, t.Class = E, t.Handler = se, t.extend = h, t.bind = a, t.stamp = u, t.setOptions = p, t.DomEvent = Xi, t.DomUtil = Zi, t.PosAnimation = Ji, t.Draggable = ce, t.LineUtil = xe, t.PolyUtil = Le, t.Point = B, t.point = I, t.Bounds = O, t.bounds = R, t.Transformation = G, t.transformation = K, t.Projection = ze, t.LatLng = j, t.latLng = W, t.LatLngBounds = N, t.latLngBounds = D, t.CRS = F, t.GeoJSON = He, t.geoJSON = $e, t.geoJson = Qe, t.Layer = Ee, t.LayerGroup = Ze, t.layerGroup = function(t, i) {
return new Ze(t, i)
}, t.FeatureGroup = ke, t.featureGroup = function(t) {
return new ke(t)
}, t.ImageOverlay = tn, t.imageOverlay = function(t, i, e) {
return new tn(t, i, e)
}, t.VideoOverlay = en, t.videoOverlay = function(t, i, e) {
return new en(t, i, e)
}, t.SVGOverlay = nn, t.svgOverlay = function(t, i, e) {
return new nn(t, i, e)
}, t.DivOverlay = on, t.Popup = sn, t.popup = function(t, i) {
return new sn(t, i)
}, t.Tooltip = rn, t.tooltip = function(t, i) {
return new rn(t, i)
}, t.Icon = Be, t.icon = function(t) {
return new Be(t)
}, t.DivIcon = an, t.divIcon = function(t) {
return new an(t)
}, t.Marker = Oe, t.marker = function(t, i) {
return new Oe(t, i)
}, t.TileLayer = un, t.tileLayer = ln, t.GridLayer = hn, t.gridLayer = function(t) {
return new hn(t)
}, t.SVG = vn, t.svg = yn, t.Renderer = _n, t.Canvas = dn, t.canvas = pn, t.Path = Re, t.CircleMarker = Ne, t.circleMarker = function(t, i) {
return new Ne(t, i)
}, t.Circle = De, t.circle = function(t, i, e) {
return new De(t, i, e)
}, t.Polyline = je, t.polyline = function(t, i) {
return new je(t, i)
}, t.Polygon = We, t.polygon = function(t, i) {
return new We(t, i)
}, t.Rectangle = xn, t.rectangle = function(t, i) {
return new xn(t, i)
}, t.Map = $i, t.map = function(t, i) {
return new $i(t, i)
};
var Cn = window.L;
t.noConflict = function() {
return window.L = Cn, this
}, window.L = t
});