Skip to content

Instantly share code, notes, and snippets.

@ndobie
Last active March 4, 2016 19:46
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save ndobie/855c4bc7e1c617cea37a to your computer and use it in GitHub Desktop.
Save ndobie/855c4bc7e1c617cea37a to your computer and use it in GitHub Desktop.
Static Leaflet Frame with Links
license: mit
border: no
height: 700
scrolling: yes

The best part about this chart is that it appears as a picture, an interactive one. I have an oversimplified geoJson shape file and I prevent the user from tapping, scrolling, or otherwise moving the imamge. Without background map tiles, this appears the same as a stactic image, only this image has links to other pages! See the website this is on for the best experiance, but this is still good here too. I also enjoy the tooltip demographic information as the user hovers around the areas.

function getCounties() { return mycounties };
var mycounties = [{"type": "FeatureCollection", "features": [{ "type": "Feature", "properties": { "name": "Harding", "geoid2": "35021", "area": "2125.44", "population": "655", "popsqmile": "0.308171484", "housing": "493", "medianage": "56.7", "under18": "100", "over65": "172", "white": "629", "hispanic": "242", "englishonly": "442", "population25": "490", "highschool": "439", "bachelor": "119", "laborforce": "325", "unemploy": "4.3", "personalinc": "53296", "sales2014": "41999865.79" }, "geometry": { "type": "Polygon", "coordinates": [[[-104.367, 35.781], [-104.365, 35.798], [-104.371, 35.805], [-104.364, 35.813], [-104.375, 35.819], [-104.378, 35.824], [-104.367, 35.829], [-104.38, 35.836], [-104.366, 35.839], [-104.366, 35.843], [-104.382, 35.843], [-104.376, 35.85], [-104.39, 35.858], [-104.38, 35.865], [-104.38, 35.874], [-104.373, 35.883], [-104.359, 35.886], [-104.366, 35.892], [-104.366, 35.898], [-104.351, 35.899], [-104.354, 35.908], [-104.346, 35.909], [-104.346, 35.915], [-104.353, 35.922], [-104.352, 35.94], [-104.342, 35.94], [-104.34, 35.945], [-104.352, 35.954], [-104.336, 35.956], [-104.327, 35.961], [-104.342, 35.974], [-104.356, 35.983], [-104.341, 35.992], [-104.34, 36], [-104.365, 36.013], [-104.361, 36.024], [-104.361, 36.035], [-104.366, 36.044], [-104.379, 36.048], [-104.379, 36.055], [-104.37, 36.066], [-104.377, 36.067], [-104.381, 36.076], [-104.39, 36.082], [-104.386, 36.089], [-104.401, 36.092], [-104.397, 36.099], [-104.403, 36.117], [-104.415, 36.124], [-104.409, 36.132], [-104.417, 36.136], [-104.419, 36.145], [-104.408, 36.147], [-104.404, 36.155], [-104.42, 36.168], [-104.414, 36.177], [-104.425, 36.185], [-104.427, 36.178], [-104.436, 36.177], [-104.434, 36.19], [-104.437, 36.196], [-104.43, 36.214], [-104.436, 36.219], [-104.251, 36.218], [-104.203, 36.218], [-104.009, 36.218], [-104.009, 36.175], [-103.794, 36.174], [-103.794, 36.086], [-103.751, 36.086], [-103.626, 36.086], [-103.598, 36.087], [-103.365, 36.086], [-103.365, 35.999], [-103.375, 35.999], [-103.375, 35.943], [-103.375, 35.928], [-103.375, 35.74], [-103.375, 35.681], [-103.375, 35.652], [-103.379, 35.652], [-103.379, 35.578], [-103.38, 35.521], [-103.379, 35.497], [-103.38, 35.398], [-103.39, 35.39], [-103.477, 35.39], [-103.506, 35.39], [-103.588, 35.39], [-103.637, 35.39], [-103.637, 35.422], [-103.725, 35.422], [-103.835, 35.588], [-103.914, 35.708], [-103.977, 35.802], [-104.021, 35.781], [-104.093, 35.781], [-104.196, 35.782], [-104.24, 35.781], [-104.255, 35.782], [-104.367, 35.781]]] } },
{ "type": "Feature", "properties": { "name": "Sierra", "geoid2": "35051", "area": "4178.96", "population": "11774", "popsqmile": "2.817447403", "housing": "8321", "medianage": "55.5", "under18": "1780", "over65": "3954", "white": "10777", "hispanic": "3394", "englishonly": "8554", "population25": "9222", "highschool": "7827", "bachelor": "1759", "laborforce": "3849", "unemploy": "8.8", "personalinc": "34621", "sales2014": "200225106.8" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.373, 33.48], [-106.372, 33.391], [-106.346, 33.391], [-106.344, 33.25], [-106.341, 33.136], [-106.341, 33.119], [-106.34, 33.053], [-106.532, 32.973], [-106.626, 32.934], [-106.752, 32.88], [-106.888, 32.823], [-106.888, 32.779], [-106.998, 32.779], [-107.092, 32.779], [-107.167, 32.779], [-107.299, 32.781], [-107.299, 32.606], [-107.465, 32.605], [-107.534, 32.605], [-107.608, 32.605], [-107.717, 32.623], [-107.732, 32.627], [-107.734, 32.643], [-107.731, 32.653], [-107.725, 32.661], [-107.724, 32.674], [-107.728, 32.68], [-107.727, 32.692], [-107.72, 32.697], [-107.72, 32.714], [-107.715, 32.722], [-107.723, 32.736], [-107.718, 32.755], [-107.721, 32.778], [-107.735, 32.783], [-107.742, 32.79], [-107.749, 32.805], [-107.745, 32.825], [-107.758, 32.846], [-107.773, 32.854], [-107.774, 32.874], [-107.779, 32.897], [-107.765, 32.912], [-107.766, 32.92], [-107.775, 32.93], [-107.776, 32.938], [-107.771, 32.942], [-107.774, 32.951], [-107.781, 32.953], [-107.792, 32.948], [-107.801, 32.958], [-107.816, 32.958], [-107.83, 32.964], [-107.832, 32.974], [-107.838, 32.979], [-107.847, 32.994], [-107.857, 33.003], [-107.849, 33.006], [-107.846, 33.016], [-107.848, 33.026], [-107.857, 33.037], [-107.85, 33.044], [-107.851, 33.056], [-107.845, 33.059], [-107.836, 33.068], [-107.834, 33.078], [-107.846, 33.086], [-107.842, 33.096], [-107.846, 33.102], [-107.851, 33.12], [-107.846, 33.131], [-107.853, 33.134], [-107.854, 33.157], [-107.856, 33.165], [-107.853, 33.171], [-107.843, 33.172], [-107.841, 33.183], [-107.849, 33.189], [-107.86, 33.192], [-107.857, 33.197], [-107.867, 33.202], [-107.876, 33.203], [-108.001, 33.202], [-108.001, 33.357], [-108.001, 33.478], [-107.968, 33.478], [-107.939, 33.474], [-107.861, 33.476], [-107.763, 33.477], [-107.746, 33.478], [-107.713, 33.477], [-107.667, 33.477], [-107.598, 33.476], [-107.516, 33.476], [-107.455, 33.476], [-107.385, 33.478], [-107.257, 33.478], [-107.169, 33.478], [-107.125, 33.478], [-107.119, 33.479], [-107.054, 33.478], [-106.943, 33.476], [-106.753, 33.476], [-106.626, 33.475], [-106.474, 33.476], [-106.474, 33.48], [-106.373, 33.48]]] } },
{ "type": "Feature", "properties": { "name": "Lea", "geoid2": "35025", "area": "4390.93", "population": "66876", "popsqmile": "15.23048648", "housing": "24993", "medianage": "32", "under18": "19932", "over65": "7161", "white": "59190", "hispanic": "35747", "englishonly": "34310", "population25": "40156", "highschool": "28820", "bachelor": "5193", "laborforce": "30192", "unemploy": "4.3", "personalinc": "45185", "sales2014": "6026516420" }, "geometry": { "type": "Polygon", "coordinates": [[[-103.815, 32.965], [-103.766, 32.965], [-103.766, 33.155], [-103.766, 33.239], [-103.767, 33.25], [-103.766, 33.395], [-103.721, 33.396], [-103.721, 33.436], [-103.721, 33.57], [-103.626, 33.569], [-103.51, 33.57], [-103.25, 33.57], [-103.053, 33.571], [-103.055, 33.435], [-103.06, 33.243], [-103.062, 33.11], [-103.065, 33], [-103.065, 32.886], [-103.065, 32.755], [-103.065, 32.625], [-103.065, 32.619], [-103.065, 32.491], [-103.065, 32.375], [-103.065, 32.227], [-103.065, 32.128], [-103.064, 32.001], [-103.196, 32], [-103.216, 32.001], [-103.375, 32], [-103.625, 32], [-103.723, 32], [-103.723, 32.075], [-103.722, 32.135], [-103.723, 32.237], [-103.723, 32.375], [-103.723, 32.523], [-103.814, 32.522], [-103.814, 32.576], [-103.814, 32.653], [-103.815, 32.77], [-103.814, 32.864], [-103.815, 32.965]]] } },
{ "type": "Feature", "properties": { "name": "Guadalupe", "geoid2": "35019", "area": "3030.48", "population": "4594", "popsqmile": "1.51593147", "housing": "2291", "medianage": "40.9", "under18": "900", "over65": "837", "white": "3837", "hispanic": "3490", "englishonly": "2071", "population25": "3364", "highschool": "2529", "bachelor": "431", "laborforce": "1646", "unemploy": "7.6", "personalinc": "28730", "sales2014": "92776353.63" }, "geometry": { "type": "Polygon", "coordinates": [[[-105.291, 35.042], [-105.291, 35.115], [-105.291, 35.216], [-105.127, 35.217], [-105.035, 35.217], [-104.875, 35.216], [-104.626, 35.216], [-104.481, 35.216], [-104.355, 35.216], [-104.125, 35.216], [-104.125, 35.142], [-104.125, 35.048], [-104.125, 35.033], [-104.126, 34.954], [-104.13, 34.954], [-104.129, 34.875], [-104.129, 34.779], [-104.239, 34.78], [-104.34, 34.779], [-104.34, 34.75], [-104.34, 34.692], [-104.445, 34.692], [-104.445, 34.605], [-104.622, 34.604], [-104.751, 34.605], [-104.786, 34.604], [-104.892, 34.604], [-104.892, 34.47], [-104.892, 34.413], [-104.892, 34.347], [-105.001, 34.347], [-105.242, 34.347], [-105.313, 34.347], [-105.313, 34.507], [-105.313, 34.607], [-105.29, 34.607], [-105.291, 34.738], [-105.291, 34.876], [-105.291, 34.956], [-105.291, 35.042]]] } },
{ "type": "Feature", "properties": { "name": "Torrance", "geoid2": "35057", "area": "3344.85", "population": "16037", "popsqmile": "4.794534882", "housing": "7774", "medianage": "43.2", "under18": "3575", "over65": "2568", "white": "13953", "hispanic": "6449", "englishonly": "11291", "population25": "11097", "highschool": "9222", "bachelor": "1831", "laborforce": "5185", "unemploy": "9.5", "personalinc": "28714", "sales2014": "206395207.3" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.411, 34.87], [-106.25, 34.87], [-106.188, 34.869], [-106.15, 34.87], [-106.15, 34.953], [-106.244, 34.953], [-106.244, 35.04], [-106.077, 35.041], [-105.876, 35.042], [-105.751, 35.041], [-105.714, 35.042], [-105.657, 35.042], [-105.489, 35.042], [-105.376, 35.042], [-105.291, 35.042], [-105.291, 34.956], [-105.291, 34.876], [-105.291, 34.738], [-105.29, 34.607], [-105.313, 34.607], [-105.313, 34.507], [-105.313, 34.347], [-105.313, 34.26], [-105.5, 34.26], [-105.685, 34.26], [-105.751, 34.26], [-105.924, 34.26], [-106.102, 34.26], [-106.239, 34.26], [-106.416, 34.26], [-106.417, 34.44], [-106.417, 34.522], [-106.47, 34.521], [-106.471, 34.609], [-106.465, 34.609], [-106.466, 34.71], [-106.465, 34.75], [-106.464, 34.87], [-106.411, 34.87]]] } },
{ "type": "Feature", "properties": { "name": "Grant", "geoid2": "35017", "area": "3961.63", "population": "29303", "popsqmile": "7.396702872", "housing": "14683", "medianage": "46.4", "under18": "6356", "over65": "6673", "white": "25345", "hispanic": "14326", "englishonly": "19328", "population25": "20679", "highschool": "17772", "bachelor": "5450", "laborforce": "12312", "unemploy": "6.6", "personalinc": "35908", "sales2014": "530554212" }, "geometry": { "type": "Polygon", "coordinates": [[[-108.001, 33.202], [-107.876, 33.203], [-107.867, 33.202], [-107.857, 33.197], [-107.86, 33.192], [-107.849, 33.189], [-107.841, 33.183], [-107.843, 33.172], [-107.853, 33.171], [-107.856, 33.165], [-107.854, 33.157], [-107.853, 33.134], [-107.846, 33.131], [-107.851, 33.12], [-107.846, 33.102], [-107.842, 33.096], [-107.846, 33.086], [-107.834, 33.078], [-107.836, 33.068], [-107.845, 33.059], [-107.851, 33.056], [-107.85, 33.044], [-107.857, 33.037], [-107.848, 33.026], [-107.846, 33.016], [-107.849, 33.006], [-107.857, 33.003], [-107.847, 32.994], [-107.838, 32.979], [-107.832, 32.974], [-107.83, 32.964], [-107.816, 32.958], [-107.801, 32.958], [-107.792, 32.948], [-107.781, 32.953], [-107.774, 32.951], [-107.771, 32.942], [-107.776, 32.938], [-107.775, 32.93], [-107.766, 32.92], [-107.765, 32.912], [-107.779, 32.897], [-107.774, 32.874], [-107.773, 32.854], [-107.758, 32.846], [-107.745, 32.825], [-107.749, 32.805], [-107.742, 32.79], [-107.735, 32.783], [-107.721, 32.778], [-107.718, 32.755], [-107.723, 32.736], [-107.715, 32.722], [-107.72, 32.714], [-107.72, 32.697], [-107.727, 32.692], [-107.728, 32.68], [-107.724, 32.674], [-107.725, 32.661], [-107.731, 32.653], [-107.734, 32.643], [-107.732, 32.627], [-107.717, 32.623], [-107.608, 32.605], [-107.757, 32.605], [-107.923, 32.604], [-107.923, 32.517], [-108.074, 32.517], [-108.229, 32.517], [-108.229, 32.373], [-108.23, 32.167], [-108.23, 32.131], [-108.23, 32.08], [-108.217, 32.08], [-108.217, 31.864], [-108.344, 31.864], [-108.503, 31.864], [-108.525, 31.864], [-108.525, 31.912], [-108.525, 31.954], [-108.525, 32], [-108.525, 32.02], [-108.525, 32.08], [-108.538, 32.08], [-108.538, 32.158], [-108.537, 32.168], [-108.537, 32.264], [-108.537, 32.437], [-108.537, 32.517], [-108.647, 32.517], [-108.646, 32.604], [-108.751, 32.604], [-108.853, 32.604], [-108.853, 32.709], [-108.854, 32.777], [-108.943, 32.778], [-109.001, 32.777], [-109.047, 32.778], [-109.047, 32.992], [-109.047, 33.068], [-109.047, 33.209], [-109.001, 33.209], [-108.957, 33.207], [-108.858, 33.209], [-108.751, 33.209], [-108.75, 33.21], [-108.647, 33.209], [-108.647, 33.208], [-108.543, 33.208], [-108.45, 33.201], [-108.306, 33.201], [-108.22, 33.201], [-108.001, 33.202]]] } },
{ "type": "Feature", "properties": { "name": "Otero", "geoid2": "35035", "area": "6613.21", "population": "65415", "popsqmile": "9.891565518", "housing": "30982", "medianage": "36", "under18": "16149", "over65": "9918", "white": "50457", "hispanic": "23230", "englishonly": "43363", "population25": "42006", "highschool": "35704", "bachelor": "7445", "laborforce": "24818", "unemploy": "6.1", "personalinc": "33653", "sales2014": "946853892.9" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.34, 33.053], [-106.341, 33.119], [-106.341, 33.136], [-106.344, 33.25], [-106.346, 33.391], [-106.251, 33.391], [-106.231, 33.39], [-106.108, 33.389], [-106.019, 33.389], [-105.93, 33.39], [-105.727, 33.391], [-105.726, 33.374], [-105.726, 33.305], [-105.626, 33.305], [-105.556, 33.305], [-105.376, 33.305], [-105.319, 33.305], [-105.319, 33.287], [-105.317, 33.214], [-105.317, 33.132], [-105.316, 32.962], [-105.353, 32.962], [-105.352, 32.842], [-105.352, 32.712], [-105.352, 32.605], [-105.353, 32.605], [-105.354, 32.519], [-105.149, 32.519], [-105.149, 32.521], [-104.967, 32.521], [-104.852, 32.521], [-104.852, 32.386], [-104.852, 32.362], [-104.851, 32.253], [-104.848, 32.253], [-104.848, 32.19], [-104.848, 32.118], [-104.848, 32.001], [-105.001, 32], [-105.155, 32.001], [-105.251, 32], [-105.429, 32.001], [-105.529, 32.001], [-105.731, 32.002], [-105.751, 32.002], [-105.854, 32.002], [-105.901, 32.002], [-106.126, 32.003], [-106.206, 32.002], [-106.377, 32.001], [-106.377, 32.125], [-106.378, 32.25], [-106.377, 32.344], [-106.377, 32.499], [-106.377, 32.525], [-106.377, 32.603], [-106.377, 32.689], [-106.377, 32.75], [-106.377, 32.867], [-106.377, 32.875], [-106.377, 32.958], [-106.341, 32.958], [-106.34, 33.053]]] } },
{ "type": "Feature", "properties": { "name": "San Juan", "geoid2": "35043", "area": "5513.07", "population": "135191", "popsqmile": "24.52190885", "housing": "53289", "medianage": "38.7", "under18": "34633", "over65": "18325", "white": "96733", "hispanic": "49157", "englishonly": "90138", "population25": "89571", "highschool": "82372", "bachelor": "26607", "laborforce": "59968", "unemploy": "7.1", "personalinc": "36088", "sales2014": "1649520414" }, "geometry": { "type": "Polygon", "coordinates": [[[-109.046, 36.002], [-109.046, 36.117], [-109.046, 36.19], [-109.046, 36.375], [-109.045, 36.503], [-109.046, 36.645], [-109.045, 36.841], [-109.045, 36.999], [-108.876, 36.999], [-108.682, 36.999], [-108.501, 36.999], [-108.251, 37], [-108.249, 36.999], [-108.001, 37], [-107.843, 37], [-107.649, 37], [-107.421, 37], [-107.431, 36.986], [-107.429, 36.974], [-107.433, 36.969], [-107.447, 36.965], [-107.457, 36.953], [-107.448, 36.945], [-107.456, 36.94], [-107.451, 36.921], [-107.446, 36.915], [-107.451, 36.904], [-107.47, 36.894], [-107.477, 36.894], [-107.497, 36.877], [-107.507, 36.875], [-107.517, 36.878], [-107.523, 36.875], [-107.53, 36.861], [-107.547, 36.849], [-107.556, 36.857], [-107.566, 36.852], [-107.565, 36.847], [-107.575, 36.841], [-107.58, 36.835], [-107.59, 36.837], [-107.598, 36.834], [-107.6, 36.815], [-107.606, 36.811], [-107.606, 36.798], [-107.614, 36.8], [-107.618, 36.793], [-107.619, 36.675], [-107.623, 36.675], [-107.623, 36.618], [-107.626, 36.546], [-107.627, 36.438], [-107.624, 36.393], [-107.626, 36.35], [-107.624, 36.22], [-107.624, 36.148], [-107.626, 36.107], [-107.627, 36], [-107.751, 36.001], [-107.876, 36.002], [-108.089, 36.003], [-108.251, 36.002], [-108.473, 36.002], [-108.625, 36.003], [-108.629, 36.003], [-108.835, 36.003], [-108.994, 36.003], [-109.046, 36.002]]] } },
{ "type": "Feature", "properties": { "name": "Roosevelt", "geoid2": "35041", "area": "2447.43", "population": "20065", "popsqmile": "8.198395868", "housing": "8251", "medianage": "29.2", "under18": "5172", "over65": "2410", "white": "14864", "hispanic": "8013", "englishonly": "13766", "population25": "11202", "highschool": "9074", "bachelor": "2599", "laborforce": "8094", "unemploy": "5.5", "personalinc": "37852", "sales2014": "313928432.7" }, "geometry": { "type": "Polygon", "coordinates": [[[-103.946, 34.083], [-103.946, 34.125], [-103.946, 34.207], [-103.946, 34.26], [-103.95, 34.26], [-103.949, 34.286], [-103.949, 34.43], [-103.949, 34.458], [-103.949, 34.537], [-103.949, 34.605], [-103.742, 34.605], [-103.738, 34.605], [-103.739, 34.563], [-103.738, 34.505], [-103.739, 34.413], [-103.74, 34.303], [-103.731, 34.303], [-103.565, 34.303], [-103.473, 34.303], [-103.267, 34.303], [-103.214, 34.303], [-103.044, 34.303], [-103.044, 34.275], [-103.044, 34.133], [-103.043, 34.124], [-103.044, 33.975], [-103.046, 33.875], [-103.048, 33.796], [-103.05, 33.738], [-103.053, 33.571], [-103.25, 33.57], [-103.51, 33.57], [-103.51, 33.657], [-103.62, 33.656], [-103.718, 33.656], [-103.718, 33.691], [-103.717, 33.819], [-103.842, 33.819], [-103.842, 33.934], [-103.842, 33.997], [-103.842, 34.082], [-103.912, 34.082], [-103.946, 34.083]]] } },
{ "type": "Feature", "properties": { "name": "Curry", "geoid2": "35009", "area": "1404.8", "population": "50173", "popsqmile": "35.71540433", "housing": "20422", "medianage": "31", "under18": "13718", "over65": "5623", "white": "36293", "hispanic": "19839", "englishonly": "33916", "population25": "30308", "highschool": "24985", "bachelor": "6293", "laborforce": "21514", "unemploy": "4.9", "personalinc": "43006", "sales2014": "1044154933" }, "geometry": { "type": "Polygon", "coordinates": [[[-103.496, 34.735], [-103.495, 34.779], [-103.39, 34.778], [-103.39, 34.785], [-103.39, 34.795], [-103.389, 34.847], [-103.389, 34.865], [-103.284, 34.865], [-103.283, 34.954], [-103.123, 34.954], [-103.043, 34.954], [-103.043, 34.757], [-103.043, 34.74], [-103.043, 34.653], [-103.044, 34.473], [-103.044, 34.303], [-103.214, 34.303], [-103.267, 34.303], [-103.473, 34.303], [-103.565, 34.303], [-103.731, 34.303], [-103.74, 34.303], [-103.739, 34.413], [-103.738, 34.505], [-103.739, 34.563], [-103.738, 34.605], [-103.707, 34.605], [-103.706, 34.692], [-103.573, 34.692], [-103.496, 34.691], [-103.496, 34.7], [-103.496, 34.735]]] } },
{ "type": "Feature", "properties": { "name": "Taos", "geoid2": "35055", "area": "2203.11", "population": "32956", "popsqmile": "14.95885362", "housing": "20296", "medianage": "46.5", "under18": "6463", "over65": "6517", "white": "21613", "hispanic": "18497", "englishonly": "17991", "population25": "24242", "highschool": "21104", "bachelor": "7108", "laborforce": "14752", "unemploy": "9.7", "personalinc": "32998", "sales2014": "695430802.3" }, "geometry": { "type": "Polygon", "coordinates": [[[-105.221, 36.995], [-105.223, 36.987], [-105.236, 36.982], [-105.236, 36.962], [-105.228, 36.955], [-105.227, 36.946], [-105.213, 36.932], [-105.212, 36.92], [-105.2, 36.916], [-105.222, 36.869], [-105.229, 36.848], [-105.223, 36.834], [-105.224, 36.822], [-105.234, 36.808], [-105.227, 36.801], [-105.235, 36.791], [-105.227, 36.771], [-105.224, 36.756], [-105.227, 36.738], [-105.224, 36.734], [-105.231, 36.724], [-105.243, 36.722], [-105.248, 36.718], [-105.263, 36.72], [-105.268, 36.717], [-105.277, 36.721], [-105.285, 36.721], [-105.289, 36.728], [-105.313, 36.723], [-105.327, 36.698], [-105.335, 36.702], [-105.344, 36.698], [-105.352, 36.697], [-105.365, 36.687], [-105.371, 36.681], [-105.37, 36.672], [-105.36, 36.663], [-105.361, 36.651], [-105.352, 36.637], [-105.354, 36.63], [-105.363, 36.629], [-105.374, 36.616], [-105.375, 36.609], [-105.367, 36.598], [-105.358, 36.59], [-105.35, 36.561], [-105.378, 36.552], [-105.363, 36.541], [-105.349, 36.533], [-105.344, 36.511], [-105.327, 36.5], [-105.319, 36.492], [-105.322, 36.487], [-105.336, 36.484], [-105.34, 36.47], [-105.344, 36.468], [-105.349, 36.456], [-105.356, 36.452], [-105.354, 36.446], [-105.34, 36.446], [-105.34, 36.435], [-105.336, 36.426], [-105.34, 36.416], [-105.328, 36.408], [-105.325, 36.389], [-105.327, 36.38], [-105.336, 36.373], [-105.332, 36.367], [-105.329, 36.35], [-105.333, 36.346], [-105.329, 36.337], [-105.333, 36.332], [-105.331, 36.323], [-105.336, 36.305], [-105.327, 36.277], [-105.341, 36.262], [-105.387, 36.253], [-105.394, 36.244], [-105.41, 36.237], [-105.399, 36.23], [-105.393, 36.216], [-105.399, 36.203], [-105.397, 36.192], [-105.422, 36.17], [-105.421, 36.162], [-105.415, 36.157], [-105.421, 36.149], [-105.42, 36.132], [-105.434, 36.115], [-105.463, 36.078], [-105.489, 36.037], [-105.495, 36.036], [-105.507, 36.021], [-105.513, 36.017], [-105.53, 36.013], [-105.613, 36.049], [-105.626, 36.053], [-105.736, 36.1], [-105.751, 36.116], [-105.762, 36.13], [-105.857, 36.23], [-105.876, 36.237], [-106.058, 36.297], [-106.056, 36.305], [-106.038, 36.324], [-106.027, 36.329], [-106.018, 36.328], [-106.012, 36.332], [-105.998, 36.334], [-105.996, 36.338], [-105.984, 36.343], [-105.977, 36.343], [-105.961, 36.353], [-105.952, 36.375], [-105.953, 36.408], [-105.955, 36.419], [-105.952, 36.434], [-105.945, 36.447], [-105.939, 36.462], [-105.942, 36.497], [-105.95, 36.516], [-105.955, 36.54], [-105.95, 36.543], [-105.956, 36.576], [-105.964, 36.598], [-105.964, 36.613], [-105.972, 36.632], [-105.972, 36.648], [-105.984, 36.645], [-105.984, 36.66], [-105.968, 36.66], [-105.971, 36.683], [-105.979, 36.701], [-105.981, 36.713], [-105.978, 36.721], [-105.982, 36.746], [-105.98, 36.767], [-105.984, 36.812], [-105.975, 36.837], [-105.973, 36.847], [-105.974, 36.866], [-105.972, 36.886], [-105.976, 36.902], [-105.986, 36.92], [-105.99, 36.946], [-106.005, 36.976], [-106.007, 36.995], [-105.9, 36.996], [-105.665, 36.996], [-105.484, 36.996], [-105.335, 36.996], [-105.251, 36.996], [-105.221, 36.995]]] } },
{ "type": "Feature", "properties": { "name": "Hidalgo", "geoid2": "35023", "area": "3436.86", "population": "4734", "popsqmile": "1.377420087", "housing": "2393", "medianage": "41", "under18": "1152", "over65": "846", "white": "4187", "hispanic": "2678", "englishonly": "2642", "population25": "3218", "highschool": "2472", "bachelor": "503", "laborforce": "2049", "unemploy": "7.1", "personalinc": "37642", "sales2014": "75664415.25" }, "geometry": { "type": "Polygon", "coordinates": [[[-109.047, 32.778], [-109.001, 32.777], [-108.943, 32.778], [-108.854, 32.777], [-108.853, 32.709], [-108.853, 32.604], [-108.751, 32.604], [-108.646, 32.604], [-108.647, 32.517], [-108.537, 32.517], [-108.537, 32.437], [-108.537, 32.264], [-108.537, 32.168], [-108.538, 32.158], [-108.538, 32.08], [-108.525, 32.08], [-108.525, 32.02], [-108.525, 32], [-108.525, 31.954], [-108.525, 31.912], [-108.525, 31.864], [-108.503, 31.864], [-108.344, 31.864], [-108.217, 31.864], [-108.217, 31.82], [-108.21, 31.82], [-108.21, 31.784], [-108.208, 31.784], [-108.208, 31.601], [-108.209, 31.526], [-108.208, 31.458], [-108.209, 31.333], [-108.368, 31.333], [-108.501, 31.333], [-108.708, 31.333], [-108.816, 31.332], [-109.05, 31.332], [-109.05, 31.48], [-109.049, 31.545], [-109.049, 31.722], [-109.049, 31.798], [-109.049, 31.876], [-109.048, 32], [-109.048, 32.164], [-109.048, 32.307], [-109.048, 32.426], [-109.048, 32.5], [-109.048, 32.602], [-109.048, 32.75], [-109.047, 32.778]]] } },
{ "type": "Feature", "properties": { "name": "Eddy", "geoid2": "35015", "area": "4175.73", "population": "54834", "popsqmile": "13.13159615", "housing": "22960", "medianage": "36.7", "under18": "14231", "over65": "7682", "white": "48393", "hispanic": "24840", "englishonly": "35386", "population25": "35687", "highschool": "29370", "bachelor": "6111", "laborforce": "29017", "unemploy": "4.3", "personalinc": "52323", "sales2014": "4566003332" }, "geometry": { "type": "Polygon", "coordinates": [[[-104.848, 32.001], [-104.848, 32.118], [-104.848, 32.19], [-104.848, 32.253], [-104.851, 32.253], [-104.852, 32.362], [-104.852, 32.386], [-104.852, 32.521], [-104.842, 32.521], [-104.842, 32.695], [-104.843, 32.725], [-104.842, 32.825], [-104.841, 32.869], [-104.841, 32.963], [-104.626, 32.964], [-104.508, 32.964], [-104.329, 32.965], [-104.291, 32.965], [-104.071, 32.965], [-103.876, 32.965], [-103.815, 32.965], [-103.814, 32.864], [-103.815, 32.77], [-103.814, 32.653], [-103.814, 32.576], [-103.814, 32.522], [-103.723, 32.523], [-103.723, 32.375], [-103.723, 32.237], [-103.722, 32.135], [-103.723, 32.075], [-103.723, 32], [-103.875, 32.001], [-103.916, 32], [-104.076, 32], [-104.252, 32], [-104.466, 32], [-104.608, 32], [-104.731, 32], [-104.848, 32.001]]] } },
{ "type": "Feature", "properties": { "name": "De Baca", "geoid2": "35011", "area": "2322.62", "population": "1967", "popsqmile": "0.846888428", "housing": "1093", "medianage": "48", "under18": "362", "over65": "373", "white": "1570", "hispanic": "769", "englishonly": "1327", "population25": "1422", "highschool": "1167", "bachelor": "165", "laborforce": "778", "unemploy": "5", "personalinc": "40160", "sales2014": "24421687.02" }, "geometry": { "type": "Polygon", "coordinates": [[[-104.893, 34.088], [-104.892, 34.233], [-104.892, 34.324], [-104.892, 34.347], [-104.892, 34.413], [-104.892, 34.47], [-104.892, 34.604], [-104.786, 34.604], [-104.751, 34.605], [-104.622, 34.604], [-104.445, 34.605], [-104.445, 34.692], [-104.34, 34.692], [-104.34, 34.75], [-104.34, 34.779], [-104.239, 34.78], [-104.129, 34.779], [-104.129, 34.678], [-104.129, 34.605], [-104.106, 34.606], [-104.077, 34.605], [-104.001, 34.605], [-103.949, 34.605], [-103.949, 34.537], [-103.949, 34.458], [-103.949, 34.43], [-103.949, 34.286], [-103.95, 34.26], [-103.946, 34.26], [-103.946, 34.207], [-103.946, 34.125], [-103.946, 34.083], [-104.001, 34.082], [-104.156, 34.083], [-104.156, 33.995], [-104.376, 33.996], [-104.497, 33.997], [-104.675, 33.999], [-104.717, 33.999], [-104.786, 34], [-104.786, 34.088], [-104.835, 34.088], [-104.893, 34.088]]] } },
{ "type": "Feature", "properties": { "name": "Cibola", "geoid2": "35006", "area": "4539.48", "population": "27392", "popsqmile": "6.034171315", "housing": "11100", "medianage": "36.2", "under18": "6691", "over65": "3770", "white": "12299", "hispanic": "10206", "englishonly": "14093", "population25": "18094", "highschool": "14607", "bachelor": "2145", "laborforce": "8972", "unemploy": "8", "personalinc": "25302", "sales2014": "363380460.4" }, "geometry": { "type": "Polygon", "coordinates": [[[-109.046, 34.96], [-108.922, 34.96], [-108.742, 34.96], [-108.669, 34.96], [-108.602, 34.959], [-108.469, 34.959], [-108.47, 34.999], [-108.47, 35.125], [-108.468, 35.169], [-108.469, 35.307], [-108.385, 35.306], [-108.202, 35.306], [-108.118, 35.306], [-108.001, 35.305], [-107.959, 35.305], [-107.734, 35.305], [-107.734, 35.348], [-107.628, 35.348], [-107.628, 35.305], [-107.544, 35.304], [-107.376, 35.305], [-107.31, 35.305], [-107.239, 35.305], [-107.214, 35.25], [-107.21, 35.248], [-107.196, 35.219], [-107.191, 35.207], [-107.128, 35.08], [-107.067, 34.957], [-107.133, 34.957], [-107.203, 34.958], [-107.203, 34.769], [-107.204, 34.732], [-107.204, 34.696], [-107.205, 34.65], [-107.204, 34.627], [-107.204, 34.579], [-107.34, 34.579], [-107.41, 34.58], [-107.515, 34.579], [-107.534, 34.581], [-107.551, 34.579], [-107.594, 34.58], [-107.674, 34.579], [-107.691, 34.579], [-107.71, 34.578], [-107.725, 34.578], [-107.793, 34.579], [-107.851, 34.579], [-107.896, 34.579], [-107.949, 34.579], [-107.965, 34.58], [-108.001, 34.579], [-108.058, 34.579], [-108.072, 34.581], [-108.188, 34.58], [-108.376, 34.579], [-108.461, 34.579], [-108.625, 34.579], [-108.649, 34.579], [-108.798, 34.579], [-108.877, 34.58], [-108.983, 34.58], [-108.983, 34.579], [-109.046, 34.579], [-109.046, 34.68], [-109.046, 34.8], [-109.046, 34.96]]] } },
{ "type": "Feature", "properties": { "name": "Quay", "geoid2": "35037", "area": "2874.35", "population": "8822", "popsqmile": "3.069215649", "housing": "5561", "medianage": "46", "under18": "1888", "over65": "1951", "white": "8209", "hispanic": "3839", "englishonly": "6374", "population25": "6165", "highschool": "5049", "bachelor": "881", "laborforce": "3456", "unemploy": "6.2", "personalinc": "35176", "sales2014": "147766174.8" }, "geometry": { "type": "Polygon", "coordinates": [[[-103.043, 34.954], [-103.123, 34.954], [-103.283, 34.954], [-103.284, 34.865], [-103.389, 34.865], [-103.389, 34.847], [-103.39, 34.795], [-103.39, 34.785], [-103.39, 34.778], [-103.495, 34.779], [-103.496, 34.735], [-103.496, 34.7], [-103.496, 34.691], [-103.573, 34.692], [-103.706, 34.692], [-103.707, 34.605], [-103.738, 34.605], [-103.742, 34.605], [-103.949, 34.605], [-104.001, 34.605], [-104.077, 34.605], [-104.106, 34.606], [-104.129, 34.605], [-104.129, 34.678], [-104.129, 34.779], [-104.129, 34.875], [-104.13, 34.954], [-104.126, 34.954], [-104.125, 35.033], [-104.125, 35.048], [-104.125, 35.142], [-104.081, 35.162], [-104.001, 35.199], [-103.89, 35.25], [-103.858, 35.264], [-103.858, 35.242], [-103.842, 35.241], [-103.751, 35.242], [-103.637, 35.241], [-103.637, 35.39], [-103.588, 35.39], [-103.506, 35.39], [-103.477, 35.39], [-103.39, 35.39], [-103.38, 35.398], [-103.379, 35.497], [-103.38, 35.521], [-103.379, 35.578], [-103.379, 35.652], [-103.375, 35.652], [-103.375, 35.681], [-103.375, 35.74], [-103.25, 35.74], [-103.197, 35.74], [-103.125, 35.74], [-103.041, 35.739], [-103.042, 35.625], [-103.042, 35.512], [-103.042, 35.394], [-103.042, 35.25], [-103.043, 35.241], [-103.042, 35.171], [-103.043, 35.11], [-103.043, 34.954]]] } },
{ "type": "Feature", "properties": { "name": "Colfax", "geoid2": "35007", "area": "3758.06", "population": "13264", "popsqmile": "3.529480636", "housing": "10046", "medianage": "47.1", "under18": "2592", "over65": "2844", "white": "11090", "hispanic": "6392", "englishonly": "9923", "population25": "9663", "highschool": "8455", "bachelor": "2043", "laborforce": "6280", "unemploy": "6.1", "personalinc": "37205", "sales2014": "298044316.8" }, "geometry": { "type": "Polygon", "coordinates": [[[-105.341, 36.262], [-105.327, 36.277], [-105.336, 36.305], [-105.331, 36.323], [-105.333, 36.332], [-105.329, 36.337], [-105.333, 36.346], [-105.329, 36.35], [-105.332, 36.367], [-105.336, 36.373], [-105.327, 36.38], [-105.325, 36.389], [-105.328, 36.408], [-105.34, 36.416], [-105.336, 36.426], [-105.34, 36.435], [-105.34, 36.446], [-105.354, 36.446], [-105.356, 36.452], [-105.349, 36.456], [-105.344, 36.468], [-105.34, 36.47], [-105.336, 36.484], [-105.322, 36.487], [-105.319, 36.492], [-105.327, 36.5], [-105.344, 36.511], [-105.349, 36.533], [-105.363, 36.541], [-105.378, 36.552], [-105.35, 36.561], [-105.358, 36.59], [-105.367, 36.598], [-105.375, 36.609], [-105.374, 36.616], [-105.363, 36.629], [-105.354, 36.63], [-105.352, 36.637], [-105.361, 36.651], [-105.36, 36.663], [-105.37, 36.672], [-105.371, 36.681], [-105.365, 36.687], [-105.352, 36.697], [-105.344, 36.698], [-105.335, 36.702], [-105.327, 36.698], [-105.313, 36.723], [-105.289, 36.728], [-105.285, 36.721], [-105.277, 36.721], [-105.268, 36.717], [-105.263, 36.72], [-105.248, 36.718], [-105.243, 36.722], [-105.231, 36.724], [-105.224, 36.734], [-105.227, 36.738], [-105.224, 36.756], [-105.227, 36.771], [-105.235, 36.791], [-105.227, 36.801], [-105.234, 36.808], [-105.224, 36.822], [-105.223, 36.834], [-105.229, 36.848], [-105.222, 36.869], [-105.2, 36.916], [-105.212, 36.92], [-105.213, 36.932], [-105.227, 36.946], [-105.228, 36.955], [-105.236, 36.962], [-105.236, 36.982], [-105.223, 36.987], [-105.221, 36.995], [-105.121, 36.995], [-105.029, 36.993], [-105.001, 36.993], [-104.871, 36.993], [-104.645, 36.993], [-104.615, 36.994], [-104.339, 36.994], [-104.251, 36.995], [-104.126, 36.995], [-104.008, 36.996], [-104.008, 36.875], [-104.008, 36.75], [-104.007, 36.698], [-104.009, 36.686], [-104.008, 36.568], [-104.008, 36.411], [-104.009, 36.218], [-104.203, 36.218], [-104.251, 36.218], [-104.436, 36.219], [-104.624, 36.218], [-104.742, 36.219], [-104.758, 36.218], [-104.866, 36.218], [-104.865, 36.261], [-105.024, 36.261], [-105.059, 36.26], [-105.126, 36.26], [-105.167, 36.262], [-105.266, 36.262], [-105.341, 36.262]]] } },
{ "type": "Feature", "properties": { "name": "Los Alamos", "geoid2": "35028", "area": "109.17", "population": "17974", "popsqmile": "164.642301", "housing": "8329", "medianage": "43.1", "under18": "4246", "over65": "2838", "white": "15778", "hispanic": "2830", "englishonly": "14363", "population25": "12667", "highschool": "14117", "bachelor": "9911", "laborforce": "8406", "unemploy": "4.1", "personalinc": "62619", "sales2014": "1049584418" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.248, 35.966], [-106.245, 35.959], [-106.245, 35.931], [-106.246, 35.893], [-106.248, 35.873], [-106.248, 35.856], [-106.266, 35.852], [-106.248, 35.839], [-106.241, 35.835], [-106.228, 35.832], [-106.226, 35.829], [-106.213, 35.828], [-106.2, 35.83], [-106.173, 35.827], [-106.178, 35.819], [-106.18, 35.81], [-106.192, 35.805], [-106.196, 35.791], [-106.209, 35.777], [-106.224, 35.767], [-106.241, 35.764], [-106.248, 35.756], [-106.254, 35.754], [-106.258, 35.77], [-106.266, 35.779], [-106.283, 35.792], [-106.325, 35.807], [-106.339, 35.808], [-106.357, 35.816], [-106.362, 35.811], [-106.374, 35.812], [-106.382, 35.808], [-106.401, 35.808], [-106.411, 35.811], [-106.418, 35.818], [-106.418, 35.828], [-106.4, 35.828], [-106.4, 35.96], [-106.386, 35.96], [-106.386, 35.953], [-106.315, 35.952], [-106.317, 35.959], [-106.3, 35.959], [-106.3, 35.973], [-106.264, 35.973], [-106.264, 35.966], [-106.248, 35.966]]] } },
{ "type": "Feature", "properties": { "name": "Bernalillo", "geoid2": "35001", "area": "1160.83", "population": "671429", "popsqmile": "578.4042452", "housing": "286270", "medianage": "36.3", "under18": "157319", "over65": "88240", "white": "481651", "hispanic": "325447", "englishonly": "431739", "population25": "446795", "highschool": "399018", "bachelor": "151207", "laborforce": "318070", "unemploy": "6.1", "personalinc": "38690", "sales2014": "17741392465" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.411, 34.87], [-106.411, 34.889], [-106.417, 34.892], [-106.423, 34.902], [-106.432, 34.903], [-106.626, 34.906], [-106.686, 34.906], [-106.696, 34.897], [-106.703, 34.885], [-106.714, 34.88], [-106.721, 34.87], [-106.911, 34.87], [-107.001, 34.87], [-107.024, 34.87], [-107.029, 34.88], [-107.067, 34.957], [-107.128, 35.08], [-107.191, 35.207], [-107.196, 35.219], [-107.131, 35.219], [-107.121, 35.218], [-107.081, 35.219], [-106.848, 35.218], [-106.805, 35.218], [-106.691, 35.218], [-106.658, 35.217], [-106.643, 35.207], [-106.646, 35.202], [-106.623, 35.209], [-106.607, 35.217], [-106.599, 35.218], [-106.363, 35.217], [-106.315, 35.217], [-106.258, 35.215], [-106.245, 35.215], [-106.244, 35.167], [-106.244, 35.04], [-106.244, 34.953], [-106.15, 34.953], [-106.15, 34.87], [-106.188, 34.869], [-106.25, 34.87], [-106.411, 34.87]]] } },
{ "type": "Feature", "properties": { "name": "Dona Ana", "geoid2": "35013", "area": "3807.51", "population": "212942", "popsqmile": "55.92683933", "housing": "82988", "medianage": "32.5", "under18": "55482", "over65": "28068", "white": "190021", "hispanic": "141087", "englishonly": "95923", "population25": "127266", "highschool": "100650", "bachelor": "36339", "laborforce": "93212", "unemploy": "7.2", "personalinc": "30593", "sales2014": "3599875376" }, "geometry": { "type": "Polygon", "coordinates": [[[-107.299, 32.606], [-107.299, 32.781], [-107.167, 32.779], [-107.092, 32.779], [-106.998, 32.779], [-106.888, 32.779], [-106.888, 32.823], [-106.752, 32.88], [-106.626, 32.934], [-106.532, 32.973], [-106.34, 33.053], [-106.341, 32.958], [-106.377, 32.958], [-106.377, 32.875], [-106.377, 32.867], [-106.377, 32.75], [-106.377, 32.689], [-106.377, 32.603], [-106.377, 32.525], [-106.377, 32.499], [-106.377, 32.344], [-106.378, 32.25], [-106.377, 32.125], [-106.377, 32.001], [-106.394, 32.001], [-106.517, 32.001], [-106.589, 32.001], [-106.618, 32], [-106.624, 31.991], [-106.631, 31.99], [-106.64, 31.98], [-106.63, 31.971], [-106.623, 31.973], [-106.619, 31.967], [-106.624, 31.961], [-106.622, 31.937], [-106.63, 31.927], [-106.612, 31.92], [-106.634, 31.91], [-106.645, 31.899], [-106.629, 31.884], [-106.635, 31.874], [-106.636, 31.866], [-106.615, 31.846], [-106.606, 31.846], [-106.602, 31.84], [-106.605, 31.828], [-106.588, 31.822], [-106.577, 31.81], [-106.563, 31.811], [-106.547, 31.807], [-106.527, 31.789], [-106.532, 31.784], [-106.626, 31.784], [-106.751, 31.784], [-106.804, 31.784], [-107.001, 31.784], [-107.185, 31.784], [-107.297, 31.784], [-107.296, 31.861], [-107.297, 31.999], [-107.298, 32.082], [-107.299, 32.082], [-107.298, 32.22], [-107.299, 32.244], [-107.299, 32.434], [-107.298, 32.518], [-107.299, 32.606]]] } },
{ "type": "Feature", "properties": { "name": "Chaves", "geoid2": "35005", "area": "6065.28", "population": "65850", "popsqmile": "10.85687718", "housing": "26672", "medianage": "34.8", "under18": "17971", "over65": "9390", "white": "52463", "hispanic": "35258", "englishonly": "37446", "population25": "41064", "highschool": "32207", "bachelor": "7720", "laborforce": "26808", "unemploy": "6", "personalinc": "35377", "sales2014": "1368153444" }, "geometry": { "type": "Polygon", "coordinates": [[[-103.946, 34.083], [-103.912, 34.082], [-103.842, 34.082], [-103.842, 33.997], [-103.842, 33.934], [-103.842, 33.819], [-103.717, 33.819], [-103.718, 33.691], [-103.718, 33.656], [-103.62, 33.656], [-103.51, 33.657], [-103.51, 33.57], [-103.626, 33.569], [-103.721, 33.57], [-103.721, 33.436], [-103.721, 33.396], [-103.766, 33.395], [-103.767, 33.25], [-103.766, 33.239], [-103.766, 33.155], [-103.766, 32.965], [-103.815, 32.965], [-103.876, 32.965], [-104.071, 32.965], [-104.291, 32.965], [-104.329, 32.965], [-104.508, 32.964], [-104.626, 32.964], [-104.841, 32.963], [-104.841, 32.869], [-104.842, 32.825], [-104.843, 32.725], [-104.842, 32.695], [-104.842, 32.521], [-104.852, 32.521], [-104.967, 32.521], [-105.149, 32.521], [-105.149, 32.519], [-105.354, 32.519], [-105.353, 32.605], [-105.352, 32.605], [-105.352, 32.712], [-105.352, 32.842], [-105.353, 32.962], [-105.316, 32.962], [-105.317, 33.132], [-105.251, 33.132], [-105.11, 33.132], [-105.099, 33.134], [-105.007, 33.134], [-105.001, 33.139], [-104.906, 33.139], [-104.906, 33.221], [-104.903, 33.25], [-104.904, 33.306], [-104.885, 33.306], [-104.885, 33.393], [-104.892, 33.398], [-104.892, 33.625], [-104.891, 33.737], [-104.892, 33.75], [-104.891, 33.822], [-104.895, 33.824], [-104.894, 33.983], [-104.893, 34.088], [-104.835, 34.088], [-104.786, 34.088], [-104.786, 34], [-104.717, 33.999], [-104.675, 33.999], [-104.497, 33.997], [-104.376, 33.996], [-104.156, 33.995], [-104.156, 34.083], [-104.001, 34.082], [-103.946, 34.083]]] } },
{ "type": "Feature", "properties": { "name": "Valencia", "geoid2": "35061", "area": "1066.18", "population": "76480", "popsqmile": "71.73272806", "housing": "30142", "medianage": "38.2", "under18": "19408", "over65": "10726", "white": "52853", "hispanic": "45018", "englishonly": "47617", "population25": "50083", "highschool": "40606", "bachelor": "8502", "laborforce": "29284", "unemploy": "7.7", "personalinc": "29422", "sales2014": "811636617.8" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.411, 34.87], [-106.464, 34.87], [-106.465, 34.75], [-106.466, 34.71], [-106.465, 34.609], [-106.471, 34.609], [-106.47, 34.521], [-106.417, 34.522], [-106.417, 34.44], [-106.456, 34.437], [-106.505, 34.457], [-106.626, 34.491], [-106.768, 34.531], [-106.883, 34.579], [-106.911, 34.581], [-106.986, 34.58], [-107.09, 34.578], [-107.204, 34.579], [-107.204, 34.627], [-107.205, 34.65], [-107.204, 34.696], [-107.204, 34.732], [-107.203, 34.769], [-107.203, 34.958], [-107.133, 34.957], [-107.067, 34.957], [-107.029, 34.88], [-107.024, 34.87], [-107.001, 34.87], [-106.911, 34.87], [-106.721, 34.87], [-106.714, 34.88], [-106.703, 34.885], [-106.696, 34.897], [-106.686, 34.906], [-106.626, 34.906], [-106.432, 34.903], [-106.423, 34.902], [-106.417, 34.892], [-106.411, 34.889], [-106.411, 34.87]]] } },
{ "type": "Feature", "properties": { "name": "Rio Arriba", "geoid2": "35039", "area": "5860.84", "population": "40155", "popsqmile": "6.851406966", "housing": "19601", "medianage": "39.5", "under18": "9821", "over65": "6122", "white": "26672", "hispanic": "28676", "englishonly": "13753", "population25": "26875", "highschool": "21410", "bachelor": "4294", "laborforce": "16356", "unemploy": "8.3", "personalinc": "30976", "sales2014": "484417642" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.007, 36.995], [-106.005, 36.976], [-105.99, 36.946], [-105.986, 36.92], [-105.976, 36.902], [-105.972, 36.886], [-105.974, 36.866], [-105.973, 36.847], [-105.975, 36.837], [-105.984, 36.812], [-105.98, 36.767], [-105.982, 36.746], [-105.978, 36.721], [-105.981, 36.713], [-105.979, 36.701], [-105.971, 36.683], [-105.968, 36.66], [-105.984, 36.66], [-105.984, 36.645], [-105.972, 36.648], [-105.972, 36.632], [-105.964, 36.613], [-105.964, 36.598], [-105.956, 36.576], [-105.95, 36.543], [-105.955, 36.54], [-105.95, 36.516], [-105.942, 36.497], [-105.939, 36.462], [-105.945, 36.447], [-105.952, 36.434], [-105.955, 36.419], [-105.953, 36.408], [-105.952, 36.375], [-105.961, 36.353], [-105.977, 36.343], [-105.984, 36.343], [-105.996, 36.338], [-105.998, 36.334], [-106.012, 36.332], [-106.018, 36.328], [-106.027, 36.329], [-106.038, 36.324], [-106.056, 36.305], [-106.058, 36.297], [-105.876, 36.237], [-105.857, 36.23], [-105.762, 36.13], [-105.751, 36.116], [-105.736, 36.1], [-105.626, 36.053], [-105.613, 36.049], [-105.53, 36.013], [-105.531, 36.001], [-105.537, 35.991], [-105.557, 35.984], [-105.566, 35.975], [-105.572, 35.972], [-105.605, 35.974], [-105.632, 35.98], [-105.644, 35.969], [-105.645, 35.962], [-105.66, 35.959], [-105.68, 35.968], [-105.708, 35.969], [-105.717, 35.979], [-105.717, 36.002], [-105.859, 36.002], [-105.918, 36.002], [-106.071, 36.002], [-106.065, 35.997], [-106.066, 35.989], [-106.054, 35.986], [-106.054, 35.931], [-106.245, 35.931], [-106.245, 35.959], [-106.248, 35.966], [-106.247, 35.973], [-106.247, 36.002], [-106.357, 36.001], [-106.501, 36.001], [-106.616, 36], [-106.751, 35.999], [-106.876, 35.999], [-106.885, 36.001], [-106.887, 36.125], [-106.885, 36.217], [-107.126, 36.216], [-107.238, 36.216], [-107.376, 36.218], [-107.501, 36.218], [-107.624, 36.22], [-107.626, 36.35], [-107.624, 36.393], [-107.627, 36.438], [-107.626, 36.546], [-107.623, 36.618], [-107.623, 36.675], [-107.619, 36.675], [-107.618, 36.793], [-107.614, 36.8], [-107.606, 36.798], [-107.606, 36.811], [-107.6, 36.815], [-107.598, 36.834], [-107.59, 36.837], [-107.58, 36.835], [-107.575, 36.841], [-107.565, 36.847], [-107.566, 36.852], [-107.556, 36.857], [-107.547, 36.849], [-107.53, 36.861], [-107.523, 36.875], [-107.517, 36.878], [-107.507, 36.875], [-107.497, 36.877], [-107.477, 36.894], [-107.47, 36.894], [-107.451, 36.904], [-107.446, 36.915], [-107.451, 36.921], [-107.456, 36.94], [-107.448, 36.945], [-107.457, 36.953], [-107.447, 36.965], [-107.433, 36.969], [-107.429, 36.974], [-107.431, 36.986], [-107.421, 37], [-107.256, 37], [-107.001, 37], [-106.877, 37], [-106.87, 36.992], [-106.75, 36.992], [-106.661, 36.993], [-106.591, 36.993], [-106.5, 36.994], [-106.343, 36.994], [-106.201, 36.994], [-106.154, 36.995], [-106.007, 36.995]]] } },
{ "type": "Feature", "properties": { "name": "San Miguel", "geoid2": "35045", "area": "4715.82", "population": "127358", "popsqmile": "27.00654393", "housing": "49527", "medianage": "33.7", "under18": "35535", "over65": "14999", "white": "67447", "hispanic": "24659", "englishonly": "79248", "population25": "79497", "highschool": "65766", "bachelor": "12374", "laborforce": "55116", "unemploy": "6.3", "personalinc": "36197", "sales2014": "3755020006" }, "geometry": { "type": "Polygon", "coordinates": [[[-105.72, 35.871], [-105.567, 35.871], [-105.355, 35.871], [-105.348, 35.871], [-105.238, 35.838], [-105.22, 35.835], [-105.211, 35.827], [-105.181, 35.826], [-105.16, 35.819], [-105.15, 35.809], [-105.128, 35.811], [-105.111, 35.808], [-105.088, 35.794], [-105.082, 35.788], [-105.066, 35.78], [-105.058, 35.78], [-105.051, 35.774], [-105.038, 35.77], [-105.037, 35.764], [-105.025, 35.759], [-105.008, 35.771], [-104.985, 35.773], [-104.876, 35.775], [-104.869, 35.775], [-104.751, 35.778], [-104.724, 35.778], [-104.481, 35.781], [-104.367, 35.781], [-104.255, 35.782], [-104.24, 35.781], [-104.196, 35.782], [-104.093, 35.781], [-104.021, 35.781], [-103.977, 35.802], [-103.914, 35.708], [-103.835, 35.588], [-103.725, 35.422], [-103.637, 35.422], [-103.637, 35.39], [-103.637, 35.241], [-103.751, 35.242], [-103.842, 35.241], [-103.858, 35.242], [-103.858, 35.264], [-103.89, 35.25], [-104.001, 35.199], [-104.081, 35.162], [-104.125, 35.142], [-104.125, 35.216], [-104.355, 35.216], [-104.481, 35.216], [-104.626, 35.216], [-104.875, 35.216], [-105.035, 35.217], [-105.127, 35.217], [-105.291, 35.216], [-105.291, 35.115], [-105.291, 35.042], [-105.376, 35.042], [-105.489, 35.042], [-105.657, 35.042], [-105.714, 35.042], [-105.715, 35.187], [-105.716, 35.304], [-105.717, 35.304], [-105.718, 35.375], [-105.718, 35.592], [-105.718, 35.644], [-105.716, 35.653], [-105.72, 35.709], [-105.721, 35.75], [-105.721, 35.812], [-105.722, 35.812], [-105.72, 35.871]]] } },
{ "type": "Feature", "properties": { "name": "Catron", "geoid2": "35003", "area": "6923.69", "population": "3651", "popsqmile": "0.52731997", "housing": "3698", "medianage": "56.8", "under18": "527", "over65": "1037", "white": "3405", "hispanic": "733", "englishonly": "2717", "population25": "3039", "highschool": "2778", "bachelor": "644", "laborforce": "1344", "unemploy": "7.1", "personalinc": "32092", "sales2014": "31535543.52" }, "geometry": { "type": "Polygon", "coordinates": [[[-109.046, 34.579], [-108.983, 34.579], [-108.983, 34.58], [-108.877, 34.58], [-108.798, 34.579], [-108.649, 34.579], [-108.625, 34.579], [-108.461, 34.579], [-108.376, 34.579], [-108.188, 34.58], [-108.072, 34.581], [-108.058, 34.579], [-108.001, 34.579], [-107.965, 34.58], [-107.949, 34.579], [-107.896, 34.579], [-107.851, 34.579], [-107.793, 34.579], [-107.725, 34.578], [-107.727, 34.5], [-107.726, 34.371], [-107.725, 34.26], [-107.716, 34.26], [-107.717, 34.089], [-107.716, 33.94], [-107.716, 33.875], [-107.716, 33.826], [-107.711, 33.826], [-107.713, 33.811], [-107.712, 33.722], [-107.713, 33.625], [-107.712, 33.624], [-107.713, 33.5], [-107.713, 33.477], [-107.746, 33.478], [-107.763, 33.477], [-107.861, 33.476], [-107.939, 33.474], [-107.968, 33.478], [-108.001, 33.478], [-108.001, 33.357], [-108.001, 33.202], [-108.22, 33.201], [-108.306, 33.201], [-108.45, 33.201], [-108.543, 33.208], [-108.647, 33.208], [-108.647, 33.209], [-108.75, 33.21], [-108.751, 33.209], [-108.858, 33.209], [-108.957, 33.207], [-109.001, 33.209], [-109.047, 33.209], [-109.047, 33.313], [-109.047, 33.375], [-109.047, 33.41], [-109.047, 33.469], [-109.047, 33.617], [-109.047, 33.739], [-109.047, 33.844], [-109.046, 33.875], [-109.047, 34], [-109.047, 34.174], [-109.047, 34.372], [-109.046, 34.579]]] } },
{ "type": "Feature", "properties": { "name": "Sandoval", "geoid2": "35047", "area": "3710.65", "population": "28899", "popsqmile": "7.788123375", "housing": "15581", "medianage": "41.8", "under18": "6094", "over65": "4844", "white": "17837", "hispanic": "22235", "englishonly": "12045", "population25": "19608", "highschool": "16246", "bachelor": "3997", "laborforce": "11214", "unemploy": "7.7", "personalinc": "31760", "sales2014": "396677243.2" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.248, 35.966], [-106.264, 35.966], [-106.264, 35.973], [-106.3, 35.973], [-106.3, 35.959], [-106.317, 35.959], [-106.315, 35.952], [-106.386, 35.953], [-106.386, 35.96], [-106.4, 35.96], [-106.4, 35.828], [-106.418, 35.828], [-106.418, 35.818], [-106.411, 35.811], [-106.401, 35.808], [-106.382, 35.808], [-106.374, 35.812], [-106.362, 35.811], [-106.357, 35.816], [-106.339, 35.808], [-106.325, 35.807], [-106.283, 35.792], [-106.266, 35.779], [-106.258, 35.77], [-106.254, 35.754], [-106.248, 35.756], [-106.248, 35.625], [-106.249, 35.5], [-106.248, 35.478], [-106.249, 35.414], [-106.249, 35.305], [-106.246, 35.294], [-106.246, 35.25], [-106.245, 35.215], [-106.258, 35.215], [-106.315, 35.217], [-106.363, 35.217], [-106.599, 35.218], [-106.607, 35.217], [-106.623, 35.209], [-106.646, 35.202], [-106.643, 35.207], [-106.658, 35.217], [-106.691, 35.218], [-106.805, 35.218], [-106.848, 35.218], [-107.081, 35.219], [-107.121, 35.218], [-107.131, 35.219], [-107.196, 35.219], [-107.21, 35.248], [-107.214, 35.25], [-107.239, 35.305], [-107.31, 35.305], [-107.31, 35.375], [-107.31, 35.419], [-107.307, 35.419], [-107.309, 35.569], [-107.309, 35.735], [-107.309, 35.75], [-107.309, 35.93], [-107.308, 35.999], [-107.416, 36], [-107.475, 35.999], [-107.532, 36], [-107.627, 36], [-107.626, 36.107], [-107.624, 36.148], [-107.624, 36.22], [-107.501, 36.218], [-107.376, 36.218], [-107.238, 36.216], [-107.126, 36.216], [-106.885, 36.217], [-106.887, 36.125], [-106.885, 36.001], [-106.876, 35.999], [-106.751, 35.999], [-106.616, 36], [-106.501, 36.001], [-106.357, 36.001], [-106.247, 36.002], [-106.247, 35.973], [-106.248, 35.966]]] } },
{ "type": "Feature", "properties": { "name": "Santa Fe", "geoid2": "35049", "area": "1909.41", "population": "146361", "popsqmile": "76.6524738", "housing": "71554", "medianage": "43.9", "under18": "29580", "over65": "25418", "white": "122044", "hispanic": "74650", "englishonly": "89593", "population25": "105598", "highschool": "94696", "bachelor": "44318", "laborforce": "71510", "unemploy": "5.4", "personalinc": "48291", "sales2014": "3971986999" }, "geometry": { "type": "Polygon", "coordinates": [[[-106.248, 35.839], [-106.248, 35.856], [-106.248, 35.873], [-106.246, 35.893], [-106.245, 35.931], [-106.054, 35.931], [-106.054, 35.986], [-106.066, 35.989], [-106.065, 35.997], [-106.071, 36.002], [-105.918, 36.002], [-105.859, 36.002], [-105.717, 36.002], [-105.717, 35.979], [-105.721, 35.875], [-105.72, 35.871], [-105.722, 35.812], [-105.721, 35.812], [-105.721, 35.75], [-105.72, 35.709], [-105.716, 35.653], [-105.718, 35.644], [-105.718, 35.592], [-105.718, 35.375], [-105.717, 35.304], [-105.716, 35.304], [-105.715, 35.187], [-105.714, 35.042], [-105.751, 35.041], [-105.876, 35.042], [-106.077, 35.041], [-106.244, 35.04], [-106.244, 35.167], [-106.245, 35.215], [-106.246, 35.25], [-106.246, 35.294], [-106.249, 35.305], [-106.249, 35.414], [-106.248, 35.478], [-106.249, 35.5], [-106.248, 35.625], [-106.248, 35.756], [-106.241, 35.764], [-106.224, 35.767], [-106.209, 35.777], [-106.196, 35.791], [-106.192, 35.805], [-106.18, 35.81], [-106.178, 35.819], [-106.173, 35.827], [-106.2, 35.83], [-106.213, 35.828], [-106.226, 35.829], [-106.228, 35.832], [-106.241, 35.835], [-106.248, 35.839]]] } },
{ "type": "Feature", "properties": { "name": "Socorro", "geoid2": "35053", "area": "6646.68", "population": "17608", "popsqmile": "2.649142128", "housing": "8024", "medianage": "36.1", "under18": "4432", "over65": "2699", "white": "13872", "hispanic": "8629", "englishonly": "9229", "population25": "11042", "highschool": "8752", "bachelor": "2279", "laborforce": "6449", "unemploy": "7.2", "personalinc": "32712", "sales2014": "226930626.9" }, "geometry": { "type": "Polygon", "coordinates": [[[-107.713, 33.477], [-107.713, 33.5], [-107.712, 33.624], [-107.713, 33.625], [-107.712, 33.722], [-107.713, 33.811], [-107.711, 33.826], [-107.716, 33.826], [-107.716, 33.875], [-107.716, 33.94], [-107.717, 34.089], [-107.716, 34.26], [-107.725, 34.26], [-107.726, 34.371], [-107.727, 34.5], [-107.725, 34.578], [-107.71, 34.578], [-107.691, 34.579], [-107.674, 34.579], [-107.594, 34.58], [-107.551, 34.579], [-107.534, 34.581], [-107.515, 34.579], [-107.41, 34.58], [-107.34, 34.579], [-107.204, 34.579], [-107.09, 34.578], [-106.986, 34.58], [-106.911, 34.581], [-106.883, 34.579], [-106.768, 34.531], [-106.626, 34.491], [-106.505, 34.457], [-106.456, 34.437], [-106.417, 34.44], [-106.416, 34.26], [-106.239, 34.26], [-106.102, 34.26], [-105.924, 34.26], [-105.925, 34.125], [-105.926, 34], [-105.925, 33.983], [-105.926, 33.911], [-105.925, 33.887], [-105.925, 33.826], [-106.053, 33.826], [-106.053, 33.739], [-106.053, 33.65], [-106.159, 33.65], [-106.159, 33.652], [-106.269, 33.66], [-106.374, 33.66], [-106.373, 33.48], [-106.474, 33.48], [-106.474, 33.476], [-106.626, 33.475], [-106.753, 33.476], [-106.943, 33.476], [-107.054, 33.478], [-107.119, 33.479], [-107.125, 33.478], [-107.169, 33.478], [-107.257, 33.478], [-107.385, 33.478], [-107.455, 33.476], [-107.516, 33.476], [-107.598, 33.476], [-107.667, 33.477], [-107.713, 33.477]]] } },
{ "type": "Feature", "properties": { "name": "Lincoln", "geoid2": "35027", "area": "4831.09", "population": "20162", "popsqmile": "4.173385302", "housing": "17597", "medianage": "50.2", "under18": "3760", "over65": "4941", "white": "17234", "hispanic": "6208", "englishonly": "14763", "population25": "15194", "highschool": "13293", "bachelor": "4102", "laborforce": "9014", "unemploy": "5.9", "personalinc": "38115", "sales2014": "535105267.3" }, "geometry": { "type": "Polygon", "coordinates": [[[-105.924, 34.26], [-105.751, 34.26], [-105.685, 34.26], [-105.5, 34.26], [-105.313, 34.26], [-105.313, 34.347], [-105.242, 34.347], [-105.001, 34.347], [-104.892, 34.347], [-104.892, 34.324], [-104.892, 34.233], [-104.893, 34.088], [-104.894, 33.983], [-104.895, 33.824], [-104.891, 33.822], [-104.892, 33.75], [-104.891, 33.737], [-104.892, 33.625], [-104.892, 33.398], [-104.885, 33.393], [-104.885, 33.306], [-104.904, 33.306], [-104.903, 33.25], [-104.906, 33.221], [-104.906, 33.139], [-105.001, 33.139], [-105.007, 33.134], [-105.099, 33.134], [-105.11, 33.132], [-105.251, 33.132], [-105.317, 33.132], [-105.317, 33.214], [-105.319, 33.287], [-105.319, 33.305], [-105.376, 33.305], [-105.556, 33.305], [-105.626, 33.305], [-105.726, 33.305], [-105.726, 33.374], [-105.727, 33.391], [-105.93, 33.39], [-106.019, 33.389], [-106.108, 33.389], [-106.231, 33.39], [-106.251, 33.391], [-106.346, 33.391], [-106.372, 33.391], [-106.373, 33.48], [-106.374, 33.66], [-106.269, 33.66], [-106.159, 33.652], [-106.159, 33.65], [-106.053, 33.65], [-106.053, 33.739], [-106.053, 33.826], [-105.925, 33.826], [-105.925, 33.887], [-105.926, 33.911], [-105.925, 33.983], [-105.926, 34], [-105.925, 34.125], [-105.924, 34.26]]] } },
{ "type": "Feature", "properties": { "name": "McKinley", "geoid2": "35031", "area": "5449.81", "population": "73082", "popsqmile": "13.41000879", "housing": "25795", "medianage": "30.7", "under18": "22371", "over65": "7388", "white": "12174", "hispanic": "10083", "englishonly": "28676", "population25": "42250", "highschool": "30831", "bachelor": "4897", "laborforce": "23798", "unemploy": "9.8", "personalinc": "23789", "sales2014": "1274421153" }, "geometry": { "type": "Polygon", "coordinates": [[[-109.046, 34.96], [-109.046, 35.125], [-109.046, 35.25], [-109.047, 35.362], [-109.047, 35.486], [-109.046, 35.623], [-109.046, 35.757], [-109.046, 35.874], [-109.046, 36.002], [-108.994, 36.003], [-108.835, 36.003], [-108.629, 36.003], [-108.625, 36.003], [-108.473, 36.002], [-108.251, 36.002], [-108.089, 36.003], [-107.876, 36.002], [-107.751, 36.001], [-107.627, 36], [-107.532, 36], [-107.475, 35.999], [-107.416, 36], [-107.308, 35.999], [-107.309, 35.93], [-107.309, 35.75], [-107.309, 35.735], [-107.309, 35.569], [-107.307, 35.419], [-107.31, 35.419], [-107.31, 35.375], [-107.31, 35.305], [-107.376, 35.305], [-107.544, 35.304], [-107.628, 35.305], [-107.628, 35.348], [-107.734, 35.348], [-107.734, 35.305], [-107.959, 35.305], [-108.001, 35.305], [-108.118, 35.306], [-108.202, 35.306], [-108.385, 35.306], [-108.469, 35.307], [-108.468, 35.169], [-108.47, 35.125], [-108.47, 34.999], [-108.469, 34.959], [-108.602, 34.959], [-108.669, 34.96], [-108.742, 34.96], [-108.922, 34.96], [-109.046, 34.96]]] } },
{ "type": "Feature", "properties": { "area": "2965.19", "bachelor": "2246", "englishonly": "11163", "geoid2": "35029", "highschool": "11232", "hispanic": "15802", "housing": "10996", "laborforce": "10623", "medianage": "38.8", "name": "Luna", "over65": "4948", "personalinc": "29055", "popsqmile": "8.413288862", "population": "24947", "population25": "16161", "sales2014": "345418348.1", "under18": "6623", "unemploy": "18", "white": "22416" }, "geometry": { "type": "Polygon", "coordinates": [[[-107.608, 32.605], [-107.534, 32.605], [-107.465, 32.605], [-107.299, 32.606], [-107.298, 32.518], [-107.299, 32.434], [-107.299, 32.244], [-107.298, 32.22], [-107.299, 32.082], [-107.298, 32.082], [-107.297, 31.999], [-107.296, 31.861], [-107.297, 31.784], [-107.422, 31.784], [-107.638, 31.784], [-107.876, 31.784], [-108.081, 31.784], [-108.208, 31.784], [-108.21, 31.784], [-108.21, 31.82], [-108.217, 31.82], [-108.217, 31.864], [-108.217, 32.08], [-108.23, 32.08], [-108.23, 32.131], [-108.23, 32.167], [-108.229, 32.373], [-108.229, 32.517], [-108.074, 32.517], [-107.923, 32.517], [-107.923, 32.604], [-107.757, 32.605], [-107.608, 32.605]]] } },
{ "type": "Feature", "properties": { "name": "Mora", "geoid2": "35033", "area": "1931.27", "population": "4722", "popsqmile": "2.445023223", "housing": "3202", "medianage": "44.1", "under18": "1116", "over65": "1159", "white": "3140", "hispanic": "3981", "englishonly": "1903", "population25": "3172", "highschool": "2548", "bachelor": "257", "laborforce": "2128", "unemploy": "11.1", "personalinc": "32262", "sales2014": "29048302.41" }, "geometry": { "type": "Polygon", "coordinates": [[[-105.72, 35.871], [-105.721, 35.875], [-105.717, 35.979], [-105.708, 35.969], [-105.68, 35.968], [-105.66, 35.959], [-105.645, 35.962], [-105.644, 35.969], [-105.632, 35.98], [-105.605, 35.974], [-105.572, 35.972], [-105.566, 35.975], [-105.557, 35.984], [-105.537, 35.991], [-105.531, 36.001], [-105.53, 36.013], [-105.513, 36.017], [-105.507, 36.021], [-105.495, 36.036], [-105.489, 36.037], [-105.463, 36.078], [-105.434, 36.115], [-105.42, 36.132], [-105.421, 36.149], [-105.415, 36.157], [-105.421, 36.162], [-105.422, 36.17], [-105.397, 36.192], [-105.399, 36.203], [-105.393, 36.216], [-105.399, 36.23], [-105.41, 36.237], [-105.394, 36.244], [-105.387, 36.253], [-105.341, 36.262], [-105.266, 36.262], [-105.167, 36.262], [-105.126, 36.26], [-105.059, 36.26], [-105.024, 36.261], [-104.865, 36.261], [-104.866, 36.218], [-104.758, 36.218], [-104.742, 36.219], [-104.624, 36.218], [-104.436, 36.219], [-104.43, 36.214], [-104.437, 36.196], [-104.434, 36.19], [-104.436, 36.177], [-104.427, 36.178], [-104.425, 36.185], [-104.414, 36.177], [-104.42, 36.168], [-104.404, 36.155], [-104.408, 36.147], [-104.419, 36.145], [-104.417, 36.136], [-104.409, 36.132], [-104.415, 36.124], [-104.403, 36.117], [-104.397, 36.099], [-104.401, 36.092], [-104.386, 36.089], [-104.39, 36.082], [-104.381, 36.076], [-104.377, 36.067], [-104.37, 36.066], [-104.379, 36.055], [-104.379, 36.048], [-104.366, 36.044], [-104.361, 36.035], [-104.361, 36.024], [-104.365, 36.013], [-104.34, 36], [-104.341, 35.992], [-104.356, 35.983], [-104.342, 35.974], [-104.327, 35.961], [-104.336, 35.956], [-104.352, 35.954], [-104.34, 35.945], [-104.342, 35.94], [-104.352, 35.94], [-104.353, 35.922], [-104.346, 35.915], [-104.346, 35.909], [-104.354, 35.908], [-104.351, 35.899], [-104.366, 35.898], [-104.366, 35.892], [-104.359, 35.886], [-104.373, 35.883], [-104.38, 35.874], [-104.38, 35.865], [-104.39, 35.858], [-104.376, 35.85], [-104.382, 35.843], [-104.366, 35.843], [-104.366, 35.839], [-104.38, 35.836], [-104.367, 35.829], [-104.378, 35.824], [-104.375, 35.819], [-104.364, 35.813], [-104.371, 35.805], [-104.365, 35.798], [-104.367, 35.781], [-104.481, 35.781], [-104.724, 35.778], [-104.751, 35.778], [-104.869, 35.775], [-104.876, 35.775], [-104.985, 35.773], [-105.008, 35.771], [-105.025, 35.759], [-105.037, 35.764], [-105.038, 35.77], [-105.051, 35.774], [-105.058, 35.78], [-105.066, 35.78], [-105.082, 35.788], [-105.088, 35.794], [-105.111, 35.808], [-105.128, 35.811], [-105.15, 35.809], [-105.16, 35.819], [-105.181, 35.826], [-105.211, 35.827], [-105.22, 35.835], [-105.238, 35.838], [-105.348, 35.871], [-105.355, 35.871], [-105.567, 35.871], [-105.72, 35.871]]] } },
{ "type": "Feature", "properties": { "name": "Union", "geoid2": "35059", "area": "3823.74", "population": "4413", "popsqmile": "1.154105666", "housing": "2309", "medianage": "40.2", "under18": "898", "over65": "826", "white": "3430", "hispanic": "1785", "englishonly": "2991", "population25": "3116", "highschool": "2502", "bachelor": "593", "laborforce": "1672", "unemploy": "5.1", "personalinc": "32393", "sales2014": "113216244" }, "geometry": { "type": "Polygon", "coordinates": [[[-104.008, 36.996], [-103.892, 36.997], [-103.702, 36.998], [-103.5, 36.999], [-103.252, 37], [-103.123, 37], [-103.002, 37], [-103.002, 36.824], [-103.002, 36.603], [-103.002, 36.501], [-103.042, 36.5], [-103.042, 36.462], [-103.042, 36.316], [-103.041, 36.125], [-103.041, 36], [-103.041, 35.838], [-103.042, 35.825], [-103.041, 35.792], [-103.041, 35.739], [-103.125, 35.74], [-103.197, 35.74], [-103.25, 35.74], [-103.375, 35.74], [-103.375, 35.928], [-103.375, 35.943], [-103.375, 35.999], [-103.365, 35.999], [-103.365, 36.086], [-103.598, 36.087], [-103.626, 36.086], [-103.751, 36.086], [-103.794, 36.086], [-103.794, 36.174], [-104.009, 36.175], [-104.009, 36.218], [-104.008, 36.411], [-104.008, 36.568], [-104.009, 36.686], [-104.007, 36.698], [-104.008, 36.75], [-104.008, 36.875], [-104.008, 36.996]]] } }]}]
<!DOCTYPE html>
<html>
<head>
<style>
@import url('//fonts.googleapis.com/css?family=Lato:400,400italic,700,700italic');
body {
font-family: 'Lato', Arial, Helvetica, sans-serif;
cursor: auto;
font-size:16px;
}
#left {
font: 13px/14px Arial, Helvetica, sans-serif;
font-family: Arial;
float: left;
width: 170px;
line-height: 125%;
}
left h5 {
padding-bottom: 0;
padding-top: 0;
}
#right2 {
font: 13px/14px Arial, Helvetica, sans-serif;
font-family: Arial;
float: right;
}
#right {
font: 13px/14px Arial, Helvetica, sans-serif;
font-family: Arial;
float: right;
width: 95px;
text-align: right;
line-height: 125%;
}
right h5 {
padding-bottom: 0;
padding-top: 0;
}
#map {
height: 650px;
width: 850px;
border: 2px #AAA;
background-color: rgba(255,0,0,0.0);
cursor: default;
shape-rendering: optimizeQuality;
/*font: 13px/14px 'lato',Arial, Helvetica, sans-serif;*/
}
.leaflet-container {
background-color: rgba(255,0,0,0.0);
shape-rendering: auto;
cursor: auto;
}
.leaflet-container a:link {
color: black;
}
.leaflet-container a:visited {
color: black;
}
.leaflet-container a:hover {
color: black;
cursor: pointer;
}
.leaflet.clickable {
cursor: default;
}
.info {
padding: 6px 0;
font: 13px/14px Arial, Helvetica, sans-serif;
font-family: Arial;
background: rgba(255,255,255,0.8);
border-radius: 5px;
fill-opacity: 0.95;
width: 265px;
min-height: 20px;
cursor: text;
}
path.leaflet-clickable {
cursor: default;
}
.info h4 {
margin: 0 0 5px;
color: #777;
}
div.leaflet-popup-pane.popup {
fill-opacity: 0.90;
}
a{
color:black;
position:absolute;
stroke-width:0;
font-size:.93em;
cursor:pointer;
pointer-events:visible;
}
a:link {
color: black;
text-decoration: none;
}
a:visited {
color: black;
text-decoration: none;
}
a:hover {
color: #3366CC;
text-decoration: underline;
}
a:active {
color: black;
text-decoration: none;
}
</style>
<script type="text/javascript" src="countyprofilesmain.js"></script>
<link href="leaflet.css" rel="stylesheet" />
<script type="text/javascript" src="leaflet_noatt.js"></script>
<script type="text/javascript">
window.onload = function () {
map = L.map( 'map', {
center: [34.28, -104.46],
zoom: 7,
zoomControl: false,
dragging: false,
touchZoom: false,
doubleClickZoom: false,
scrollWheelZoom: false,
boxZoom: false,
keyboard: false,
tap: true
} );
county = L.geoJson( getCounties(), {
style: style,
onEachFeature: onEachFeature
} ).addTo( map );
function highlightFeature( e ) {
var layer = e.target;
layer.setStyle( {
weight: 3,
color: '#666',
attributionControl: false
} );
if ( !L.Browser.ie && !L.Browser.opera ) {
layer.bringToFront();
};
info.update( layer.feature.properties )
};
function resetHighlight( e ) {
county.resetStyle( e.target );
info.update(); //This makes it the state data when mouse leaves map
};
function onEachFeature( feature, layer ) {
layer.on( {
mouseover: highlightFeature,
mouseout: resetHighlight
} );
};
//TODO: Make the svg shapes clickable and open new page. Additonally make it open in this page without just changing frame source
//function openLink(props) {(props ? window.open("/" + props.name.toLowerCase()
function style( feature ) {
return {
fillColor: getColor( feature.properties.geoid2 ),
weight: 1.65,
opacity: 1,
color: '#222',
fillOpacity: 1
};
};
var ber = L.divIcon( { className: 'ber', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Bernalillo%20County.html">Bernalillo</a>' } );
var cat = L.divIcon( { className: 'cat', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Catron%20County.html">Catron</a>' } );
var cha = L.divIcon( { className: 'cha', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Chaves%20County.html">Chaves</a>' } );
var cib = L.divIcon( { className: 'cib', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Cibola%20County.html">Cibola</a>' } );
var colf = L.divIcon( { className: 'colf', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Colfax%20County.html">Colfax</a>' } );
var cur = L.divIcon( { className: 'cur', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Curry%20County.html">Curry</a>' } );
var deb = L.divIcon( { className: 'deb', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/De%20Baca%20County.html">De Baca</a>' } );
var don = L.divIcon( { className: 'don', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Dona%20Ana%20County.html">Do&ntilde;a Ana</a>' } );
var edy = L.divIcon( { className: 'edy', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Eddy%20County.html">Eddy</a>' } );
var gra = L.divIcon( { className: 'gra', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Grant%20County.html">Grant</a>' } );
var gua = L.divIcon( { className: 'gua', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Guadalupe%20County.html">Guadalupe</a>' } );
var har = L.divIcon( { className: 'har', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Harding%20County.html">Harding</a>' } );
var hid = L.divIcon( { className: 'hid', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Hidalgo%20County.html">Hidalgo</a>' } );
var lea = L.divIcon( { className: 'lea', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Lea%20County.html">Lea</a>' } );
var lin = L.divIcon( { className: 'lin', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Lincoln%20County.html">Lincoln</a>' } );
var los = L.divIcon( { className: 'los', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Los%20Alamos%20County.html">Los Alamos</a>' } );
var lun = L.divIcon( { className: 'lun', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Luna%20County.html">Luna</a>' } );
var mck = L.divIcon( { className: 'mck', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/McKinley%20County.html">McKinley</a>' } );
var mor = L.divIcon( { className: 'mor', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Mora%20County.html">Mora</a>' } );
var ote = L.divIcon( { className: 'ote', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Otero%20County.html">Otero</a>' } );
var qua = L.divIcon( { className: 'qua', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Quay%20County.html">Quay</a>' } );
var rio = L.divIcon( { className: 'rio', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Rio%20Arriba%20County.html">Rio Arriba</a>' } );
var roo = L.divIcon( { className: 'roo', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Roosevelt%20County.html">Roosevelt</a>' } );
var sand = L.divIcon( { className: 'sand', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Sandoval%20County.html">Sandoval</a>' } );
var sanj = L.divIcon( { className: 'sanj', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/San%20Juan%20County.html">San Juan</a>' } );
var sanm = L.divIcon( { className: 'sanm', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/San%20Miguel%20County.html">San Miguel</a>' } );
var sant = L.divIcon( { className: 'sant', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Santa%20Fe%20County.html">Santa Fe</a>' } );
var sie = L.divIcon( { className: 'sie', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Sierra%20County.html">Sierra</a>' } );
var soc = L.divIcon( { className: 'soc', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Socorro%20County.html">Socorro</a>' } );
var tao = L.divIcon( { className: 'tao', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Taos%20County.html">Taos</a>' } );
var tor = L.divIcon( { className: 'tor', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Torrance%20County.html">Torrance</a>' } );
var uni = L.divIcon( { className: 'uni', iconSize: [10, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Union%20County.html">Union</a>' } );
var val = L.divIcon( { className: 'val', iconSize: [40, 10], html: '<a target="_self" href="http://bber.unm.edu/visualizations/CountyProfile/Valencia%20County.html">Valencia</a>' } );
L.marker( [35.1040019, -106.7990645], { icon: ber } ).addTo( map );
L.marker( [33.9518135, -108.4520974], { icon: cat } ).addTo( map );
L.marker( [33.4116045, -104.5298374], { icon: cha } ).addTo( map );
L.marker( [34.98205, -108.0602545], { icon: cib } ).addTo( map );
L.marker( [36.6629625, -104.7001256], { icon: colf } ).addTo( map );
L.marker( [34.6229841, -103.4060546], { icon: cur } ).addTo( map );
L.marker( [34.4014285, -104.4615274], { icon: deb } ).addTo( map );
L.marker( [32.4009119, -106.8921821], { icon: don } ).addTo( map );
L.marker( [32.5078575, -104.3664708], { icon: edy } ).addTo( map );
L.marker( [32.782087, -108.4415043], { icon: gra } ).addTo( map );
L.marker( [34.9197822, -104.8449677], { icon: gua } ).addTo( map );
L.marker( [35.9131519, -103.8899311], { icon: har } ).addTo( map );
L.marker( [31.8096575, -108.8057292], { icon: hid } ).addTo( map );
L.marker( [32.8456865, -103.4732707], { icon: lea } ).addTo( map );
L.marker( [33.7909407, -105.5090834], { icon: lin } ).addTo( map );
L.marker( [35.89, -106.3279679], { icon: los } ).addTo( map );
L.marker( [32.2344822, -107.8066387], { icon: lun } ).addTo( map );
L.marker( [35.6237323, -108.3153073], { icon: mck } ).addTo( map );
L.marker( [36.0328413, -104.9818975], { icon: mor } ).addTo( map );
L.marker( [32.6387764, -105.8410785], { icon: ote } ).addTo( map );
L.marker( [35.1570184, -103.6080712], { icon: qua } ).addTo( map );
L.marker( [36.5596687, -106.7539829], { icon: rio } ).addTo( map );
L.marker( [34.0714569, -103.5727248], { icon: roo } ).addTo( map );
L.marker( [35.6150734, -106.9626177], { icon: sand } ).addTo( map );
L.marker( [36.5616245, -108.3845778], { icon: sanj } ).addTo( map );
L.marker( [35.5268758, -104.8635146], { icon: sanm } ).addTo( map );
L.marker( [35.5437223, -106.0564409], { icon: sant } ).addTo( map );
L.marker( [33.169479, -107.2481607], { icon: sie } ).addTo( map );
L.marker( [34.0416142, -106.9990026], { icon: soc } ).addTo( map );
L.marker( [36.6265287, -105.6979865], { icon: tao } ).addTo( map );
L.marker( [34.6846444, -105.9068361], { icon: tor } ).addTo( map );
L.marker( [36.5380853, -103.5357229], { icon: uni } ).addTo( map );
L.marker( [34.7668404, -106.9265821], { icon: val } ).addTo( map );
var popup = L.popup( {
closeButton: false,
className: 'popup'
} )
.setLatLng( [35.64, -106.9] )
.setContent( "Click on the label of any county </br> to go to that county's profile page" )
.openOn( map );
county.once( 'mouseover', function ( e ) {
map.closePopup( popup ); //this works but no animation, TODO: use d3 to deflate and remove gradually.
} );
function getColor( d ) {
return d < 35002 ? '#fee08b' :
d < 35004 ? '#abd9e9' :
d < 35006 ? '#99d594' :
d < 35008 ? '#e6f598' :
d < 35010 ? '#99d594' :
d < 35012 ? '#d53e4f' :
d < 35014 ? '#fc8d59' :
d < 35016 ? '#e6f598' :
d < 35018 ? '#e6f598' :
d < 35020 ? '#99d594' :
d < 35022 ? '#d53e4f' :
d < 35024 ? '#fc8d59' :
d < 35026 ? '#abd9e9' :
d < 35028 ? '#abd9e9' :
d < 35030 ? '#d53e4f' :
d < 35032 ? '#d53e4f' :
d < 35034 ? '#fc8d59' :
d < 35036 ? '#fee08b' :
d < 35038 ? '#fee08b' :
d < 35040 ? '#abd9e9' :
d < 35042 ? '#fc8d59' :
d < 35044 ? '#fee08b' :
d < 35046 ? '#abd9e9' :
d < 35048 ? '#fc8d59' :
d < 35050 ? '#99d594' :
d < 35052 ? '#99d594' :
d < 35054 ? '#fc8d59' :
d < 35056 ? '#fee08b' :
d < 35058 ? '#e6f598' :
d < 35060 ? '#99d594' :
d < 35062 ? '#99d594' :
'#666';
};
var info = L.control();
info.onAdd = function ( map ) {
this._div = L.DomUtil.create( 'div', 'info' );
this.update();
return this._div;
};
info.update = function ( props ) {
this._div.innerHTML = ( props ? '<div id="wrap">' +
'<div id="left"><h4>' + props.name + ' County</h4><h5><b>Demographics</b></h5>' +
'Population Estimate:' +
'<br/>Housing Units:' +
'<br/>Persons per Square Mile:' +
'<br/>Median Age:' +
'<br/>Under 18 Years:' +
'<br/>65 Years and Over:' +
'<br/>White:' +
'<br/>Hispanic:' +
'<br />Speak English Only:' +
'<br />High School Graduate:' +
'<br />Bachelor Degree or Higher:' +
'<br /><h5><b>Labor Force Statistics</b></h5>' +
'Labor Force:' +
'<br/>Annual Unemployment Rate:' +
'<br/><h5><b>Economic Indicators</b></h5>' +
'Txbl Gross Receipts + <br/>Food & Med Deduction:' +
'<br/>Per Capita Personal Income:' +
'</div>' +
'<div id="right">' +
'<br/><h5>(2014)</h5>' + formatMoney( props.population ) +
'<br/>' + formatMoney( props.housing ) +
'<br/>' + formatMoney( roundToTwo( props.popsqmile ) ) +
'<br/>' + props.medianage +
'<br/>' + roundToTwo(( props.under18 / props.population ) * 100 ) +
'%<br/>' + roundToTwo(( props.over65 / props.population ) * 100 ) +
'%<br/>' + roundToTwo(( props.white / props.population ) * 100 ) +
'%<br/>' + roundToTwo(( props.hispanic / props.population ) * 100 ) +
'%<br />' + roundToTwo(( props.englishonly / props.population ) * 100 ) +
'%<br />' + roundToTwo(( props.highschool / props.population25 ) * 100 ) +
'%<br />' + roundToTwo(( props.bachelor / props.population25 ) * 100 ) +
'%<h5>&nbsp;</h5>' +
formatMoney( props.laborforce ) +
'<br/>' + props.unemploy +
'%<h5>&nbsp;</h5>' +
'<br/>$' + formatMoney( Math.round( props.sales2014 ) ) +
'<br/>$' + formatMoney( Math.round( props.personalinc ) ) +
'</div>' + '</div>'
: '<div id="wrap">' +
'<div id="left"><h4>' + 'New Mexico' + '</h4><h5><b>Demographics</b></h5>' +
'Population Estimate:' +
'<br/>Housing Units:' +
'<br/>Persons per Square Mile:' +
'<br/>Median Age:' +
'<br/>Under 18 Years:' +
'<br/>65 Years and Over:' +
'<br/>White:' +
'<br/>Hispanic:' +
'<br />Speak English Only:' +
'<br />High School Graduate:' +
'<br />Bachelor Degree or Higher:' +
'<br /><h5><b>Labor Force Statistics</b></h5>' +
'Labor Force:' +
'<br/>Annual Unemployment Rate:' +
'<br/><h5><b>Economic Indicators</b></h5>' +
'Txbl Gross Receipts + <br/>Food & Med Deduction:(mil)' +
'<br/>Per Capita Personal Income:' +
'</div>' +
'<div id="right">' +
'<br/><h5>(2014)</h5>' + formatMoney( '2085572' ) +
'<br/>' + formatMoney( '912890' ) +
'<br/>' + formatMoney( '17.0' ) +
'<br/>' + '37.1' +
'<br/>' + roundToTwo(( 501949 / 2085572 ) * 100 ) +
'%<br/>' + roundToTwo(( 318855 / 2085572 ) * 100 ) +
'%<br/>' + 82.8 +
'%<br/>' + 47.7 +
'%<br />' +
'<br />' + 84.0 +
'%<br />' + 26.1 +
'%<h5>&nbsp;</h5>' +
formatMoney( 915411 ) +
'<br/>' + 6.5 +
'%<h5>&nbsp;</h5>' +
'<br/>$' + formatMoney( 57739 ) +
'<br/>$' + formatMoney( 23948 ) +
'</div>' + '</div>' )
};
info.addTo( map );
function roundToTwo( num ) {
return +( Math.round( num + "e+1" ) + "e-1" );
};
function formatMoney( num ) {
return num.toString().replace( /(\d)(?=(\d{3})+(?!\d))/g, "$1," )
};
};
</script>
</head>
<body>
<div id='map'>
</div>
<span id="source" style="font-size:0.625em;color:grey;">Sources: Nathan Dobie with Census Bureau Annual Estimates of the Resident Population, 2014 American Community Survey, and New Mexico Department of Taxation and Revenue.</span>
</body>
</html>
/* required styles */
.leaflet-map-pane,
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-tile-pane,
.leaflet-tile-container,
.leaflet-overlay-pane,
.leaflet-shadow-pane,
.leaflet-marker-pane,
.leaflet-popup-pane,
.leaflet-overlay-pane svg,
.leaflet-zoom-box,
.leaflet-image-layer,
.leaflet-layer {
position: absolute;
left: 0;
top: 0;
}
.leaflet-container {
overflow: hidden;
touch-action:none;
-ms-touch-action: none;
}
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow {
-webkit-user-select: none;
-moz-user-select: none;
user-select: none;
-webkit-user-drag: none;
}
.leaflet-marker-icon,
.leaflet-marker-shadow {
display: block;
}
/* map is broken in FF if you have max-width: 100% on tiles */
.leaflet-container img {
max-width: none !important;
}
/* stupid Android 2 doesn't understand "max-width: none" properly */
.leaflet-container img.leaflet-image-layer {
max-width: 15000px !important;
}
.leaflet-tile {
filter: inherit;
visibility: hidden;
}
.leaflet-tile-loaded {
visibility: inherit;
}
.leaflet-zoom-box {
width: 0;
height: 0;
}
/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
.leaflet-overlay-pane svg {
-moz-user-select: none;
}
.leaflet-tile-pane { z-index: 2; }
.leaflet-objects-pane { z-index: 3; }
.leaflet-overlay-pane { z-index: 4; }
.leaflet-shadow-pane { z-index: 5; }
.leaflet-marker-pane { z-index: 6; }
.leaflet-popup-pane { z-index: 7; }
.leaflet-vml-shape {
width: 1px;
height: 1px;
}
.lvml {
behavior: url(#default#VML);
display: inline-block;
position: absolute;
}
/* control positioning */
.leaflet-control {
position: relative;
z-index: 7;
pointer-events: auto;
}
.leaflet-top,
.leaflet-bottom {
position: absolute;
z-index: 1000;
pointer-events: none;
}
.leaflet-top {
top: 0;
}
.leaflet-right {
right: 0;
}
.leaflet-bottom {
bottom: 0;
}
.leaflet-left {
left: 0;
}
.leaflet-control {
float: left;
clear: both;
}
.leaflet-right .leaflet-control {
float: right;
}
.leaflet-top .leaflet-control {
margin-top: 10px;
}
.leaflet-bottom .leaflet-control {
margin-bottom: 10px;
}
.leaflet-left .leaflet-control {
margin-left: 10px;
}
.leaflet-right .leaflet-control {
margin-right: 10px;
}
/* zoom and fade animations */
.leaflet-fade-anim .leaflet-tile,
.leaflet-fade-anim .leaflet-popup {
opacity: 0;
-webkit-transition: opacity 0.2s linear;
-moz-transition: opacity 0.2s linear;
-o-transition: opacity 0.2s linear;
transition: opacity 0.2s linear;
}
.leaflet-fade-anim .leaflet-tile-loaded,
.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
opacity: 1;
}
.leaflet-zoom-anim .leaflet-zoom-animated {
-webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
-moz-transition: -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
-o-transition: -o-transform 0.25s cubic-bezier(0,0,0.25,1);
transition: transform 0.25s cubic-bezier(0,0,0.25,1);
}
.leaflet-zoom-anim .leaflet-tile,
.leaflet-pan-anim .leaflet-tile,
.leaflet-touching .leaflet-zoom-animated {
-webkit-transition: none;
-moz-transition: none;
-o-transition: none;
transition: none;
}
.leaflet-zoom-anim .leaflet-zoom-hide {
visibility: hidden;
}
/* cursors */
.leaflet-clickable {
cursor: pointer;
}
.leaflet-container {
cursor: -webkit-grab;
cursor: -moz-grab;
}
.leaflet-popup-pane,
.leaflet-control {
cursor: auto;
}
.leaflet-dragging .leaflet-container,
.leaflet-dragging .leaflet-clickable {
cursor: move;
cursor: -webkit-grabbing;
cursor: -moz-grabbing;
}
/* visual tweaks */
.leaflet-container {
background: #ddd;
outline: 0;
}
.leaflet-container a {
color: #0078A8;
}
.leaflet-container a.leaflet-active {
outline: 2px solid orange;
}
.leaflet-zoom-box {
border: 2px dotted #38f;
background: rgba(255,255,255,0.5);
}
/* general typography */
.leaflet-container {
font: 12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif;
}
/* general toolbar styles */
.leaflet-bar {
box-shadow: 0 1px 5px rgba(0,0,0,0.65);
border-radius: 4px;
}
.leaflet-bar a,
.leaflet-bar a:hover {
background-color: #fff;
border-bottom: 1px solid #ccc;
width: 26px;
height: 26px;
line-height: 26px;
display: block;
text-align: center;
text-decoration: none;
color: black;
}
.leaflet-bar a,
.leaflet-control-layers-toggle {
background-position: 50% 50%;
background-repeat: no-repeat;
display: block;
}
.leaflet-bar a:hover {
background-color: #f4f4f4;
}
.leaflet-bar a:first-child {
border-top-left-radius: 4px;
border-top-right-radius: 4px;
}
.leaflet-bar a:last-child {
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
border-bottom: none;
}
.leaflet-bar a.leaflet-disabled {
cursor: default;
background-color: #f4f4f4;
color: #bbb;
}
.leaflet-touch .leaflet-bar a {
width: 30px;
height: 30px;
line-height: 30px;
}
/* zoom control */
.leaflet-control-zoom-in,
.leaflet-control-zoom-out {
font: bold 18px 'Lucida Console', Monaco, monospace;
text-indent: 1px;
}
.leaflet-control-zoom-out {
font-size: 20px;
}
.leaflet-touch .leaflet-control-zoom-in {
font-size: 22px;
}
.leaflet-touch .leaflet-control-zoom-out {
font-size: 24px;
}
/* layers control */
.leaflet-control-layers {
box-shadow: 0 1px 5px rgba(0,0,0,0.4);
background: #fff;
border-radius: 5px;
}
.leaflet-control-layers-toggle {
background-image: url(images/layers.png);
width: 36px;
height: 36px;
}
.leaflet-retina .leaflet-control-layers-toggle {
background-image: url(images/layers-2x.png);
background-size: 26px 26px;
}
.leaflet-touch .leaflet-control-layers-toggle {
width: 44px;
height: 44px;
}
.leaflet-control-layers .leaflet-control-layers-list,
.leaflet-control-layers-expanded .leaflet-control-layers-toggle {
display: none;
}
.leaflet-control-layers-expanded .leaflet-control-layers-list {
display: block;
position: relative;
}
.leaflet-control-layers-expanded {
padding: 6px 10px 6px 6px;
color: #333;
background: #fff;
}
.leaflet-control-layers-selector {
margin-top: 2px;
position: relative;
top: 1px;
}
.leaflet-control-layers label {
display: block;
}
.leaflet-control-layers-separator {
height: 0;
border-top: 1px solid #ddd;
margin: 5px -10px 5px -6px;
}
/* attribution and scale controls */
.leaflet-container .leaflet-control-attribution {
background: #fff;
background: rgba(255, 255, 255, 0.7);
margin: 0;
}
.leaflet-control-attribution,
.leaflet-control-scale-line {
padding: 0 5px;
color: #333;
}
.leaflet-control-attribution a {
text-decoration: none;
}
.leaflet-control-attribution a:hover {
text-decoration: underline;
}
.leaflet-container .leaflet-control-attribution,
.leaflet-container .leaflet-control-scale {
font-size: 11px;
}
.leaflet-left .leaflet-control-scale {
margin-left: 5px;
}
.leaflet-bottom .leaflet-control-scale {
margin-bottom: 5px;
}
.leaflet-control-scale-line {
border: 2px solid #777;
border-top: none;
line-height: 1.1;
padding: 2px 5px 1px;
font-size: 11px;
white-space: nowrap;
overflow: hidden;
-moz-box-sizing: content-box;
box-sizing: content-box;
background: #fff;
background: rgba(255, 255, 255, 0.5);
}
.leaflet-control-scale-line:not(:first-child) {
border-top: 2px solid #777;
border-bottom: none;
margin-top: -2px;
}
.leaflet-control-scale-line:not(:first-child):not(:last-child) {
border-bottom: 2px solid #777;
}
.leaflet-touch .leaflet-control-attribution,
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
box-shadow: none;
}
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
border: 2px solid rgba(0,0,0,0.2);
background-clip: padding-box;
}
/* popup */
.leaflet-popup {
position: absolute;
text-align: center;
}
.leaflet-popup-content-wrapper {
padding: 1px;
text-align: left;
border-radius: 12px;
}
.leaflet-popup-content {
margin: 13px 19px;
line-height: 1.4;
}
.leaflet-popup-content p {
margin: 18px 0;
}
.leaflet-popup-tip-container {
margin: 0 auto;
width: 40px;
height: 20px;
position: relative;
overflow: hidden;
}
.leaflet-popup-tip {
width: 17px;
height: 17px;
padding: 1px;
margin: -10px auto 0;
-webkit-transform: rotate(45deg);
-moz-transform: rotate(45deg);
-ms-transform: rotate(45deg);
-o-transform: rotate(45deg);
transform: rotate(45deg);
}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
background: white;
box-shadow: 0 3px 14px rgba(0,0,0,0.4);
}
.leaflet-container a.leaflet-popup-close-button {
position: absolute;
top: 0;
right: 0;
padding: 4px 4px 0 0;
text-align: center;
width: 18px;
height: 14px;
font: 16px/14px Tahoma, Verdana, sans-serif;
color: #c3c3c3;
text-decoration: none;
font-weight: bold;
background: transparent;
}
.leaflet-container a.leaflet-popup-close-button:hover {
color: #999;
}
.leaflet-popup-scrolled {
overflow: auto;
border-bottom: 1px solid #ddd;
border-top: 1px solid #ddd;
}
.leaflet-oldie .leaflet-popup-content-wrapper {
zoom: 1;
}
.leaflet-oldie .leaflet-popup-tip {
width: 24px;
margin: 0 auto;
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
}
.leaflet-oldie .leaflet-popup-tip-container {
margin-top: -1px;
}
.leaflet-oldie .leaflet-control-zoom,
.leaflet-oldie .leaflet-control-layers,
.leaflet-oldie .leaflet-popup-content-wrapper,
.leaflet-oldie .leaflet-popup-tip {
border: 1px solid #999;
}
/* div icon */
.leaflet-div-icon {
background: #fff;
border: 1px solid #666;
}
//This is just the standard leaflet library, however it removes any attribution to give it the frameless look.
!function (t, e, i) {
var n = t.L, o = {}; o.version = "0.7.5", "object" == typeof module && "object" == typeof module.exports ? module.exports = o : "function" == typeof define && define.amd && define(o), o.noConflict = function () { return t.L = n, this }, t.L = o, o.Util = { extend: function (t) { var e, i, n, o, s = Array.prototype.slice.call(arguments, 1); for (i = 0, n = s.length; n > i; i++) { o = s[i] || {}; for (e in o) o.hasOwnProperty(e) && (t[e] = o[e]) } return t }, bind: function (t, e) { var i = arguments.length > 2 ? Array.prototype.slice.call(arguments, 2) : null; return function () { return t.apply(e, i || arguments) } }, stamp: function () { var t = 0, e = "_leaflet_id"; return function (i) { return i[e] = i[e] || ++t, i[e] } }(), invokeEach: function (t, e, i) { var n, o; if ("object" == typeof t) { o = Array.prototype.slice.call(arguments, 3); for (n in t) e.apply(i, [n, t[n]].concat(o)); return !0 } return !1 }, limitExecByInterval: function (t, e, i) { var n, o; return function s() { var a = arguments; return n ? void (o = !0) : (n = !0, setTimeout(function () { n = !1, o && (s.apply(i, a), o = !1) }, e), void t.apply(i, a)) } }, falseFn: function () { return !1 }, formatNum: function (t, e) { var i = Math.pow(10, e || 5); return Math.round(t * i) / i }, trim: function (t) { return t.trim ? t.trim() : t.replace(/^\s+|\s+$/g, "") }, splitWords: function (t) { return o.Util.trim(t).split(/\s+/) }, setOptions: function (t, e) { return t.options = o.extend({}, t.options, e), t.options }, getParamString: function (t, e, i) { var n = []; for (var o in t) n.push(encodeURIComponent(i ? o.toUpperCase() : o) + "=" + encodeURIComponent(t[o])); return (e && -1 !== e.indexOf("?") ? "&" : "?") + n.join("&") }, template: function (t, e) { return t.replace(/\{ *([\w_]+) *\}/g, function (t, n) { var o = e[n]; if (o === i) throw new Error("No value provided for variable " + t); return "function" == typeof o && (o = o(e)), o }) }, isArray: Array.isArray || function (t) { return "[object Array]" === Object.prototype.toString.call(t) }, emptyImageUrl: "data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs=" }, function () { function e(e) { var i, n, o = ["webkit", "moz", "o", "ms"]; for (i = 0; i < o.length && !n; i++) n = t[o[i] + e]; return n } function i(e) { var i = +new Date, o = Math.max(0, 16 - (i - n)); return n = i + o, t.setTimeout(e, o) } var n = 0, s = t.requestAnimationFrame || e("RequestAnimationFrame") || i, a = t.cancelAnimationFrame || e("CancelAnimationFrame") || e("CancelRequestAnimationFrame") || function (e) { t.clearTimeout(e) }; o.Util.requestAnimFrame = function (e, n, a, r) { return e = o.bind(e, n), a && s === i ? void e() : s.call(t, e, r) }, o.Util.cancelAnimFrame = function (e) { e && a.call(t, e) } }(), o.extend = o.Util.extend, o.bind = o.Util.bind, o.stamp = o.Util.stamp, o.setOptions = o.Util.setOptions, o.Class = function () { }, o.Class.extend = function (t) { var e = function () { this.initialize && this.initialize.apply(this, arguments), this._initHooks && this.callInitHooks() }, i = function () { }; i.prototype = this.prototype; var n = new i; n.constructor = e, e.prototype = n; for (var s in this) this.hasOwnProperty(s) && "prototype" !== s && (e[s] = this[s]); t.statics && (o.extend(e, t.statics), delete t.statics), t.includes && (o.Util.extend.apply(null, [n].concat(t.includes)), delete t.includes), t.options && n.options && (t.options = o.extend({}, n.options, t.options)), o.extend(n, t), n._initHooks = []; var a = this; return e.__super__ = a.prototype, n.callInitHooks = function () { if (!this._initHooksCalled) { a.prototype.callInitHooks && a.prototype.callInitHooks.call(this), this._initHooksCalled = !0; for (var t = 0, e = n._initHooks.length; e > t; t++) n._initHooks[t].call(this) } }, e }, o.Class.include = function (t) { o.extend(this.prototype, t) }, o.Class.mergeOptions = function (t) { o.extend(this.prototype.options, t) }, o.Class.addInitHook = function (t) { var e = Array.prototype.slice.call(arguments, 1), i = "function" == typeof t ? t : function () { this[t].apply(this, e) }; this.prototype._initHooks = this.prototype._initHooks || [], this.prototype._initHooks.push(i) }; var s = "_leaflet_events"; o.Mixin = {}, o.Mixin.Events = { addEventListener: function (t, e, i) { if (o.Util.invokeEach(t, this.addEventListener, this, e, i)) return this; var n, a, r, h, l, u, c, d = this[s] = this[s] || {}, p = i && i !== this && o.stamp(i); for (t = o.Util.splitWords(t), n = 0, a = t.length; a > n; n++) r = { action: e, context: i || this }, h = t[n], p ? (l = h + "_idx", u = l + "_len", c = d[l] = d[l] || {}, c[p] || (c[p] = [], d[u] = (d[u] || 0) + 1), c[p].push(r)) : (d[h] = d[h] || [], d[h].push(r)); return this }, hasEventListeners: function (t) { var e = this[s]; return !!e && (t in e && e[t].length > 0 || t + "_idx" in e && e[t + "_idx_len"] > 0) }, removeEventListener: function (t, e, i) { if (!this[s]) return this; if (!t) return this.clearAllEventListeners(); if (o.Util.invokeEach(t, this.removeEventListener, this, e, i)) return this; var n, a, r, h, l, u, c, d, p, _ = this[s], m = i && i !== this && o.stamp(i); for (t = o.Util.splitWords(t), n = 0, a = t.length; a > n; n++) if (r = t[n], u = r + "_idx", c = u + "_len", d = _[u], e) { if (h = m && d ? d[m] : _[r]) { for (l = h.length - 1; l >= 0; l--) h[l].action !== e || i && h[l].context !== i || (p = h.splice(l, 1), p[0].action = o.Util.falseFn); i && d && 0 === h.length && (delete d[m], _[c]--) } } else delete _[r], delete _[u], delete _[c]; return this }, clearAllEventListeners: function () { return delete this[s], this }, fireEvent: function (t, e) { if (!this.hasEventListeners(t)) return this; var i, n, a, r, h, l = o.Util.extend({}, e, { type: t, target: this }), u = this[s]; if (u[t]) for (i = u[t].slice(), n = 0, a = i.length; a > n; n++) i[n].action.call(i[n].context, l); r = u[t + "_idx"]; for (h in r) if (i = r[h].slice()) for (n = 0, a = i.length; a > n; n++) i[n].action.call(i[n].context, l); return this }, addOneTimeEventListener: function (t, e, i) { if (o.Util.invokeEach(t, this.addOneTimeEventListener, this, e, i)) return this; var n = o.bind(function () { this.removeEventListener(t, e, i).removeEventListener(t, n, i) }, this); return this.addEventListener(t, e, i).addEventListener(t, n, i) } }, o.Mixin.Events.on = o.Mixin.Events.addEventListener, o.Mixin.Events.off = o.Mixin.Events.removeEventListener, o.Mixin.Events.once = o.Mixin.Events.addOneTimeEventListener, o.Mixin.Events.fire = o.Mixin.Events.fireEvent, function () { var n = "ActiveXObject" in t, s = n && !e.addEventListener, a = navigator.userAgent.toLowerCase(), r = -1 !== a.indexOf("webkit"), h = -1 !== a.indexOf("chrome"), l = -1 !== a.indexOf("phantom"), u = -1 !== a.indexOf("android"), c = -1 !== a.search("android [23]"), d = -1 !== a.indexOf("gecko"), p = typeof orientation != i + "", _ = !t.PointerEvent && t.MSPointerEvent, m = t.PointerEvent && t.navigator.pointerEnabled && t.navigator.maxTouchPoints || _, f = "devicePixelRatio" in t && t.devicePixelRatio > 1 || "matchMedia" in t && t.matchMedia("(min-resolution:144dpi)") && t.matchMedia("(min-resolution:144dpi)").matches, g = e.documentElement, v = n && "transition" in g.style, y = "WebKitCSSMatrix" in t && "m11" in new t.WebKitCSSMatrix && !c, P = "MozPerspective" in g.style, L = "OTransition" in g.style, x = !t.L_DISABLE_3D && (v || y || P || L) && !l, w = !t.L_NO_TOUCH && !l && (m || "ontouchstart" in t || t.DocumentTouch && e instanceof t.DocumentTouch); o.Browser = { ie: n, ielt9: s, webkit: r, gecko: d && !r && !t.opera && !n, android: u, android23: c, chrome: h, ie3d: v, webkit3d: y, gecko3d: P, opera3d: L, any3d: x, mobile: p, mobileWebkit: p && r, mobileWebkit3d: p && y, mobileOpera: p && t.opera, touch: w, msPointer: _, pointer: m, retina: f } }(), o.Point = function (t, e, i) { this.x = i ? Math.round(t) : t, this.y = i ? Math.round(e) : e }, o.Point.prototype = { clone: function () { return new o.Point(this.x, this.y) }, add: function (t) { return this.clone()._add(o.point(t)) }, _add: function (t) { return this.x += t.x, this.y += t.y, this }, subtract: function (t) { return this.clone()._subtract(o.point(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 }, 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 }, distanceTo: function (t) { t = o.point(t); var e = t.x - this.x, i = t.y - this.y; return Math.sqrt(e * e + i * i) }, equals: function (t) { return t = o.point(t), t.x === this.x && t.y === this.y }, contains: function (t) { return t = o.point(t), Math.abs(t.x) <= Math.abs(this.x) && Math.abs(t.y) <= Math.abs(this.y) }, toString: function () { return "Point(" + o.Util.formatNum(this.x) + ", " + o.Util.formatNum(this.y) + ")" } }, o.point = function (t, e, n) { return t instanceof o.Point ? t : o.Util.isArray(t) ? new o.Point(t[0], t[1]) : t === i || null === t ? t : new o.Point(t, e, n) }, o.Bounds = function (t, e) { if (t) for (var i = e ? [t, e] : t, n = 0, o = i.length; o > n; n++) this.extend(i[n]) }, o.Bounds.prototype = { extend: function (t) { return t = o.point(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 o.Point((this.min.x + this.max.x) / 2, (this.min.y + this.max.y) / 2, t) }, getBottomLeft: function () { return new o.Point(this.min.x, this.max.y) }, getTopRight: function () { return new o.Point(this.max.x, this.min.y) }, getSize: function () { return this.max.subtract(this.min) }, contains: function (t) { var e, i; return t = "number" == typeof t[0] || t instanceof o.Point ? o.point(t) : o.bounds(t), t instanceof o.Bounds ? (e = t.min, i = t.max) : e = i = t, e.x >= this.min.x && i.x <= this.max.x && e.y >= this.min.y && i.y <= this.max.y }, intersects: function (t) { t = o.bounds(t); var e = this.min, i = this.max, n = t.min, s = t.max, a = s.x >= e.x && n.x <= i.x, r = s.y >= e.y && n.y <= i.y; return a && r }, isValid: function () { return !(!this.min || !this.max) } }, o.bounds = function (t, e) { return !t || t instanceof o.Bounds ? t : new o.Bounds(t, e) }, o.Transformation = function (t, e, i, n) { this._a = t, this._b = e, this._c = i, this._d = n }, o.Transformation.prototype = { transform: function (t, e) { return this._transform(t.clone(), e) }, _transform: function (t, e) { return e = e || 1, t.x = e * (this._a * t.x + this._b), t.y = e * (this._c * t.y + this._d), t }, untransform: function (t, e) { return e = e || 1, new o.Point((t.x / e - this._b) / this._a, (t.y / e - this._d) / this._c) } }, o.DomUtil = { get: function (t) { return "string" == typeof t ? e.getElementById(t) : t }, getStyle: function (t, i) { var n = t.style[i]; if (!n && t.currentStyle && (n = t.currentStyle[i]), (!n || "auto" === n) && e.defaultView) { var o = e.defaultView.getComputedStyle(t, null); n = o ? o[i] : null } return "auto" === n ? null : n }, getViewportOffset: function (t) { var i, n = 0, s = 0, a = t, r = e.body, h = e.documentElement; do { if (n += a.offsetTop || 0, s += a.offsetLeft || 0, n += parseInt(o.DomUtil.getStyle(a, "borderTopWidth"), 10) || 0, s += parseInt(o.DomUtil.getStyle(a, "borderLeftWidth"), 10) || 0, i = o.DomUtil.getStyle(a, "position"), a.offsetParent === r && "absolute" === i) break; if ("fixed" === i) { n += r.scrollTop || h.scrollTop || 0, s += r.scrollLeft || h.scrollLeft || 0; break } if ("relative" === i && !a.offsetLeft) { var l = o.DomUtil.getStyle(a, "width"), u = o.DomUtil.getStyle(a, "max-width"), c = a.getBoundingClientRect(); ("none" !== l || "none" !== u) && (s += c.left + a.clientLeft), n += c.top + (r.scrollTop || h.scrollTop || 0); break } a = a.offsetParent } while (a); a = t; do { if (a === r) break; n -= a.scrollTop || 0, s -= a.scrollLeft || 0, a = a.parentNode } while (a); return new o.Point(s, n) }, documentIsLtr: function () { return o.DomUtil._docIsLtrCached || (o.DomUtil._docIsLtrCached = !0, o.DomUtil._docIsLtr = "ltr" === o.DomUtil.getStyle(e.body, "direction")), o.DomUtil._docIsLtr }, create: function (t, i, n) { var o = e.createElement(t); return o.className = i, n && n.appendChild(o), o }, hasClass: function (t, e) { if (t.classList !== i) return t.classList.contains(e); var n = o.DomUtil._getClass(t); return n.length > 0 && new RegExp("(^|\\s)" + e + "(\\s|$)").test(n) }, addClass: function (t, e) { if (t.classList !== i) for (var n = o.Util.splitWords(e), s = 0, a = n.length; a > s; s++) t.classList.add(n[s]); else if (!o.DomUtil.hasClass(t, e)) { var r = o.DomUtil._getClass(t); o.DomUtil._setClass(t, (r ? r + " " : "") + e) } }, removeClass: function (t, e) { t.classList !== i ? t.classList.remove(e) : o.DomUtil._setClass(t, o.Util.trim((" " + o.DomUtil._getClass(t) + " ").replace(" " + e + " ", " "))) }, _setClass: function (t, e) { t.className.baseVal === i ? t.className = e : t.className.baseVal = e }, _getClass: function (t) { return t.className.baseVal === i ? t.className : t.className.baseVal }, setOpacity: function (t, e) { if ("opacity" in t.style) t.style.opacity = e; else if ("filter" in t.style) { var i = !1, n = "DXImageTransform.Microsoft.Alpha"; try { i = t.filters.item(n) } catch (o) { if (1 === e) return } e = Math.round(100 * e), i ? (i.Enabled = 100 !== e, i.Opacity = e) : t.style.filter += " progid:" + n + "(opacity=" + e + ")" } }, testProp: function (t) { for (var i = e.documentElement.style, n = 0; n < t.length; n++) if (t[n] in i) return t[n]; return !1 }, getTranslateString: function (t) { var e = o.Browser.webkit3d, i = "translate" + (e ? "3d" : "") + "(", n = (e ? ",0" : "") + ")"; return i + t.x + "px," + t.y + "px" + n }, getScaleString: function (t, e) { var i = o.DomUtil.getTranslateString(e.add(e.multiplyBy(-1 * t))), n = " scale(" + t + ") "; return i + n }, setPosition: function (t, e, i) { t._leaflet_pos = e, !i && o.Browser.any3d ? t.style[o.DomUtil.TRANSFORM] = o.DomUtil.getTranslateString(e) : (t.style.left = e.x + "px", t.style.top = e.y + "px") }, getPosition: function (t) { return t._leaflet_pos } }, o.DomUtil.TRANSFORM = o.DomUtil.testProp(["transform", "WebkitTransform", "OTransform", "MozTransform", "msTransform"]), o.DomUtil.TRANSITION = o.DomUtil.testProp(["webkitTransition", "transition", "OTransition", "MozTransition", "msTransition"]), o.DomUtil.TRANSITION_END = "webkitTransition" === o.DomUtil.TRANSITION || "OTransition" === o.DomUtil.TRANSITION ? o.DomUtil.TRANSITION + "End" : "transitionend", function () { if ("onselectstart" in e) o.extend(o.DomUtil, { disableTextSelection: function () { o.DomEvent.on(t, "selectstart", o.DomEvent.preventDefault) }, enableTextSelection: function () { o.DomEvent.off(t, "selectstart", o.DomEvent.preventDefault) } }); else { var i = o.DomUtil.testProp(["userSelect", "WebkitUserSelect", "OUserSelect", "MozUserSelect", "msUserSelect"]); o.extend(o.DomUtil, { disableTextSelection: function () { if (i) { var t = e.documentElement.style; this._userSelect = t[i], t[i] = "none" } }, enableTextSelection: function () { i && (e.documentElement.style[i] = this._userSelect, delete this._userSelect) } }) } o.extend(o.DomUtil, { disableImageDrag: function () { o.DomEvent.on(t, "dragstart", o.DomEvent.preventDefault) }, enableImageDrag: function () { o.DomEvent.off(t, "dragstart", o.DomEvent.preventDefault) } }) }(), o.LatLng = function (t, e, n) { if (t = parseFloat(t), e = parseFloat(e), isNaN(t) || isNaN(e)) throw new Error("Invalid LatLng object: (" + t + ", " + e + ")"); this.lat = t, this.lng = e, n !== i && (this.alt = parseFloat(n)) }, o.extend(o.LatLng, { DEG_TO_RAD: Math.PI / 180, RAD_TO_DEG: 180 / Math.PI, MAX_MARGIN: 1e-9 }), o.LatLng.prototype = { equals: function (t) { if (!t) return !1; t = o.latLng(t); var e = Math.max(Math.abs(this.lat - t.lat), Math.abs(this.lng - t.lng)); return e <= o.LatLng.MAX_MARGIN }, toString: function (t) { return "LatLng(" + o.Util.formatNum(this.lat, t) + ", " + o.Util.formatNum(this.lng, t) + ")" }, distanceTo: function (t) { t = o.latLng(t); var e = 6378137, i = o.LatLng.DEG_TO_RAD, n = (t.lat - this.lat) * i, s = (t.lng - this.lng) * i, a = this.lat * i, r = t.lat * i, h = Math.sin(n / 2), l = Math.sin(s / 2), u = h * h + l * l * Math.cos(a) * Math.cos(r); return 2 * e * Math.atan2(Math.sqrt(u), Math.sqrt(1 - u)) }, wrap: function (t, e) { var i = this.lng; return t = t || -180, e = e || 180, i = (i + e) % (e - t) + (t > i || i === e ? e : t), new o.LatLng(this.lat, i) } }, o.latLng = function (t, e) { return t instanceof o.LatLng ? t : o.Util.isArray(t) ? "number" == typeof t[0] || "string" == typeof t[0] ? new o.LatLng(t[0], t[1], t[2]) : null : t === i || null === t ? t : "object" == typeof t && "lat" in t ? new o.LatLng(t.lat, "lng" in t ? t.lng : t.lon) : e === i ? null : new o.LatLng(t, e) }, o.LatLngBounds = function (t, e) { if (t) for (var i = e ? [t, e] : t, n = 0, o = i.length; o > n; n++) this.extend(i[n]) }, o.LatLngBounds.prototype = { extend: function (t) { if (!t) return this; var e = o.latLng(t); return t = null !== e ? e : o.latLngBounds(t), t instanceof o.LatLng ? this._southWest || this._northEast ? (this._southWest.lat = Math.min(t.lat, this._southWest.lat), this._southWest.lng = Math.min(t.lng, this._southWest.lng), this._northEast.lat = Math.max(t.lat, this._northEast.lat), this._northEast.lng = Math.max(t.lng, this._northEast.lng)) : (this._southWest = new o.LatLng(t.lat, t.lng), this._northEast = new o.LatLng(t.lat, t.lng)) : t instanceof o.LatLngBounds && (this.extend(t._southWest), this.extend(t._northEast)), this }, pad: function (t) { var e = this._southWest, i = this._northEast, n = Math.abs(e.lat - i.lat) * t, s = Math.abs(e.lng - i.lng) * t; return new o.LatLngBounds(new o.LatLng(e.lat - n, e.lng - s), new o.LatLng(i.lat + n, i.lng + s)) }, getCenter: function () { return new o.LatLng((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 o.LatLng(this.getNorth(), this.getWest()) }, getSouthEast: function () { return new o.LatLng(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 o.LatLng ? o.latLng(t) : o.latLngBounds(t); var e, i, n = this._southWest, s = this._northEast; return t instanceof o.LatLngBounds ? (e = t.getSouthWest(), i = t.getNorthEast()) : e = i = t, e.lat >= n.lat && i.lat <= s.lat && e.lng >= n.lng && i.lng <= s.lng }, intersects: function (t) { t = o.latLngBounds(t); var e = this._southWest, i = this._northEast, n = t.getSouthWest(), s = t.getNorthEast(), a = s.lat >= e.lat && n.lat <= i.lat, r = s.lng >= e.lng && n.lng <= i.lng; return a && r }, toBBoxString: function () { return [this.getWest(), this.getSouth(), this.getEast(), this.getNorth()].join(",") }, equals: function (t) { return t ? (t = o.latLngBounds(t), this._southWest.equals(t.getSouthWest()) && this._northEast.equals(t.getNorthEast())) : !1 }, isValid: function () { return !(!this._southWest || !this._northEast) } }, o.latLngBounds = function (t, e) { return !t || t instanceof o.LatLngBounds ? t : new o.LatLngBounds(t, e) }, o.Projection = {}, o.Projection.SphericalMercator = { MAX_LATITUDE: 85.0511287798, project: function (t) { var e = o.LatLng.DEG_TO_RAD, i = this.MAX_LATITUDE, n = Math.max(Math.min(i, t.lat), -i), s = t.lng * e, a = n * e; return a = Math.log(Math.tan(Math.PI / 4 + a / 2)), new o.Point(s, a) }, unproject: function (t) { var e = o.LatLng.RAD_TO_DEG, i = t.x * e, n = (2 * Math.atan(Math.exp(t.y)) - Math.PI / 2) * e; return new o.LatLng(n, i) } }, o.Projection.LonLat = { project: function (t) { return new o.Point(t.lng, t.lat) }, unproject: function (t) { return new o.LatLng(t.y, t.x) } }, o.CRS = { latLngToPoint: function (t, e) { var i = this.projection.project(t), n = this.scale(e); return this.transformation._transform(i, n) }, pointToLatLng: function (t, e) { var i = this.scale(e), n = this.transformation.untransform(t, i); return this.projection.unproject(n) }, project: function (t) { return this.projection.project(t) }, scale: function (t) { return 256 * Math.pow(2, t) }, getSize: function (t) { var e = this.scale(t); return o.point(e, e) } }, o.CRS.Simple = o.extend({}, o.CRS, { projection: o.Projection.LonLat, transformation: new o.Transformation(1, 0, -1, 0), scale: function (t) { return Math.pow(2, t) } }), o.CRS.EPSG3857 = o.extend({}, o.CRS, { code: "EPSG:3857", projection: o.Projection.SphericalMercator, transformation: new o.Transformation(.5 / Math.PI, .5, -.5 / Math.PI, .5), project: function (t) { var e = this.projection.project(t), i = 6378137; return e.multiplyBy(i) } }), o.CRS.EPSG900913 = o.extend({}, o.CRS.EPSG3857, { code: "EPSG:900913" }), o.CRS.EPSG4326 = o.extend({}, o.CRS, { code: "EPSG:4326", projection: o.Projection.LonLat, transformation: new o.Transformation(1 / 360, .5, -1 / 360, .5) }), o.Map = o.Class.extend({ includes: o.Mixin.Events, options: { crs: o.CRS.EPSG3857, fadeAnimation: o.DomUtil.TRANSITION && !o.Browser.android23, trackResize: !0, markerZoomAnimation: o.DomUtil.TRANSITION && o.Browser.any3d }, initialize: function (t, e) { e = o.setOptions(this, e), this._initContainer(t), this._initLayout(), this._onResize = o.bind(this._onResize, this), this._initEvents(), e.maxBounds && this.setMaxBounds(e.maxBounds), e.center && e.zoom !== i && this.setView(o.latLng(e.center), e.zoom, { reset: !0 }), this._handlers = [], this._layers = {}, this._zoomBoundLayers = {}, this._tileLayersNum = 0, this.callInitHooks(), this._addLayers(e.layers) }, setView: function (t, e) { return e = e === i ? this.getZoom() : e, this._resetView(o.latLng(t), this._limitZoom(e)), this }, setZoom: function (t, e) { return this._loaded ? this.setView(this.getCenter(), t, { zoom: e }) : (this._zoom = this._limitZoom(t), this) }, zoomIn: function (t, e) { return this.setZoom(this._zoom + (t || 1), e) }, zoomOut: function (t, e) { return this.setZoom(this._zoom - (t || 1), e) }, setZoomAround: function (t, e, i) { var n = this.getZoomScale(e), s = this.getSize().divideBy(2), a = t instanceof o.Point ? t : this.latLngToContainerPoint(t), r = a.subtract(s).multiplyBy(1 - 1 / n), h = this.containerPointToLatLng(s.add(r)); return this.setView(h, e, { zoom: i }) }, fitBounds: function (t, e) { e = e || {}, t = t.getBounds ? t.getBounds() : o.latLngBounds(t); var i = o.point(e.paddingTopLeft || e.padding || [0, 0]), n = o.point(e.paddingBottomRight || e.padding || [0, 0]), s = this.getBoundsZoom(t, !1, i.add(n)); s = e.maxZoom ? Math.min(e.maxZoom, s) : s; var a = n.subtract(i).divideBy(2), r = this.project(t.getSouthWest(), s), h = this.project(t.getNorthEast(), s), l = this.unproject(r.add(h).divideBy(2).add(a), s); return this.setView(l, s, e) }, fitWorld: function (t) { return this.fitBounds([[-90, -180], [90, 180]], t) }, panTo: function (t, e) { return this.setView(t, this._zoom, { pan: e }) }, panBy: function (t) { return this.fire("movestart"), this._rawPanBy(o.point(t)), this.fire("move"), this.fire("moveend") }, setMaxBounds: function (t) { return t = o.latLngBounds(t), this.options.maxBounds = t, t ? (this._loaded && this._panInsideMaxBounds(), this.on("moveend", this._panInsideMaxBounds, this)) : this.off("moveend", this._panInsideMaxBounds, this) }, panInsideBounds: function (t, e) { var i = this.getCenter(), n = this._limitCenter(i, this._zoom, t); return i.equals(n) ? this : this.panTo(n, e) }, addLayer: function (t) { var e = o.stamp(t); return this._layers[e] ? this : (this._layers[e] = t, !t.options || isNaN(t.options.maxZoom) && isNaN(t.options.minZoom) || (this._zoomBoundLayers[e] = t, this._updateZoomLevels()), this.options.zoomAnimation && o.TileLayer && t instanceof o.TileLayer && (this._tileLayersNum++, this._tileLayersToLoad++, t.on("load", this._onTileLayerLoad, this)), this._loaded && this._layerAdd(t), this) }, removeLayer: function (t) { var e = o.stamp(t); return this._layers[e] ? (this._loaded && t.onRemove(this), delete this._layers[e], this._loaded && this.fire("layerremove", { layer: t }), this._zoomBoundLayers[e] && (delete this._zoomBoundLayers[e], this._updateZoomLevels()), this.options.zoomAnimation && o.TileLayer && t instanceof o.TileLayer && (this._tileLayersNum--, this._tileLayersToLoad--, t.off("load", this._onTileLayerLoad, this)), this) : this }, hasLayer: function (t) { return t ? o.stamp(t) in this._layers : !1 }, eachLayer: function (t, e) { for (var i in this._layers) t.call(e, this._layers[i]); return this }, invalidateSize: function (t) { if (!this._loaded) return this; t = o.extend({ animate: !1, pan: !0 }, t === !0 ? { animate: !0 } : t); var e = this.getSize(); this._sizeChanged = !0, this._initialCenter = null; var i = this.getSize(), n = e.divideBy(2).round(), s = i.divideBy(2).round(), a = n.subtract(s); return a.x || a.y ? (t.animate && t.pan ? this.panBy(a) : (t.pan && this._rawPanBy(a), this.fire("move"), t.debounceMoveend ? (clearTimeout(this._sizeTimer), this._sizeTimer = setTimeout(o.bind(this.fire, this, "moveend"), 200)) : this.fire("moveend")), this.fire("resize", { oldSize: e, newSize: i })) : this }, addHandler: function (t, e) { if (!e) return this; var i = this[t] = new e(this); return this._handlers.push(i), this.options[t] && i.enable(), this }, remove: function () { this._loaded && this.fire("unload"), this._initEvents("off"); try { delete this._container._leaflet } catch (t) { this._container._leaflet = i } return this._clearPanes(), this._clearControlPos && this._clearControlPos(), this._clearHandlers(), this }, getCenter: function () { return this._checkIfLoaded(), this._initialCenter && !this._moved() ? this._initialCenter : this.layerPointToLatLng(this._getCenterLayerPoint()) }, getZoom: function () { return this._zoom }, getBounds: function () { var t = this.getPixelBounds(), e = this.unproject(t.getBottomLeft()), i = this.unproject(t.getTopRight()); return new o.LatLngBounds(e, i) }, getMinZoom: function () { return this.options.minZoom === i ? this._layersMinZoom === i ? 0 : this._layersMinZoom : this.options.minZoom }, getMaxZoom: function () { return this.options.maxZoom === i ? this._layersMaxZoom === i ? 1 / 0 : this._layersMaxZoom : this.options.maxZoom }, getBoundsZoom: function (t, e, i) { t = o.latLngBounds(t); var n, s = this.getMinZoom() - (e ? 1 : 0), a = this.getMaxZoom(), r = this.getSize(), h = t.getNorthWest(), l = t.getSouthEast(), u = !0; i = o.point(i || [0, 0]); do s++, n = this.project(l, s).subtract(this.project(h, s)).add(i), u = e ? n.x < r.x || n.y < r.y : r.contains(n); while (u && a >= s); return u && e ? null : e ? s : s - 1 }, getSize: function () { return (!this._size || this._sizeChanged) && (this._size = new o.Point(this._container.clientWidth, this._container.clientHeight), this._sizeChanged = !1), this._size.clone() }, getPixelBounds: function () { var t = this._getTopLeftPoint(); return new o.Bounds(t, t.add(this.getSize())) }, getPixelOrigin: function () { return this._checkIfLoaded(), this._initialTopLeftPoint }, getPanes: function () { return this._panes }, getContainer: function () { return this._container }, getZoomScale: function (t) { var e = this.options.crs; return e.scale(t) / e.scale(this._zoom) }, getScaleZoom: function (t) { return this._zoom + Math.log(t) / Math.LN2 }, project: function (t, e) { return e = e === i ? this._zoom : e, this.options.crs.latLngToPoint(o.latLng(t), e) }, unproject: function (t, e) { return e = e === i ? this._zoom : e, this.options.crs.pointToLatLng(o.point(t), e) }, layerPointToLatLng: function (t) { var e = o.point(t).add(this.getPixelOrigin()); return this.unproject(e) }, latLngToLayerPoint: function (t) { var e = this.project(o.latLng(t))._round(); return e._subtract(this.getPixelOrigin()) }, containerPointToLayerPoint: function (t) { return o.point(t).subtract(this._getMapPanePos()) }, layerPointToContainerPoint: function (t) { return o.point(t).add(this._getMapPanePos()) }, containerPointToLatLng: function (t) { var e = this.containerPointToLayerPoint(o.point(t)); return this.layerPointToLatLng(e) }, latLngToContainerPoint: function (t) { return this.layerPointToContainerPoint(this.latLngToLayerPoint(o.latLng(t))) }, mouseEventToContainerPoint: function (t) { return o.DomEvent.getMousePosition(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 e = this._container = o.DomUtil.get(t); if (!e) throw new Error("Map container not found."); if (e._leaflet) throw new Error("Map container is already initialized."); e._leaflet = !0 }, _initLayout: function () { var t = this._container; o.DomUtil.addClass(t, "leaflet-container" + (o.Browser.touch ? " leaflet-touch" : "") + (o.Browser.retina ? " leaflet-retina" : "") + (o.Browser.ielt9 ? " leaflet-oldie" : "") + (this.options.fadeAnimation ? " leaflet-fade-anim" : "")); var e = o.DomUtil.getStyle(t, "position"); "absolute" !== e && "relative" !== e && "fixed" !== e && (t.style.position = "relative"), this._initPanes(), this._initControlPos && this._initControlPos() }, _initPanes: function () { var t = this._panes = {}; this._mapPane = t.mapPane = this._createPane("leaflet-map-pane", this._container), this._tilePane = t.tilePane = this._createPane("leaflet-tile-pane", this._mapPane), t.objectsPane = this._createPane("leaflet-objects-pane", this._mapPane), t.shadowPane = this._createPane("leaflet-shadow-pane"), t.overlayPane = this._createPane("leaflet-overlay-pane"), t.markerPane = this._createPane("leaflet-marker-pane"), t.popupPane = this._createPane("leaflet-popup-pane"); var e = " leaflet-zoom-hide"; this.options.markerZoomAnimation || (o.DomUtil.addClass(t.markerPane, e), o.DomUtil.addClass(t.shadowPane, e), o.DomUtil.addClass(t.popupPane, e)) }, _createPane: function (t, e) { return o.DomUtil.create("div", t, e || this._panes.objectsPane) }, _clearPanes: function () { this._container.removeChild(this._mapPane) }, _addLayers: function (t) { t = t ? o.Util.isArray(t) ? t : [t] : []; for (var e = 0, i = t.length; i > e; e++) this.addLayer(t[e]) }, _resetView: function (t, e, i, n) { var s = this._zoom !== e; n || (this.fire("movestart"), s && this.fire("zoomstart")), this._zoom = e, this._initialCenter = t, this._initialTopLeftPoint = this._getNewTopLeftPoint(t), i ? this._initialTopLeftPoint._add(this._getMapPanePos()) : o.DomUtil.setPosition(this._mapPane, new o.Point(0, 0)), this._tileLayersToLoad = this._tileLayersNum; var a = !this._loaded; this._loaded = !0, this.fire("viewreset", { hard: !i }), a && (this.fire("load"), this.eachLayer(this._layerAdd, this)), this.fire("move"), (s || n) && this.fire("zoomend"), this.fire("moveend", { hard: !i }) }, _rawPanBy: function (t) { o.DomUtil.setPosition(this._mapPane, this._getMapPanePos().subtract(t)) }, _getZoomSpan: function () { return this.getMaxZoom() - this.getMinZoom() }, _updateZoomLevels: function () { var t, e = 1 / 0, n = -(1 / 0), o = this._getZoomSpan(); for (t in this._zoomBoundLayers) { var s = this._zoomBoundLayers[t]; isNaN(s.options.minZoom) || (e = Math.min(e, s.options.minZoom)), isNaN(s.options.maxZoom) || (n = Math.max(n, s.options.maxZoom)) } t === i ? this._layersMaxZoom = this._layersMinZoom = i : (this._layersMaxZoom = n, this._layersMinZoom = e), o !== this._getZoomSpan() && this.fire("zoomlevelschange") }, _panInsideMaxBounds: function () { this.panInsideBounds(this.options.maxBounds) }, _checkIfLoaded: function () { if (!this._loaded) throw new Error("Set map center and zoom first.") }, _initEvents: function (e) { if (o.DomEvent) { e = e || "on", o.DomEvent[e](this._container, "click", this._onMouseClick, this); var i, n, s = ["dblclick", "mousedown", "mouseup", "mouseenter", "mouseleave", "mousemove", "contextmenu"]; for (i = 0, n = s.length; n > i; i++) o.DomEvent[e](this._container, s[i], this._fireMouseEvent, this); this.options.trackResize && o.DomEvent[e](t, "resize", this._onResize, this) } }, _onResize: function () { o.Util.cancelAnimFrame(this._resizeRequest), this._resizeRequest = o.Util.requestAnimFrame(function () { this.invalidateSize({ debounceMoveend: !0 }) }, this, !1, this._container) }, _onMouseClick: function (t) { !this._loaded || !t._simulated && (this.dragging && this.dragging.moved() || this.boxZoom && this.boxZoom.moved()) || o.DomEvent._skipped(t) || (this.fire("preclick"), this._fireMouseEvent(t)) }, _fireMouseEvent: function (t) { if (this._loaded && !o.DomEvent._skipped(t)) { var e = t.type; if (e = "mouseenter" === e ? "mouseover" : "mouseleave" === e ? "mouseout" : e, this.hasEventListeners(e)) { "contextmenu" === e && o.DomEvent.preventDefault(t); var i = this.mouseEventToContainerPoint(t), n = this.containerPointToLayerPoint(i), s = this.layerPointToLatLng(n); this.fire(e, { latlng: s, layerPoint: n, containerPoint: i, originalEvent: t }) } } }, _onTileLayerLoad: function () { this._tileLayersToLoad--, this._tileLayersNum && !this._tileLayersToLoad && this.fire("tilelayersload") }, _clearHandlers: function () { for (var t = 0, e = this._handlers.length; e > t; t++) this._handlers[t].disable() }, whenReady: function (t, e) { return this._loaded ? t.call(e || this, this) : this.on("load", t, e), this }, _layerAdd: function (t) { t.onAdd(this), this.fire("layeradd", { layer: t }) }, _getMapPanePos: function () { return o.DomUtil.getPosition(this._mapPane) }, _moved: function () { var t = this._getMapPanePos(); return t && !t.equals([0, 0]) }, _getTopLeftPoint: function () { return this.getPixelOrigin().subtract(this._getMapPanePos()) }, _getNewTopLeftPoint: function (t, e) { var i = this.getSize()._divideBy(2); return this.project(t, e)._subtract(i)._round() }, _latLngToNewLayerPoint: function (t, e, i) { var n = this._getNewTopLeftPoint(i, e).add(this._getMapPanePos()); return this.project(t, e)._subtract(n) }, _getCenterLayerPoint: function () { return this.containerPointToLayerPoint(this.getSize()._divideBy(2)) }, _getCenterOffset: function (t) { return this.latLngToLayerPoint(t).subtract(this._getCenterLayerPoint()) }, _limitCenter: function (t, e, i) { if (!i) return t; var n = this.project(t, e), s = this.getSize().divideBy(2), a = new o.Bounds(n.subtract(s), n.add(s)), r = this._getBoundsOffset(a, i, e); return this.unproject(n.add(r), e) }, _limitOffset: function (t, e) { if (!e) return t; var i = this.getPixelBounds(), n = new o.Bounds(i.min.add(t), i.max.add(t)); return t.add(this._getBoundsOffset(n, e)) }, _getBoundsOffset: function (t, e, i) { var n = this.project(e.getNorthWest(), i).subtract(t.min), s = this.project(e.getSouthEast(), i).subtract(t.max), a = this._rebound(n.x, -s.x), r = this._rebound(n.y, -s.y); return new o.Point(a, r) }, _rebound: function (t, e) { return t + e > 0 ? Math.round(t - e) / 2 : Math.max(0, Math.ceil(t)) - Math.max(0, Math.floor(e)) }, _limitZoom: function (t) { var e = this.getMinZoom(), i = this.getMaxZoom(); return Math.max(e, Math.min(i, t)) } }), o.map = function (t, e) { return new o.Map(t, e) }, o.Projection.Mercator = { MAX_LATITUDE: 85.0840591556, R_MINOR: 6356752.314245179, R_MAJOR: 6378137, project: function (t) { var e = o.LatLng.DEG_TO_RAD, i = this.MAX_LATITUDE, n = Math.max(Math.min(i, t.lat), -i), s = this.R_MAJOR, a = this.R_MINOR, r = t.lng * e * s, h = n * e, l = a / s, u = Math.sqrt(1 - l * l), c = u * Math.sin(h); c = Math.pow((1 - c) / (1 + c), .5 * u); var d = Math.tan(.5 * (.5 * Math.PI - h)) / c; return h = -s * Math.log(d), new o.Point(r, h) }, unproject: function (t) { for (var e, i = o.LatLng.RAD_TO_DEG, n = this.R_MAJOR, s = this.R_MINOR, a = t.x * i / n, r = s / n, h = Math.sqrt(1 - r * r), l = Math.exp(-t.y / n), u = Math.PI / 2 - 2 * Math.atan(l), c = 15, d = 1e-7, p = c, _ = .1; Math.abs(_) > d && --p > 0;) e = h * Math.sin(u), _ = Math.PI / 2 - 2 * Math.atan(l * Math.pow((1 - e) / (1 + e), .5 * h)) - u, u += _; return new o.LatLng(u * i, a) } }, o.CRS.EPSG3395 = o.extend({}, o.CRS, {
code: "EPSG:3395",
projection: o.Projection.Mercator, transformation: function () { var t = o.Projection.Mercator, e = t.R_MAJOR, i = .5 / (Math.PI * e); return new o.Transformation(i, .5, -i, .5) }()
}), o.TileLayer = o.Class.extend({ includes: o.Mixin.Events, options: { minZoom: 0, maxZoom: 18, tileSize: 256, subdomains: "abc", errorTileUrl: "", attribution: "", zoomOffset: 0, opacity: 1, unloadInvisibleTiles: o.Browser.mobile, updateWhenIdle: o.Browser.mobile }, initialize: function (t, e) { e = o.setOptions(this, e), e.detectRetina && o.Browser.retina && e.maxZoom > 0 && (e.tileSize = Math.floor(e.tileSize / 2), e.zoomOffset++, e.minZoom > 0 && e.minZoom--, this.options.maxZoom--), e.bounds && (e.bounds = o.latLngBounds(e.bounds)), this._url = t; var i = this.options.subdomains; "string" == typeof i && (this.options.subdomains = i.split("")) }, onAdd: function (t) { this._map = t, this._animated = t._zoomAnimated, this._initContainer(), t.on({ viewreset: this._reset, moveend: this._update }, this), this._animated && t.on({ zoomanim: this._animateZoom, zoomend: this._endZoomAnim }, this), this.options.updateWhenIdle || (this._limitedUpdate = o.Util.limitExecByInterval(this._update, 150, this), t.on("move", this._limitedUpdate, this)), this._reset(), this._update() }, addTo: function (t) { return t.addLayer(this), this }, onRemove: function (t) { this._container.parentNode.removeChild(this._container), t.off({ viewreset: this._reset, moveend: this._update }, this), this._animated && t.off({ zoomanim: this._animateZoom, zoomend: this._endZoomAnim }, this), this.options.updateWhenIdle || t.off("move", this._limitedUpdate, this), this._container = null, this._map = null }, bringToFront: function () { var t = this._map._panes.tilePane; return this._container && (t.appendChild(this._container), this._setAutoZIndex(t, Math.max)), this }, bringToBack: function () { var t = this._map._panes.tilePane; return this._container && (t.insertBefore(this._container, t.firstChild), this._setAutoZIndex(t, Math.min)), this }, getAttribution: function () { return this.options.attribution }, getContainer: function () { return this._container }, setOpacity: function (t) { return this.options.opacity = t, this._map && this._updateOpacity(), this }, setZIndex: function (t) { return this.options.zIndex = t, this._updateZIndex(), this }, setUrl: function (t, e) { return this._url = t, e || this.redraw(), this }, redraw: function () { return this._map && (this._reset({ hard: !0 }), this._update()), this }, _updateZIndex: function () { this._container && this.options.zIndex !== i && (this._container.style.zIndex = this.options.zIndex) }, _setAutoZIndex: function (t, e) { var i, n, o, s = t.children, a = -e(1 / 0, -(1 / 0)); for (n = 0, o = s.length; o > n; n++) s[n] !== this._container && (i = parseInt(s[n].style.zIndex, 10), isNaN(i) || (a = e(a, i))); this.options.zIndex = this._container.style.zIndex = (isFinite(a) ? a : 0) + e(1, -1) }, _updateOpacity: function () { var t, e = this._tiles; if (o.Browser.ielt9) for (t in e) o.DomUtil.setOpacity(e[t], this.options.opacity); else o.DomUtil.setOpacity(this._container, this.options.opacity) }, _initContainer: function () { var t = this._map._panes.tilePane; if (!this._container) { if (this._container = o.DomUtil.create("div", "leaflet-layer"), this._updateZIndex(), this._animated) { var e = "leaflet-tile-container"; this._bgBuffer = o.DomUtil.create("div", e, this._container), this._tileContainer = o.DomUtil.create("div", e, this._container) } else this._tileContainer = this._container; t.appendChild(this._container), this.options.opacity < 1 && this._updateOpacity() } }, _reset: function (t) { for (var e in this._tiles) this.fire("tileunload", { tile: this._tiles[e] }); this._tiles = {}, this._tilesToLoad = 0, this.options.reuseTiles && (this._unusedTiles = []), this._tileContainer.innerHTML = "", this._animated && t && t.hard && this._clearBgBuffer(), this._initContainer() }, _getTileSize: function () { var t = this._map, e = t.getZoom() + this.options.zoomOffset, i = this.options.maxNativeZoom, n = this.options.tileSize; return i && e > i && (n = Math.round(t.getZoomScale(e) / t.getZoomScale(i) * n)), n }, _update: function () { if (this._map) { var t = this._map, e = t.getPixelBounds(), i = t.getZoom(), n = this._getTileSize(); if (!(i > this.options.maxZoom || i < this.options.minZoom)) { var s = o.bounds(e.min.divideBy(n)._floor(), e.max.divideBy(n)._floor()); this._addTilesFromCenterOut(s), (this.options.unloadInvisibleTiles || this.options.reuseTiles) && this._removeOtherTiles(s) } } }, _addTilesFromCenterOut: function (t) { var i, n, s, a = [], r = t.getCenter(); for (i = t.min.y; i <= t.max.y; i++) for (n = t.min.x; n <= t.max.x; n++) s = new o.Point(n, i), this._tileShouldBeLoaded(s) && a.push(s); var h = a.length; if (0 !== h) { a.sort(function (t, e) { return t.distanceTo(r) - e.distanceTo(r) }); var l = e.createDocumentFragment(); for (this._tilesToLoad || this.fire("loading"), this._tilesToLoad += h, n = 0; h > n; n++) this._addTile(a[n], l); this._tileContainer.appendChild(l) } }, _tileShouldBeLoaded: function (t) { if (t.x + ":" + t.y in this._tiles) return !1; var e = this.options; if (!e.continuousWorld) { var i = this._getWrapTileNum(); if (e.noWrap && (t.x < 0 || t.x >= i.x) || t.y < 0 || t.y >= i.y) return !1 } if (e.bounds) { var n = this._getTileSize(), o = t.multiplyBy(n), s = o.add([n, n]), a = this._map.unproject(o), r = this._map.unproject(s); if (e.continuousWorld || e.noWrap || (a = a.wrap(), r = r.wrap()), !e.bounds.intersects([a, r])) return !1 } return !0 }, _removeOtherTiles: function (t) { var e, i, n, o; for (o in this._tiles) e = o.split(":"), i = parseInt(e[0], 10), n = parseInt(e[1], 10), (i < t.min.x || i > t.max.x || n < t.min.y || n > t.max.y) && this._removeTile(o) }, _removeTile: function (t) { var e = this._tiles[t]; this.fire("tileunload", { tile: e, url: e.src }), this.options.reuseTiles ? (o.DomUtil.removeClass(e, "leaflet-tile-loaded"), this._unusedTiles.push(e)) : e.parentNode === this._tileContainer && this._tileContainer.removeChild(e), o.Browser.android || (e.onload = null, e.src = o.Util.emptyImageUrl), delete this._tiles[t] }, _addTile: function (t, e) { var i = this._getTilePos(t), n = this._getTile(); o.DomUtil.setPosition(n, i, o.Browser.chrome), this._tiles[t.x + ":" + t.y] = n, this._loadTile(n, t), n.parentNode !== this._tileContainer && e.appendChild(n) }, _getZoomForUrl: function () { var t = this.options, e = this._map.getZoom(); return t.zoomReverse && (e = t.maxZoom - e), e += t.zoomOffset, t.maxNativeZoom ? Math.min(e, t.maxNativeZoom) : e }, _getTilePos: function (t) { var e = this._map.getPixelOrigin(), i = this._getTileSize(); return t.multiplyBy(i).subtract(e) }, getTileUrl: function (t) { return o.Util.template(this._url, o.extend({ s: this._getSubdomain(t), z: t.z, x: t.x, y: t.y }, this.options)) }, _getWrapTileNum: function () { var t = this._map.options.crs, e = t.getSize(this._map.getZoom()); return e.divideBy(this._getTileSize())._floor() }, _adjustTilePoint: function (t) { var e = this._getWrapTileNum(); this.options.continuousWorld || this.options.noWrap || (t.x = (t.x % e.x + e.x) % e.x), this.options.tms && (t.y = e.y - t.y - 1), t.z = this._getZoomForUrl() }, _getSubdomain: function (t) { var e = Math.abs(t.x + t.y) % this.options.subdomains.length; return this.options.subdomains[e] }, _getTile: function () { if (this.options.reuseTiles && this._unusedTiles.length > 0) { var t = this._unusedTiles.pop(); return this._resetTile(t), t } return this._createTile() }, _resetTile: function () { }, _createTile: function () { var t = o.DomUtil.create("img", "leaflet-tile"); return t.style.width = t.style.height = this._getTileSize() + "px", t.galleryimg = "no", t.onselectstart = t.onmousemove = o.Util.falseFn, o.Browser.ielt9 && this.options.opacity !== i && o.DomUtil.setOpacity(t, this.options.opacity), o.Browser.mobileWebkit3d && (t.style.WebkitBackfaceVisibility = "hidden"), t }, _loadTile: function (t, e) { t._layer = this, t.onload = this._tileOnLoad, t.onerror = this._tileOnError, this._adjustTilePoint(e), t.src = this.getTileUrl(e), this.fire("tileloadstart", { tile: t, url: t.src }) }, _tileLoaded: function () { this._tilesToLoad--, this._animated && o.DomUtil.addClass(this._tileContainer, "leaflet-zoom-animated"), this._tilesToLoad || (this.fire("load"), this._animated && (clearTimeout(this._clearBgBufferTimer), this._clearBgBufferTimer = setTimeout(o.bind(this._clearBgBuffer, this), 500))) }, _tileOnLoad: function () { var t = this._layer; this.src !== o.Util.emptyImageUrl && (o.DomUtil.addClass(this, "leaflet-tile-loaded"), t.fire("tileload", { tile: this, url: this.src })), t._tileLoaded() }, _tileOnError: function () { var t = this._layer; t.fire("tileerror", { tile: this, url: this.src }); var e = t.options.errorTileUrl; e && (this.src = e), t._tileLoaded() } }), o.tileLayer = function (t, e) { return new o.TileLayer(t, e) }, o.TileLayer.WMS = o.TileLayer.extend({ defaultWmsParams: { service: "WMS", request: "GetMap", version: "1.1.1", layers: "", styles: "", format: "image/jpeg", transparent: !1 }, initialize: function (t, e) { this._url = t; var i = o.extend({}, this.defaultWmsParams), n = e.tileSize || this.options.tileSize; e.detectRetina && o.Browser.retina ? i.width = i.height = 2 * n : i.width = i.height = n; for (var s in e) this.options.hasOwnProperty(s) || "crs" === s || (i[s] = e[s]); this.wmsParams = i, o.setOptions(this, e) }, onAdd: function (t) { this._crs = this.options.crs || t.options.crs, this._wmsVersion = parseFloat(this.wmsParams.version); var e = this._wmsVersion >= 1.3 ? "crs" : "srs"; this.wmsParams[e] = this._crs.code, o.TileLayer.prototype.onAdd.call(this, t) }, getTileUrl: function (t) { var e = this._map, i = this.options.tileSize, n = t.multiplyBy(i), s = n.add([i, i]), a = this._crs.project(e.unproject(n, t.z)), r = this._crs.project(e.unproject(s, t.z)), h = this._wmsVersion >= 1.3 && this._crs === o.CRS.EPSG4326 ? [r.y, a.x, a.y, r.x].join(",") : [a.x, r.y, r.x, a.y].join(","), l = o.Util.template(this._url, { s: this._getSubdomain(t) }); return l + o.Util.getParamString(this.wmsParams, l, !0) + "&BBOX=" + h }, setParams: function (t, e) { return o.extend(this.wmsParams, t), e || this.redraw(), this } }), o.tileLayer.wms = function (t, e) { return new o.TileLayer.WMS(t, e) }, o.TileLayer.Canvas = o.TileLayer.extend({ options: { async: !1 }, initialize: function (t) { o.setOptions(this, t) }, redraw: function () { this._map && (this._reset({ hard: !0 }), this._update()); for (var t in this._tiles) this._redrawTile(this._tiles[t]); return this }, _redrawTile: function (t) { this.drawTile(t, t._tilePoint, this._map._zoom) }, _createTile: function () { var t = o.DomUtil.create("canvas", "leaflet-tile"); return t.width = t.height = this.options.tileSize, t.onselectstart = t.onmousemove = o.Util.falseFn, t }, _loadTile: function (t, e) { t._layer = this, t._tilePoint = e, this._redrawTile(t), this.options.async || this.tileDrawn(t) }, drawTile: function () { }, tileDrawn: function (t) { this._tileOnLoad.call(t) } }), o.tileLayer.canvas = function (t) { return new o.TileLayer.Canvas(t) }, o.ImageOverlay = o.Class.extend({ includes: o.Mixin.Events, options: { opacity: 1 }, initialize: function (t, e, i) { this._url = t, this._bounds = o.latLngBounds(e), o.setOptions(this, i) }, onAdd: function (t) { this._map = t, this._image || this._initImage(), t._panes.overlayPane.appendChild(this._image), t.on("viewreset", this._reset, this), t.options.zoomAnimation && o.Browser.any3d && t.on("zoomanim", this._animateZoom, this), this._reset() }, onRemove: function (t) { t.getPanes().overlayPane.removeChild(this._image), t.off("viewreset", this._reset, this), t.options.zoomAnimation && t.off("zoomanim", this._animateZoom, this) }, addTo: function (t) { return t.addLayer(this), this }, setOpacity: function (t) { return this.options.opacity = t, this._updateOpacity(), this }, bringToFront: function () { return this._image && this._map._panes.overlayPane.appendChild(this._image), this }, bringToBack: function () { var t = this._map._panes.overlayPane; return this._image && t.insertBefore(this._image, t.firstChild), this }, setUrl: function (t) { this._url = t, this._image.src = this._url }, getAttribution: function () { return this.options.attribution }, _initImage: function () { this._image = o.DomUtil.create("img", "leaflet-image-layer"), this._map.options.zoomAnimation && o.Browser.any3d ? o.DomUtil.addClass(this._image, "leaflet-zoom-animated") : o.DomUtil.addClass(this._image, "leaflet-zoom-hide"), this._updateOpacity(), o.extend(this._image, { galleryimg: "no", onselectstart: o.Util.falseFn, onmousemove: o.Util.falseFn, onload: o.bind(this._onImageLoad, this), src: this._url }) }, _animateZoom: function (t) { var e = this._map, i = this._image, n = e.getZoomScale(t.zoom), s = this._bounds.getNorthWest(), a = this._bounds.getSouthEast(), r = e._latLngToNewLayerPoint(s, t.zoom, t.center), h = e._latLngToNewLayerPoint(a, t.zoom, t.center)._subtract(r), l = r._add(h._multiplyBy(.5 * (1 - 1 / n))); i.style[o.DomUtil.TRANSFORM] = o.DomUtil.getTranslateString(l) + " scale(" + n + ") " }, _reset: function () { var t = this._image, e = this._map.latLngToLayerPoint(this._bounds.getNorthWest()), i = this._map.latLngToLayerPoint(this._bounds.getSouthEast())._subtract(e); o.DomUtil.setPosition(t, e), t.style.width = i.x + "px", t.style.height = i.y + "px" }, _onImageLoad: function () { this.fire("load") }, _updateOpacity: function () { o.DomUtil.setOpacity(this._image, this.options.opacity) } }), o.imageOverlay = function (t, e, i) { return new o.ImageOverlay(t, e, i) }, o.Icon = o.Class.extend({ options: { className: "" }, initialize: function (t) { o.setOptions(this, t) }, createIcon: function (t) { return this._createIcon("icon", t) }, createShadow: function (t) { return this._createIcon("shadow", t) }, _createIcon: function (t, e) { var i = this._getIconUrl(t); if (!i) { if ("icon" === t) throw new Error("iconUrl not set in Icon options (see the docs)."); return null } var n; return n = e && "IMG" === e.tagName ? this._createImg(i, e) : this._createImg(i), this._setIconStyles(n, t), n }, _setIconStyles: function (t, e) { var i, n = this.options, s = o.point(n[e + "Size"]); i = "shadow" === e ? o.point(n.shadowAnchor || n.iconAnchor) : o.point(n.iconAnchor), !i && s && (i = s.divideBy(2, !0)), t.className = "leaflet-marker-" + e + " " + n.className, i && (t.style.marginLeft = -i.x + "px", t.style.marginTop = -i.y + "px"), s && (t.style.width = s.x + "px", t.style.height = s.y + "px") }, _createImg: function (t, i) { return i = i || e.createElement("img"), i.src = t, i }, _getIconUrl: function (t) { return o.Browser.retina && this.options[t + "RetinaUrl"] ? this.options[t + "RetinaUrl"] : this.options[t + "Url"] } }), o.icon = function (t) { return new o.Icon(t) }, o.Icon.Default = o.Icon.extend({ options: { iconSize: [25, 41], iconAnchor: [12, 41], popupAnchor: [1, -34], shadowSize: [41, 41] }, _getIconUrl: function (t) { var e = t + "Url"; if (this.options[e]) return this.options[e]; o.Browser.retina && "icon" === t && (t += "-2x"); var i = o.Icon.Default.imagePath; if (!i) throw new Error("Couldn't autodetect L.Icon.Default.imagePath, set it manually."); return i + "/marker-" + t + ".png" } }), o.Icon.Default.imagePath = function () { var t, i, n, o, s, a = e.getElementsByTagName("script"), r = /[\/^]leaflet[\-\._]?([\w\-\._]*)\.js\??/; for (t = 0, i = a.length; i > t; t++) if (n = a[t].src, o = n.match(r)) return s = n.split(r)[0], (s ? s + "/" : "") + "images" }(), o.Marker = o.Class.extend({ includes: o.Mixin.Events, options: { icon: new o.Icon.Default, title: "", alt: "", clickable: !0, draggable: !1, keyboard: !0, zIndexOffset: 0, opacity: 1, riseOnHover: !1, riseOffset: 250 }, initialize: function (t, e) { o.setOptions(this, e), this._latlng = o.latLng(t) }, onAdd: function (t) { this._map = t, t.on("viewreset", this.update, this), this._initIcon(), this.update(), this.fire("add"), t.options.zoomAnimation && t.options.markerZoomAnimation && t.on("zoomanim", this._animateZoom, this) }, addTo: function (t) { return t.addLayer(this), this }, onRemove: function (t) { this.dragging && this.dragging.disable(), this._removeIcon(), this._removeShadow(), this.fire("remove"), t.off({ viewreset: this.update, zoomanim: this._animateZoom }, this), this._map = null }, getLatLng: function () { return this._latlng }, setLatLng: function (t) { return this._latlng = o.latLng(t), this.update(), this.fire("move", { latlng: this._latlng }) }, setZIndexOffset: function (t) { return this.options.zIndexOffset = t, this.update(), this }, setIcon: function (t) { return this.options.icon = t, this._map && (this._initIcon(), this.update()), this._popup && this.bindPopup(this._popup), this }, update: function () { return this._icon && this._setPos(this._map.latLngToLayerPoint(this._latlng).round()), this }, _initIcon: function () { var t = this.options, e = this._map, i = e.options.zoomAnimation && e.options.markerZoomAnimation, n = i ? "leaflet-zoom-animated" : "leaflet-zoom-hide", s = t.icon.createIcon(this._icon), a = !1; s !== this._icon && (this._icon && this._removeIcon(), a = !0, t.title && (s.title = t.title), t.alt && (s.alt = t.alt)), o.DomUtil.addClass(s, n), t.keyboard && (s.tabIndex = "0"), this._icon = s, this._initInteraction(), t.riseOnHover && o.DomEvent.on(s, "mouseover", this._bringToFront, this).on(s, "mouseout", this._resetZIndex, this); var r = t.icon.createShadow(this._shadow), h = !1; r !== this._shadow && (this._removeShadow(), h = !0), r && o.DomUtil.addClass(r, n), this._shadow = r, t.opacity < 1 && this._updateOpacity(); var l = this._map._panes; a && l.markerPane.appendChild(this._icon), r && h && l.shadowPane.appendChild(this._shadow) }, _removeIcon: function () { this.options.riseOnHover && o.DomEvent.off(this._icon, "mouseover", this._bringToFront).off(this._icon, "mouseout", this._resetZIndex), this._map._panes.markerPane.removeChild(this._icon), this._icon = null }, _removeShadow: function () { this._shadow && this._map._panes.shadowPane.removeChild(this._shadow), this._shadow = null }, _setPos: function (t) { o.DomUtil.setPosition(this._icon, t), this._shadow && o.DomUtil.setPosition(this._shadow, t), this._zIndex = t.y + this.options.zIndexOffset, this._resetZIndex() }, _updateZIndex: function (t) { this._icon.style.zIndex = this._zIndex + t }, _animateZoom: function (t) { var e = this._map._latLngToNewLayerPoint(this._latlng, t.zoom, t.center).round(); this._setPos(e) }, _initInteraction: function () { if (this.options.clickable) { var t = this._icon, e = ["dblclick", "mousedown", "mouseover", "mouseout", "contextmenu"]; o.DomUtil.addClass(t, "leaflet-clickable"), o.DomEvent.on(t, "click", this._onMouseClick, this), o.DomEvent.on(t, "keypress", this._onKeyPress, this); for (var i = 0; i < e.length; i++) o.DomEvent.on(t, e[i], this._fireMouseEvent, this); o.Handler.MarkerDrag && (this.dragging = new o.Handler.MarkerDrag(this), this.options.draggable && this.dragging.enable()) } }, _onMouseClick: function (t) { var e = this.dragging && this.dragging.moved(); (this.hasEventListeners(t.type) || e) && o.DomEvent.stopPropagation(t), e || (this.dragging && this.dragging._enabled || !this._map.dragging || !this._map.dragging.moved()) && this.fire(t.type, { originalEvent: t, latlng: this._latlng }) }, _onKeyPress: function (t) { 13 === t.keyCode && this.fire("click", { originalEvent: t, latlng: this._latlng }) }, _fireMouseEvent: function (t) { this.fire(t.type, { originalEvent: t, latlng: this._latlng }), "contextmenu" === t.type && this.hasEventListeners(t.type) && o.DomEvent.preventDefault(t), "mousedown" !== t.type ? o.DomEvent.stopPropagation(t) : o.DomEvent.preventDefault(t) }, setOpacity: function (t) { return this.options.opacity = t, this._map && this._updateOpacity(), this }, _updateOpacity: function () { o.DomUtil.setOpacity(this._icon, this.options.opacity), this._shadow && o.DomUtil.setOpacity(this._shadow, this.options.opacity) }, _bringToFront: function () { this._updateZIndex(this.options.riseOffset) }, _resetZIndex: function () { this._updateZIndex(0) } }), o.marker = function (t, e) { return new o.Marker(t, e) }, o.DivIcon = o.Icon.extend({ options: { iconSize: [12, 12], className: "leaflet-div-icon", html: !1 }, createIcon: function (t) { var i = t && "DIV" === t.tagName ? t : e.createElement("div"), n = this.options; return n.html !== !1 ? i.innerHTML = n.html : i.innerHTML = "", n.bgPos && (i.style.backgroundPosition = -n.bgPos.x + "px " + -n.bgPos.y + "px"), this._setIconStyles(i, "icon"), i }, createShadow: function () { return null } }), o.divIcon = function (t) { return new o.DivIcon(t) }, o.Map.mergeOptions({ closePopupOnClick: !0 }), o.Popup = o.Class.extend({ includes: o.Mixin.Events, options: { minWidth: 50, maxWidth: 300, autoPan: !0, closeButton: !0, offset: [0, 7], autoPanPadding: [5, 5], keepInView: !1, className: "", zoomAnimation: !0 }, initialize: function (t, e) { o.setOptions(this, t), this._source = e, this._animated = o.Browser.any3d && this.options.zoomAnimation, this._isOpen = !1 }, onAdd: function (t) { this._map = t, this._container || this._initLayout(); var e = t.options.fadeAnimation; e && o.DomUtil.setOpacity(this._container, 0), t._panes.popupPane.appendChild(this._container), t.on(this._getEvents(), this), this.update(), e && o.DomUtil.setOpacity(this._container, 1), this.fire("open"), t.fire("popupopen", { popup: this }), this._source && this._source.fire("popupopen", { popup: this }) }, addTo: function (t) { return t.addLayer(this), this }, openOn: function (t) { return t.openPopup(this), this }, onRemove: function (t) { t._panes.popupPane.removeChild(this._container), o.Util.falseFn(this._container.offsetWidth), t.off(this._getEvents(), this), t.options.fadeAnimation && o.DomUtil.setOpacity(this._container, 0), this._map = null, this.fire("close"), t.fire("popupclose", { popup: this }), this._source && this._source.fire("popupclose", { popup: this }) }, getLatLng: function () { return this._latlng }, setLatLng: function (t) { return this._latlng = o.latLng(t), this._map && (this._updatePosition(), this._adjustPan()), this }, getContent: function () { return this._content }, setContent: function (t) { return this._content = t, this.update(), this }, 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 = { viewreset: this._updatePosition }; return this._animated && (t.zoomanim = this._zoomAnimation), ("closeOnClick" in this.options ? 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, e = "leaflet-popup", i = e + " " + this.options.className + " leaflet-zoom-" + (this._animated ? "animated" : "hide"), n = this._container = o.DomUtil.create("div", i); this.options.closeButton && (t = this._closeButton = o.DomUtil.create("a", e + "-close-button", n), t.href = "#close", t.innerHTML = "&#215;", o.DomEvent.disableClickPropagation(t), o.DomEvent.on(t, "click", this._onCloseButtonClick, this)); var s = this._wrapper = o.DomUtil.create("div", e + "-content-wrapper", n); o.DomEvent.disableClickPropagation(s), this._contentNode = o.DomUtil.create("div", e + "-content", s), o.DomEvent.disableScrollPropagation(this._contentNode), o.DomEvent.on(s, "contextmenu", o.DomEvent.stopPropagation), this._tipContainer = o.DomUtil.create("div", e + "-tip-container", n), this._tip = o.DomUtil.create("div", e + "-tip", this._tipContainer) }, _updateContent: function () { if (this._content) { if ("string" == typeof this._content) this._contentNode.innerHTML = this._content; else { for (; this._contentNode.hasChildNodes() ;) this._contentNode.removeChild(this._contentNode.firstChild); this._contentNode.appendChild(this._content) } this.fire("contentupdate") } }, _updateLayout: function () { var t = this._contentNode, e = t.style; e.width = "", e.whiteSpace = "nowrap"; var i = t.offsetWidth; i = Math.min(i, this.options.maxWidth), i = Math.max(i, this.options.minWidth), e.width = i + 1 + "px", e.whiteSpace = "", e.height = ""; var n = t.offsetHeight, s = this.options.maxHeight, a = "leaflet-popup-scrolled"; s && n > s ? (e.height = s + "px", o.DomUtil.addClass(t, a)) : o.DomUtil.removeClass(t, a), this._containerWidth = this._container.offsetWidth }, _updatePosition: function () { if (this._map) { var t = this._map.latLngToLayerPoint(this._latlng), e = this._animated, i = o.point(this.options.offset); e && o.DomUtil.setPosition(this._container, t), this._containerBottom = -i.y - (e ? 0 : t.y), this._containerLeft = -Math.round(this._containerWidth / 2) + i.x + (e ? 0 : t.x), this._container.style.bottom = this._containerBottom + "px", this._container.style.left = this._containerLeft + "px" } }, _zoomAnimation: function (t) { var e = this._map._latLngToNewLayerPoint(this._latlng, t.zoom, t.center); o.DomUtil.setPosition(this._container, e) }, _adjustPan: function () { if (this.options.autoPan) { var t = this._map, e = this._container.offsetHeight, i = this._containerWidth, n = new o.Point(this._containerLeft, -e - this._containerBottom); this._animated && n._add(o.DomUtil.getPosition(this._container)); var s = t.layerPointToContainerPoint(n), a = o.point(this.options.autoPanPadding), r = o.point(this.options.autoPanPaddingTopLeft || a), h = o.point(this.options.autoPanPaddingBottomRight || a), l = t.getSize(), u = 0, c = 0; s.x + i + h.x > l.x && (u = s.x + i - l.x + h.x), s.x - u - r.x < 0 && (u = s.x - r.x), s.y + e + h.y > l.y && (c = s.y + e - l.y + h.y), s.y - c - r.y < 0 && (c = s.y - r.y), (u || c) && t.fire("autopanstart").panBy([u, c]) } }, _onCloseButtonClick: function (t) { this._close(), o.DomEvent.stop(t) } }), o.popup = function (t, e) { return new o.Popup(t, e) }, o.Map.include({ openPopup: function (t, e, i) { if (this.closePopup(), !(t instanceof o.Popup)) { var n = t; t = new o.Popup(i).setLatLng(e).setContent(n) } return t._isOpen = !0, this._popup = t, this.addLayer(t) }, closePopup: function (t) { return t && t !== this._popup || (t = this._popup, this._popup = null), t && (this.removeLayer(t), t._isOpen = !1), this } }), o.Marker.include({ openPopup: function () { return this._popup && this._map && !this._map.hasLayer(this._popup) && (this._popup.setLatLng(this._latlng), this._map.openPopup(this._popup)), this }, closePopup: function () { return this._popup && this._popup._close(), this }, togglePopup: function () { return this._popup && (this._popup._isOpen ? this.closePopup() : this.openPopup()), this }, bindPopup: function (t, e) { var i = o.point(this.options.icon.options.popupAnchor || [0, 0]); return i = i.add(o.Popup.prototype.options.offset), e && e.offset && (i = i.add(e.offset)), e = o.extend({ offset: i }, e), this._popupHandlersAdded || (this.on("click", this.togglePopup, this).on("remove", this.closePopup, this).on("move", this._movePopup, this), this._popupHandlersAdded = !0), t instanceof o.Popup ? (o.setOptions(t, e), this._popup = t, t._source = this) : this._popup = new o.Popup(e, this).setContent(t), this }, setPopupContent: function (t) { return this._popup && this._popup.setContent(t), this }, unbindPopup: function () { return this._popup && (this._popup = null, this.off("click", this.togglePopup, this).off("remove", this.closePopup, this).off("move", this._movePopup, this), this._popupHandlersAdded = !1), this }, getPopup: function () { return this._popup }, _movePopup: function (t) { this._popup.setLatLng(t.latlng) } }), o.LayerGroup = o.Class.extend({ initialize: function (t) { this._layers = {}; var e, i; if (t) for (e = 0, i = t.length; i > e; e++) this.addLayer(t[e]) }, addLayer: function (t) { var e = this.getLayerId(t); return this._layers[e] = t, this._map && this._map.addLayer(t), this }, removeLayer: function (t) { var e = t in this._layers ? t : this.getLayerId(t); return this._map && this._layers[e] && this._map.removeLayer(this._layers[e]), delete this._layers[e], this }, hasLayer: function (t) { return t ? t in this._layers || this.getLayerId(t) in this._layers : !1 }, clearLayers: function () { return this.eachLayer(this.removeLayer, this), this }, invoke: function (t) { var e, i, n = Array.prototype.slice.call(arguments, 1); for (e in this._layers) i = this._layers[e], i[t] && i[t].apply(i, n); return this }, onAdd: function (t) { this._map = t, this.eachLayer(t.addLayer, t) }, onRemove: function (t) { this.eachLayer(t.removeLayer, t), this._map = null }, addTo: function (t) { return t.addLayer(this), this }, eachLayer: function (t, e) { for (var i in this._layers) t.call(e, this._layers[i]); return this }, getLayer: function (t) { return this._layers[t] }, getLayers: function () { var t = []; for (var e in this._layers) t.push(this._layers[e]); return t }, setZIndex: function (t) { return this.invoke("setZIndex", t) }, getLayerId: function (t) { return o.stamp(t) } }), o.layerGroup = function (t) { return new o.LayerGroup(t) }, o.FeatureGroup = o.LayerGroup.extend({ includes: o.Mixin.Events, statics: { EVENTS: "click dblclick mouseover mouseout mousemove contextmenu popupopen popupclose" }, addLayer: function (t) { return this.hasLayer(t) ? this : ("on" in t && t.on(o.FeatureGroup.EVENTS, this._propagateEvent, this), o.LayerGroup.prototype.addLayer.call(this, t), this._popupContent && t.bindPopup && t.bindPopup(this._popupContent, this._popupOptions), this.fire("layeradd", { layer: t })) }, removeLayer: function (t) { return this.hasLayer(t) ? (t in this._layers && (t = this._layers[t]), t.off(o.FeatureGroup.EVENTS, this._propagateEvent, this), o.LayerGroup.prototype.removeLayer.call(this, t), this._popupContent && this.invoke("unbindPopup"), this.fire("layerremove", { layer: t })) : this }, bindPopup: function (t, e) { return this._popupContent = t, this._popupOptions = e, this.invoke("bindPopup", t, e) }, openPopup: function (t) { for (var e in this._layers) { this._layers[e].openPopup(t); break } return 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 o.LatLngBounds; return this.eachLayer(function (e) { t.extend(e instanceof o.Marker ? e.getLatLng() : e.getBounds()) }), t }, _propagateEvent: function (t) { t = o.extend({ layer: t.target, target: this }, t), this.fire(t.type, t) } }), o.featureGroup = function (t) { return new o.FeatureGroup(t) }, o.Path = o.Class.extend({ includes: [o.Mixin.Events], statics: { CLIP_PADDING: function () { var e = o.Browser.mobile ? 1280 : 2e3, i = (e / Math.max(t.outerWidth, t.outerHeight) - 1) / 2; return Math.max(0, Math.min(.5, i)) }() }, options: { stroke: !0, color: "#0033ff", dashArray: null, lineCap: null, lineJoin: null, weight: 5, opacity: .5, fill: !1, fillColor: null, fillOpacity: .2, clickable: !0 }, initialize: function (t) { o.setOptions(this, t) }, onAdd: function (t) { this._map = t, this._container || (this._initElements(), this._initEvents()), this.projectLatlngs(), this._updatePath(), this._container && this._map._pathRoot.appendChild(this._container), this.fire("add"), t.on({ viewreset: this.projectLatlngs, moveend: this._updatePath }, this) }, addTo: function (t) { return t.addLayer(this), this }, onRemove: function (t) { t._pathRoot.removeChild(this._container), this.fire("remove"), this._map = null, o.Browser.vml && (this._container = null, this._stroke = null, this._fill = null), t.off({ viewreset: this.projectLatlngs, moveend: this._updatePath }, this) }, projectLatlngs: function () { }, setStyle: function (t) { return o.setOptions(this, t), this._container && this._updateStyle(), this }, redraw: function () { return this._map && (this.projectLatlngs(), this._updatePath()), this } }), o.Map.include({ _updatePathViewport: function () { var t = o.Path.CLIP_PADDING, e = this.getSize(), i = o.DomUtil.getPosition(this._mapPane), n = i.multiplyBy(-1)._subtract(e.multiplyBy(t)._round()), s = n.add(e.multiplyBy(1 + 2 * t)._round()); this._pathViewport = new o.Bounds(n, s) } }), o.Path.SVG_NS = "http://www.w3.org/2000/svg", o.Browser.svg = !(!e.createElementNS || !e.createElementNS(o.Path.SVG_NS, "svg").createSVGRect), o.Path = o.Path.extend({ statics: { SVG: o.Browser.svg }, bringToFront: function () { var t = this._map._pathRoot, e = this._container; return e && t.lastChild !== e && t.appendChild(e), this }, bringToBack: function () { var t = this._map._pathRoot, e = this._container, i = t.firstChild; return e && i !== e && t.insertBefore(e, i), this }, getPathString: function () { }, _createElement: function (t) { return e.createElementNS(o.Path.SVG_NS, t) }, _initElements: function () { this._map._initPathRoot(), this._initPath(), this._initStyle() }, _initPath: function () { this._container = this._createElement("g"), this._path = this._createElement("path"), this.options.className && o.DomUtil.addClass(this._path, this.options.className), this._container.appendChild(this._path) }, _initStyle: function () { this.options.stroke && (this._path.setAttribute("stroke-linejoin", "round"), this._path.setAttribute("stroke-linecap", "round")), this.options.fill && this._path.setAttribute("fill-rule", "evenodd"), this.options.pointerEvents && this._path.setAttribute("pointer-events", this.options.pointerEvents), this.options.clickable || this.options.pointerEvents || this._path.setAttribute("pointer-events", "none"), this._updateStyle() }, _updateStyle: function () { this.options.stroke ? (this._path.setAttribute("stroke", this.options.color), this._path.setAttribute("stroke-opacity", this.options.opacity), this._path.setAttribute("stroke-width", this.options.weight), this.options.dashArray ? this._path.setAttribute("stroke-dasharray", this.options.dashArray) : this._path.removeAttribute("stroke-dasharray"), this.options.lineCap && this._path.setAttribute("stroke-linecap", this.options.lineCap), this.options.lineJoin && this._path.setAttribute("stroke-linejoin", this.options.lineJoin)) : this._path.setAttribute("stroke", "none"), this.options.fill ? (this._path.setAttribute("fill", this.options.fillColor || this.options.color), this._path.setAttribute("fill-opacity", this.options.fillOpacity)) : this._path.setAttribute("fill", "none") }, _updatePath: function () { var t = this.getPathString(); t || (t = "M0 0"), this._path.setAttribute("d", t) }, _initEvents: function () { if (this.options.clickable) { (o.Browser.svg || !o.Browser.vml) && o.DomUtil.addClass(this._path, "leaflet-clickable"), o.DomEvent.on(this._container, "click", this._onMouseClick, this); for (var t = ["dblclick", "mousedown", "mouseover", "mouseout", "mousemove", "contextmenu"], e = 0; e < t.length; e++) o.DomEvent.on(this._container, t[e], this._fireMouseEvent, this) } }, _onMouseClick: function (t) { this._map.dragging && this._map.dragging.moved() || this._fireMouseEvent(t) }, _fireMouseEvent: function (t) { if (this.hasEventListeners(t.type)) { var e = this._map, i = e.mouseEventToContainerPoint(t), n = e.containerPointToLayerPoint(i), s = e.layerPointToLatLng(n); this.fire(t.type, { latlng: s, layerPoint: n, containerPoint: i, originalEvent: t }), "contextmenu" === t.type && o.DomEvent.preventDefault(t), "mousemove" !== t.type && o.DomEvent.stopPropagation(t) } } }), o.Map.include({
_initPathRoot: function () {
this._pathRoot || (this._pathRoot = o.Path.prototype._createElement("svg"), this._panes.overlayPane.appendChild(this._pathRoot), this.options.zoomAnimation && o.Browser.any3d ? (o.DomUtil.addClass(this._pathRoot, "leaflet-zoom-animated"),
this.on({ zoomanim: this._animatePathZoom, zoomend: this._endPathZoom })) : o.DomUtil.addClass(this._pathRoot, "leaflet-zoom-hide"), this.on("moveend", this._updateSvgViewport), this._updateSvgViewport())
}, _animatePathZoom: function (t) { var e = this.getZoomScale(t.zoom), i = this._getCenterOffset(t.center)._multiplyBy(-e)._add(this._pathViewport.min); this._pathRoot.style[o.DomUtil.TRANSFORM] = o.DomUtil.getTranslateString(i) + " scale(" + e + ") ", this._pathZooming = !0 }, _endPathZoom: function () { this._pathZooming = !1 }, _updateSvgViewport: function () { if (!this._pathZooming) { this._updatePathViewport(); var t = this._pathViewport, e = t.min, i = t.max, n = i.x - e.x, s = i.y - e.y, a = this._pathRoot, r = this._panes.overlayPane; o.Browser.mobileWebkit && r.removeChild(a), o.DomUtil.setPosition(a, e), a.setAttribute("width", n), a.setAttribute("height", s), a.setAttribute("viewBox", [e.x, e.y, n, s].join(" ")), o.Browser.mobileWebkit && r.appendChild(a) } }
}), o.Path.include({ bindPopup: function (t, e) { return t instanceof o.Popup ? this._popup = t : ((!this._popup || e) && (this._popup = new o.Popup(e, this)), this._popup.setContent(t)), this._popupHandlersAdded || (this.on("click", this._openPopup, this).on("remove", this.closePopup, this), this._popupHandlersAdded = !0), this }, unbindPopup: function () { return this._popup && (this._popup = null, this.off("click", this._openPopup).off("remove", this.closePopup), this._popupHandlersAdded = !1), this }, openPopup: function (t) { return this._popup && (t = t || this._latlng || this._latlngs[Math.floor(this._latlngs.length / 2)], this._openPopup({ latlng: t })), this }, closePopup: function () { return this._popup && this._popup._close(), this }, _openPopup: function (t) { this._popup.setLatLng(t.latlng), this._map.openPopup(this._popup) } }), o.Browser.vml = !o.Browser.svg && function () { try { var t = e.createElement("div"); t.innerHTML = '<v:shape adj="1"/>'; var i = t.firstChild; return i.style.behavior = "url(#default#VML)", i && "object" == typeof i.adj } catch (n) { return !1 } }(), o.Path = o.Browser.svg || !o.Browser.vml ? o.Path : o.Path.extend({ statics: { VML: !0, CLIP_PADDING: .02 }, _createElement: function () { try { return e.namespaces.add("lvml", "urn:schemas-microsoft-com:vml"), function (t) { return e.createElement("<lvml:" + t + ' class="lvml">') } } catch (t) { return function (t) { return e.createElement("<" + t + ' xmlns="urn:schemas-microsoft.com:vml" class="lvml">') } } }(), _initPath: function () { var t = this._container = this._createElement("shape"); o.DomUtil.addClass(t, "leaflet-vml-shape" + (this.options.className ? " " + this.options.className : "")), this.options.clickable && o.DomUtil.addClass(t, "leaflet-clickable"), t.coordsize = "1 1", this._path = this._createElement("path"), t.appendChild(this._path), this._map._pathRoot.appendChild(t) }, _initStyle: function () { this._updateStyle() }, _updateStyle: function () { var t = this._stroke, e = this._fill, i = this.options, n = this._container; n.stroked = i.stroke, n.filled = i.fill, i.stroke ? (t || (t = this._stroke = this._createElement("stroke"), t.endcap = "round", n.appendChild(t)), t.weight = i.weight + "px", t.color = i.color, t.opacity = i.opacity, i.dashArray ? t.dashStyle = o.Util.isArray(i.dashArray) ? i.dashArray.join(" ") : i.dashArray.replace(/( *, *)/g, " ") : t.dashStyle = "", i.lineCap && (t.endcap = i.lineCap.replace("butt", "flat")), i.lineJoin && (t.joinstyle = i.lineJoin)) : t && (n.removeChild(t), this._stroke = null), i.fill ? (e || (e = this._fill = this._createElement("fill"), n.appendChild(e)), e.color = i.fillColor || i.color, e.opacity = i.fillOpacity) : e && (n.removeChild(e), this._fill = null) }, _updatePath: function () { var t = this._container.style; t.display = "none", this._path.v = this.getPathString() + " ", t.display = "" } }), o.Map.include(o.Browser.svg || !o.Browser.vml ? {} : { _initPathRoot: function () { if (!this._pathRoot) { var t = this._pathRoot = e.createElement("div"); t.className = "leaflet-vml-container", this._panes.overlayPane.appendChild(t), this.on("moveend", this._updatePathViewport), this._updatePathViewport() } } }), o.Browser.canvas = function () { return !!e.createElement("canvas").getContext }(), o.Path = o.Path.SVG && !t.L_PREFER_CANVAS || !o.Browser.canvas ? o.Path : o.Path.extend({ statics: { CANVAS: !0, SVG: !1 }, redraw: function () { return this._map && (this.projectLatlngs(), this._requestUpdate()), this }, setStyle: function (t) { return o.setOptions(this, t), this._map && (this._updateStyle(), this._requestUpdate()), this }, onRemove: function (t) { t.off("viewreset", this.projectLatlngs, this).off("moveend", this._updatePath, this), this.options.clickable && (this._map.off("click", this._onClick, this), this._map.off("mousemove", this._onMouseMove, this)), this._requestUpdate(), this.fire("remove"), this._map = null }, _requestUpdate: function () { this._map && !o.Path._updateRequest && (o.Path._updateRequest = o.Util.requestAnimFrame(this._fireMapMoveEnd, this._map)) }, _fireMapMoveEnd: function () { o.Path._updateRequest = null, this.fire("moveend") }, _initElements: function () { this._map._initPathRoot(), this._ctx = this._map._canvasCtx }, _updateStyle: function () { var t = this.options; t.stroke && (this._ctx.lineWidth = t.weight, this._ctx.strokeStyle = t.color), t.fill && (this._ctx.fillStyle = t.fillColor || t.color), t.lineCap && (this._ctx.lineCap = t.lineCap), t.lineJoin && (this._ctx.lineJoin = t.lineJoin) }, _drawPath: function () { var t, e, i, n, s, a; for (this._ctx.beginPath(), t = 0, i = this._parts.length; i > t; t++) { for (e = 0, n = this._parts[t].length; n > e; e++) s = this._parts[t][e], a = (0 === e ? "move" : "line") + "To", this._ctx[a](s.x, s.y); this instanceof o.Polygon && this._ctx.closePath() } }, _checkIfEmpty: function () { return !this._parts.length }, _updatePath: function () { if (!this._checkIfEmpty()) { var t = this._ctx, e = this.options; this._drawPath(), t.save(), this._updateStyle(), e.fill && (t.globalAlpha = e.fillOpacity, t.fill(e.fillRule || "evenodd")), e.stroke && (t.globalAlpha = e.opacity, t.stroke()), t.restore() } }, _initEvents: function () { this.options.clickable && (this._map.on("mousemove", this._onMouseMove, this), this._map.on("click dblclick contextmenu", this._fireMouseEvent, this)) }, _fireMouseEvent: function (t) { this._containsPoint(t.layerPoint) && this.fire(t.type, t) }, _onMouseMove: function (t) { this._map && !this._map._animatingZoom && (this._containsPoint(t.layerPoint) ? (this._ctx.canvas.style.cursor = "pointer", this._mouseInside = !0, this.fire("mouseover", t)) : this._mouseInside && (this._ctx.canvas.style.cursor = "", this._mouseInside = !1, this.fire("mouseout", t))) } }), o.Map.include(o.Path.SVG && !t.L_PREFER_CANVAS || !o.Browser.canvas ? {} : { _initPathRoot: function () { var t, i = this._pathRoot; i || (i = this._pathRoot = e.createElement("canvas"), i.style.position = "absolute", t = this._canvasCtx = i.getContext("2d"), t.lineCap = "round", t.lineJoin = "round", this._panes.overlayPane.appendChild(i), this.options.zoomAnimation && (this._pathRoot.className = "leaflet-zoom-animated", this.on("zoomanim", this._animatePathZoom), this.on("zoomend", this._endPathZoom)), this.on("moveend", this._updateCanvasViewport), this._updateCanvasViewport()) }, _updateCanvasViewport: function () { if (!this._pathZooming) { this._updatePathViewport(); var t = this._pathViewport, e = t.min, i = t.max.subtract(e), n = this._pathRoot; o.DomUtil.setPosition(n, e), n.width = i.x, n.height = i.y, n.getContext("2d").translate(-e.x, -e.y) } } }), o.LineUtil = { simplify: function (t, e) { if (!e || !t.length) return t.slice(); var i = e * e; return t = this._reducePoints(t, i), t = this._simplifyDP(t, i) }, pointToSegmentDistance: function (t, e, i) { return Math.sqrt(this._sqClosestPointOnSegment(t, e, i, !0)) }, closestPointOnSegment: function (t, e, i) { return this._sqClosestPointOnSegment(t, e, i) }, _simplifyDP: function (t, e) { var n = t.length, o = typeof Uint8Array != i + "" ? Uint8Array : Array, s = new o(n); s[0] = s[n - 1] = 1, this._simplifyDPStep(t, s, e, 0, n - 1); var a, r = []; for (a = 0; n > a; a++) s[a] && r.push(t[a]); return r }, _simplifyDPStep: function (t, e, i, n, o) { var s, a, r, h = 0; for (a = n + 1; o - 1 >= a; a++) r = this._sqClosestPointOnSegment(t[a], t[n], t[o], !0), r > h && (s = a, h = r); h > i && (e[s] = 1, this._simplifyDPStep(t, e, i, n, s), this._simplifyDPStep(t, e, i, s, o)) }, _reducePoints: function (t, e) { for (var i = [t[0]], n = 1, o = 0, s = t.length; s > n; n++) this._sqDist(t[n], t[o]) > e && (i.push(t[n]), o = n); return s - 1 > o && i.push(t[s - 1]), i }, clipSegment: function (t, e, i, n) { var o, s, a, r = n ? this._lastCode : this._getBitCode(t, i), h = this._getBitCode(e, i); for (this._lastCode = h; ;) { if (!(r | h)) return [t, e]; if (r & h) return !1; o = r || h, s = this._getEdgeIntersection(t, e, o, i), a = this._getBitCode(s, i), o === r ? (t = s, r = a) : (e = s, h = a) } }, _getEdgeIntersection: function (t, e, i, n) { var s = e.x - t.x, a = e.y - t.y, r = n.min, h = n.max; return 8 & i ? new o.Point(t.x + s * (h.y - t.y) / a, h.y) : 4 & i ? new o.Point(t.x + s * (r.y - t.y) / a, r.y) : 2 & i ? new o.Point(h.x, t.y + a * (h.x - t.x) / s) : 1 & i ? new o.Point(r.x, t.y + a * (r.x - t.x) / s) : void 0 }, _getBitCode: function (t, e) { var i = 0; return t.x < e.min.x ? i |= 1 : t.x > e.max.x && (i |= 2), t.y < e.min.y ? i |= 4 : t.y > e.max.y && (i |= 8), i }, _sqDist: function (t, e) { var i = e.x - t.x, n = e.y - t.y; return i * i + n * n }, _sqClosestPointOnSegment: function (t, e, i, n) { var s, a = e.x, r = e.y, h = i.x - a, l = i.y - r, u = h * h + l * l; return u > 0 && (s = ((t.x - a) * h + (t.y - r) * l) / u, s > 1 ? (a = i.x, r = i.y) : s > 0 && (a += h * s, r += l * s)), h = t.x - a, l = t.y - r, n ? h * h + l * l : new o.Point(a, r) } }, o.Polyline = o.Path.extend({ initialize: function (t, e) { o.Path.prototype.initialize.call(this, e), this._latlngs = this._convertLatLngs(t) }, options: { smoothFactor: 1, noClip: !1 }, projectLatlngs: function () { this._originalPoints = []; for (var t = 0, e = this._latlngs.length; e > t; t++) this._originalPoints[t] = this._map.latLngToLayerPoint(this._latlngs[t]) }, getPathString: function () { for (var t = 0, e = this._parts.length, i = ""; e > t; t++) i += this._getPathPartStr(this._parts[t]); return i }, getLatLngs: function () { return this._latlngs }, setLatLngs: function (t) { return this._latlngs = this._convertLatLngs(t), this.redraw() }, addLatLng: function (t) { return this._latlngs.push(o.latLng(t)), this.redraw() }, spliceLatLngs: function () { var t = [].splice.apply(this._latlngs, arguments); return this._convertLatLngs(this._latlngs, !0), this.redraw(), t }, closestLayerPoint: function (t) { for (var e, i, n = 1 / 0, s = this._parts, a = null, r = 0, h = s.length; h > r; r++) for (var l = s[r], u = 1, c = l.length; c > u; u++) { e = l[u - 1], i = l[u]; var d = o.LineUtil._sqClosestPointOnSegment(t, e, i, !0); n > d && (n = d, a = o.LineUtil._sqClosestPointOnSegment(t, e, i)) } return a && (a.distance = Math.sqrt(n)), a }, getBounds: function () { return new o.LatLngBounds(this.getLatLngs()) }, _convertLatLngs: function (t, e) { var i, n, s = e ? t : []; for (i = 0, n = t.length; n > i; i++) { if (o.Util.isArray(t[i]) && "number" != typeof t[i][0]) return; s[i] = o.latLng(t[i]) } return s }, _initEvents: function () { o.Path.prototype._initEvents.call(this) }, _getPathPartStr: function (t) { for (var e, i = o.Path.VML, n = 0, s = t.length, a = ""; s > n; n++) e = t[n], i && e._round(), a += (n ? "L" : "M") + e.x + " " + e.y; return a }, _clipPoints: function () { var t, e, i, n = this._originalPoints, s = n.length; if (this.options.noClip) return void (this._parts = [n]); this._parts = []; var a = this._parts, r = this._map._pathViewport, h = o.LineUtil; for (t = 0, e = 0; s - 1 > t; t++) i = h.clipSegment(n[t], n[t + 1], r, t), i && (a[e] = a[e] || [], a[e].push(i[0]), (i[1] !== n[t + 1] || t === s - 2) && (a[e].push(i[1]), e++)) }, _simplifyPoints: function () { for (var t = this._parts, e = o.LineUtil, i = 0, n = t.length; n > i; i++) t[i] = e.simplify(t[i], this.options.smoothFactor) }, _updatePath: function () { this._map && (this._clipPoints(), this._simplifyPoints(), o.Path.prototype._updatePath.call(this)) } }), o.polyline = function (t, e) { return new o.Polyline(t, e) }, o.PolyUtil = {}, o.PolyUtil.clipPolygon = function (t, e) { var i, n, s, a, r, h, l, u, c, d = [1, 4, 2, 8], p = o.LineUtil; for (n = 0, l = t.length; l > n; n++) t[n]._code = p._getBitCode(t[n], e); for (a = 0; 4 > a; a++) { for (u = d[a], i = [], n = 0, l = t.length, s = l - 1; l > n; s = n++) r = t[n], h = t[s], r._code & u ? h._code & u || (c = p._getEdgeIntersection(h, r, u, e), c._code = p._getBitCode(c, e), i.push(c)) : (h._code & u && (c = p._getEdgeIntersection(h, r, u, e), c._code = p._getBitCode(c, e), i.push(c)), i.push(r)); t = i } return t }, o.Polygon = o.Polyline.extend({ options: { fill: !0 }, initialize: function (t, e) { o.Polyline.prototype.initialize.call(this, t, e), this._initWithHoles(t) }, _initWithHoles: function (t) { var e, i, n; if (t && o.Util.isArray(t[0]) && "number" != typeof t[0][0]) for (this._latlngs = this._convertLatLngs(t[0]), this._holes = t.slice(1), e = 0, i = this._holes.length; i > e; e++) n = this._holes[e] = this._convertLatLngs(this._holes[e]), n[0].equals(n[n.length - 1]) && n.pop(); t = this._latlngs, t.length >= 2 && t[0].equals(t[t.length - 1]) && t.pop() }, projectLatlngs: function () { if (o.Polyline.prototype.projectLatlngs.call(this), this._holePoints = [], this._holes) { var t, e, i, n; for (t = 0, i = this._holes.length; i > t; t++) for (this._holePoints[t] = [], e = 0, n = this._holes[t].length; n > e; e++) this._holePoints[t][e] = this._map.latLngToLayerPoint(this._holes[t][e]) } }, setLatLngs: function (t) { return t && o.Util.isArray(t[0]) && "number" != typeof t[0][0] ? (this._initWithHoles(t), this.redraw()) : o.Polyline.prototype.setLatLngs.call(this, t) }, _clipPoints: function () { var t = this._originalPoints, e = []; if (this._parts = [t].concat(this._holePoints), !this.options.noClip) { for (var i = 0, n = this._parts.length; n > i; i++) { var s = o.PolyUtil.clipPolygon(this._parts[i], this._map._pathViewport); s.length && e.push(s) } this._parts = e } }, _getPathPartStr: function (t) { var e = o.Polyline.prototype._getPathPartStr.call(this, t); return e + (o.Browser.svg ? "z" : "x") } }), o.polygon = function (t, e) { return new o.Polygon(t, e) }, function () { function t(t) { return o.FeatureGroup.extend({ initialize: function (t, e) { this._layers = {}, this._options = e, this.setLatLngs(t) }, setLatLngs: function (e) { var i = 0, n = e.length; for (this.eachLayer(function (t) { n > i ? t.setLatLngs(e[i++]) : this.removeLayer(t) }, this) ; n > i;) this.addLayer(new t(e[i++], this._options)); return this }, getLatLngs: function () { var t = []; return this.eachLayer(function (e) { t.push(e.getLatLngs()) }), t } }) } o.MultiPolyline = t(o.Polyline), o.MultiPolygon = t(o.Polygon), o.multiPolyline = function (t, e) { return new o.MultiPolyline(t, e) }, o.multiPolygon = function (t, e) { return new o.MultiPolygon(t, e) } }(), o.Rectangle = o.Polygon.extend({ initialize: function (t, e) { o.Polygon.prototype.initialize.call(this, this._boundsToLatLngs(t), e) }, setBounds: function (t) { this.setLatLngs(this._boundsToLatLngs(t)) }, _boundsToLatLngs: function (t) { return t = o.latLngBounds(t), [t.getSouthWest(), t.getNorthWest(), t.getNorthEast(), t.getSouthEast()] } }), o.rectangle = function (t, e) { return new o.Rectangle(t, e) }, o.Circle = o.Path.extend({ initialize: function (t, e, i) { o.Path.prototype.initialize.call(this, i), this._latlng = o.latLng(t), this._mRadius = e }, options: { fill: !0 }, setLatLng: function (t) { return this._latlng = o.latLng(t), this.redraw() }, setRadius: function (t) { return this._mRadius = t, this.redraw() }, projectLatlngs: function () { var t = this._getLngRadius(), e = this._latlng, i = this._map.latLngToLayerPoint([e.lat, e.lng - t]); this._point = this._map.latLngToLayerPoint(e), this._radius = Math.max(this._point.x - i.x, 1) }, getBounds: function () { var t = this._getLngRadius(), e = this._mRadius / 40075017 * 360, i = this._latlng; return new o.LatLngBounds([i.lat - e, i.lng - t], [i.lat + e, i.lng + t]) }, getLatLng: function () { return this._latlng }, getPathString: function () { var t = this._point, e = this._radius; return this._checkIfEmpty() ? "" : o.Browser.svg ? "M" + t.x + "," + (t.y - e) + "A" + e + "," + e + ",0,1,1," + (t.x - .1) + "," + (t.y - e) + " z" : (t._round(), e = Math.round(e), "AL " + t.x + "," + t.y + " " + e + "," + e + " 0,23592600") }, getRadius: function () { return this._mRadius }, _getLatRadius: function () { return this._mRadius / 40075017 * 360 }, _getLngRadius: function () { return this._getLatRadius() / Math.cos(o.LatLng.DEG_TO_RAD * this._latlng.lat) }, _checkIfEmpty: function () { if (!this._map) return !1; var t = this._map._pathViewport, e = this._radius, i = this._point; return i.x - e > t.max.x || i.y - e > t.max.y || i.x + e < t.min.x || i.y + e < t.min.y } }), o.circle = function (t, e, i) { return new o.Circle(t, e, i) }, o.CircleMarker = o.Circle.extend({ options: { radius: 10, weight: 2 }, initialize: function (t, e) { o.Circle.prototype.initialize.call(this, t, null, e), this._radius = this.options.radius }, projectLatlngs: function () { this._point = this._map.latLngToLayerPoint(this._latlng) }, _updateStyle: function () { o.Circle.prototype._updateStyle.call(this), this.setRadius(this.options.radius) }, setLatLng: function (t) { return o.Circle.prototype.setLatLng.call(this, t), this._popup && this._popup._isOpen && this._popup.setLatLng(t), this }, setRadius: function (t) { return this.options.radius = this._radius = t, this.redraw() }, getRadius: function () { return this._radius } }), o.circleMarker = function (t, e) { return new o.CircleMarker(t, e) }, o.Polyline.include(o.Path.CANVAS ? { _containsPoint: function (t, e) { var i, n, s, a, r, h, l, u = this.options.weight / 2; for (o.Browser.touch && (u += 10), i = 0, a = this._parts.length; a > i; i++) for (l = this._parts[i], n = 0, r = l.length, s = r - 1; r > n; s = n++) if ((e || 0 !== n) && (h = o.LineUtil.pointToSegmentDistance(t, l[s], l[n]), u >= h)) return !0; return !1 } } : {}), o.Polygon.include(o.Path.CANVAS ? { _containsPoint: function (t) { var e, i, n, s, a, r, h, l, u = !1; if (o.Polyline.prototype._containsPoint.call(this, t, !0)) return !0; for (s = 0, h = this._parts.length; h > s; s++) for (e = this._parts[s], a = 0, l = e.length, r = l - 1; l > a; r = a++) i = e[a], n = e[r], i.y > t.y != n.y > t.y && t.x < (n.x - i.x) * (t.y - i.y) / (n.y - i.y) + i.x && (u = !u); return u } } : {}), o.Circle.include(o.Path.CANVAS ? { _drawPath: function () { var t = this._point; this._ctx.beginPath(), this._ctx.arc(t.x, t.y, this._radius, 0, 2 * Math.PI, !1) }, _containsPoint: function (t) { var e = this._point, i = this.options.stroke ? this.options.weight / 2 : 0; return t.distanceTo(e) <= this._radius + i } } : {}), o.CircleMarker.include(o.Path.CANVAS ? { _updateStyle: function () { o.Path.prototype._updateStyle.call(this) } } : {}), o.GeoJSON = o.FeatureGroup.extend({ initialize: function (t, e) { o.setOptions(this, e), this._layers = {}, t && this.addData(t) }, addData: function (t) { var e, i, n, s = o.Util.isArray(t) ? t : t.features; if (s) { for (e = 0, i = s.length; i > e; e++) n = s[e], (n.geometries || n.geometry || n.features || n.coordinates) && this.addData(s[e]); return this } var a = this.options; if (!a.filter || a.filter(t)) { var r = o.GeoJSON.geometryToLayer(t, a.pointToLayer, a.coordsToLatLng, a); return r.feature = o.GeoJSON.asFeature(t), r.defaultOptions = r.options, this.resetStyle(r), a.onEachFeature && a.onEachFeature(t, r), this.addLayer(r) } }, resetStyle: function (t) { var e = this.options.style; e && (o.Util.extend(t.options, t.defaultOptions), this._setLayerStyle(t, e)) }, setStyle: function (t) { this.eachLayer(function (e) { this._setLayerStyle(e, t) }, this) }, _setLayerStyle: function (t, e) { "function" == typeof e && (e = e(t.feature)), t.setStyle && t.setStyle(e) } }), o.extend(o.GeoJSON, { geometryToLayer: function (t, e, i, n) { var s, a, r, h, l = "Feature" === t.type ? t.geometry : t, u = l.coordinates, c = []; switch (i = i || this.coordsToLatLng, l.type) { case "Point": return s = i(u), e ? e(t, s) : new o.Marker(s); case "MultiPoint": for (r = 0, h = u.length; h > r; r++) s = i(u[r]), c.push(e ? e(t, s) : new o.Marker(s)); return new o.FeatureGroup(c); case "LineString": return a = this.coordsToLatLngs(u, 0, i), new o.Polyline(a, n); case "Polygon": if (2 === u.length && !u[1].length) throw new Error("Invalid GeoJSON object."); return a = this.coordsToLatLngs(u, 1, i), new o.Polygon(a, n); case "MultiLineString": return a = this.coordsToLatLngs(u, 1, i), new o.MultiPolyline(a, n); case "MultiPolygon": return a = this.coordsToLatLngs(u, 2, i), new o.MultiPolygon(a, n); case "GeometryCollection": for (r = 0, h = l.geometries.length; h > r; r++) c.push(this.geometryToLayer({ geometry: l.geometries[r], type: "Feature", properties: t.properties }, e, i, n)); return new o.FeatureGroup(c); default: throw new Error("Invalid GeoJSON object.") } }, coordsToLatLng: function (t) { return new o.LatLng(t[1], t[0], t[2]) }, coordsToLatLngs: function (t, e, i) { var n, o, s, a = []; for (o = 0, s = t.length; s > o; o++) n = e ? this.coordsToLatLngs(t[o], e - 1, i) : (i || this.coordsToLatLng)(t[o]), a.push(n); return a }, latLngToCoords: function (t) { var e = [t.lng, t.lat]; return t.alt !== i && e.push(t.alt), e }, latLngsToCoords: function (t) { for (var e = [], i = 0, n = t.length; n > i; i++) e.push(o.GeoJSON.latLngToCoords(t[i])); return e }, getFeature: function (t, e) { return t.feature ? o.extend({}, t.feature, { geometry: e }) : o.GeoJSON.asFeature(e) }, asFeature: function (t) { return "Feature" === t.type ? t : { type: "Feature", properties: {}, geometry: t } } }); var a = { toGeoJSON: function () { return o.GeoJSON.getFeature(this, { type: "Point", coordinates: o.GeoJSON.latLngToCoords(this.getLatLng()) }) } }; o.Marker.include(a), o.Circle.include(a), o.CircleMarker.include(a), o.Polyline.include({ toGeoJSON: function () { return o.GeoJSON.getFeature(this, { type: "LineString", coordinates: o.GeoJSON.latLngsToCoords(this.getLatLngs()) }) } }), o.Polygon.include({ toGeoJSON: function () { var t, e, i, n = [o.GeoJSON.latLngsToCoords(this.getLatLngs())]; if (n[0].push(n[0][0]), this._holes) for (t = 0, e = this._holes.length; e > t; t++) i = o.GeoJSON.latLngsToCoords(this._holes[t]), i.push(i[0]), n.push(i); return o.GeoJSON.getFeature(this, { type: "Polygon", coordinates: n }) } }), function () { function t(t) { return function () { var e = []; return this.eachLayer(function (t) { e.push(t.toGeoJSON().geometry.coordinates) }), o.GeoJSON.getFeature(this, { type: t, coordinates: e }) } } o.MultiPolyline.include({ toGeoJSON: t("MultiLineString") }), o.MultiPolygon.include({ toGeoJSON: t("MultiPolygon") }), o.LayerGroup.include({ toGeoJSON: function () { var e, i = this.feature && this.feature.geometry, n = []; if (i && "MultiPoint" === i.type) return t("MultiPoint").call(this); var s = i && "GeometryCollection" === i.type; return this.eachLayer(function (t) { t.toGeoJSON && (e = t.toGeoJSON(), n.push(s ? e.geometry : o.GeoJSON.asFeature(e))) }), s ? o.GeoJSON.getFeature(this, { geometries: n, type: "GeometryCollection" }) : { type: "FeatureCollection", features: n } } }) }(), o.geoJson = function (t, e) { return new o.GeoJSON(t, e) }, o.DomEvent = { addListener: function (t, e, i, n) { var s, a, r, h = o.stamp(i), l = "_leaflet_" + e + h; return t[l] ? this : (s = function (e) { return i.call(n || t, e || o.DomEvent._getEvent()) }, o.Browser.pointer && 0 === e.indexOf("touch") ? this.addPointerListener(t, e, s, h) : (o.Browser.touch && "dblclick" === e && this.addDoubleTapListener && this.addDoubleTapListener(t, s, h), "addEventListener" in t ? "mousewheel" === e ? (t.addEventListener("DOMMouseScroll", s, !1), t.addEventListener(e, s, !1)) : "mouseenter" === e || "mouseleave" === e ? (a = s, r = "mouseenter" === e ? "mouseover" : "mouseout", s = function (e) { return o.DomEvent._checkMouse(t, e) ? a(e) : void 0 }, t.addEventListener(r, s, !1)) : "click" === e && o.Browser.android ? (a = s, s = function (t) { return o.DomEvent._filterClick(t, a) }, t.addEventListener(e, s, !1)) : t.addEventListener(e, s, !1) : "attachEvent" in t && t.attachEvent("on" + e, s), t[l] = s, this)) }, removeListener: function (t, e, i) { var n = o.stamp(i), s = "_leaflet_" + e + n, a = t[s]; return a ? (o.Browser.pointer && 0 === e.indexOf("touch") ? this.removePointerListener(t, e, n) : o.Browser.touch && "dblclick" === e && this.removeDoubleTapListener ? this.removeDoubleTapListener(t, n) : "removeEventListener" in t ? "mousewheel" === e ? (t.removeEventListener("DOMMouseScroll", a, !1), t.removeEventListener(e, a, !1)) : "mouseenter" === e || "mouseleave" === e ? t.removeEventListener("mouseenter" === e ? "mouseover" : "mouseout", a, !1) : t.removeEventListener(e, a, !1) : "detachEvent" in t && t.detachEvent("on" + e, a), t[s] = null, this) : this }, stopPropagation: function (t) { return t.stopPropagation ? t.stopPropagation() : t.cancelBubble = !0, o.DomEvent._skipped(t), this }, disableScrollPropagation: function (t) { var e = o.DomEvent.stopPropagation; return o.DomEvent.on(t, "mousewheel", e).on(t, "MozMousePixelScroll", e) }, disableClickPropagation: function (t) { for (var e = o.DomEvent.stopPropagation, i = o.Draggable.START.length - 1; i >= 0; i--) o.DomEvent.on(t, o.Draggable.START[i], e); return o.DomEvent.on(t, "click", o.DomEvent._fakeStop).on(t, "dblclick", e) }, preventDefault: function (t) { return t.preventDefault ? t.preventDefault() : t.returnValue = !1, this }, stop: function (t) { return o.DomEvent.preventDefault(t).stopPropagation(t) }, getMousePosition: function (t, e) { if (!e) return new o.Point(t.clientX, t.clientY); var i = e.getBoundingClientRect(); return new o.Point(t.clientX - i.left - e.clientLeft, t.clientY - i.top - e.clientTop) }, getWheelDelta: function (t) { var e = 0; return t.wheelDelta && (e = t.wheelDelta / 120), t.detail && (e = -t.detail / 3), e }, _skipEvents: {}, _fakeStop: function (t) { o.DomEvent._skipEvents[t.type] = !0 }, _skipped: function (t) { var e = this._skipEvents[t.type]; return this._skipEvents[t.type] = !1, e }, _checkMouse: function (t, e) { var i = e.relatedTarget; if (!i) return !0; try { for (; i && i !== t;) i = i.parentNode } catch (n) { return !1 } return i !== t }, _getEvent: function () { var e = t.event; if (!e) for (var i = arguments.callee.caller; i && (e = i.arguments[0], !e || t.Event !== e.constructor) ;) i = i.caller; return e }, _filterClick: function (t, e) { var i = t.timeStamp || t.originalEvent.timeStamp, n = o.DomEvent._lastClick && i - o.DomEvent._lastClick; return n && n > 100 && 500 > n || t.target._simulatedClick && !t._simulated ? void o.DomEvent.stop(t) : (o.DomEvent._lastClick = i, e(t)) } }, o.DomEvent.on = o.DomEvent.addListener, o.DomEvent.off = o.DomEvent.removeListener, o.Draggable = o.Class.extend({ includes: o.Mixin.Events, statics: { START: o.Browser.touch ? ["touchstart", "mousedown"] : ["mousedown"], END: { mousedown: "mouseup", touchstart: "touchend", pointerdown: "touchend", MSPointerDown: "touchend" }, MOVE: { mousedown: "mousemove", touchstart: "touchmove", pointerdown: "touchmove", MSPointerDown: "touchmove" } }, initialize: function (t, e) { this._element = t, this._dragStartTarget = e || t }, enable: function () { if (!this._enabled) { for (var t = o.Draggable.START.length - 1; t >= 0; t--) o.DomEvent.on(this._dragStartTarget, o.Draggable.START[t], this._onDown, this); this._enabled = !0 } }, disable: function () { if (this._enabled) { for (var t = o.Draggable.START.length - 1; t >= 0; t--) o.DomEvent.off(this._dragStartTarget, o.Draggable.START[t], this._onDown, this); this._enabled = !1, this._moved = !1 } }, _onDown: function (t) { if (this._moved = !1, !(t.shiftKey || 1 !== t.which && 1 !== t.button && !t.touches || (o.DomEvent.stopPropagation(t), o.Draggable._disabled || (o.DomUtil.disableImageDrag(), o.DomUtil.disableTextSelection(), this._moving)))) { var i = t.touches ? t.touches[0] : t; this._startPoint = new o.Point(i.clientX, i.clientY), this._startPos = this._newPos = o.DomUtil.getPosition(this._element), o.DomEvent.on(e, o.Draggable.MOVE[t.type], this._onMove, this).on(e, o.Draggable.END[t.type], this._onUp, this) } }, _onMove: function (t) { if (t.touches && t.touches.length > 1) return void (this._moved = !0); var i = t.touches && 1 === t.touches.length ? t.touches[0] : t, n = new o.Point(i.clientX, i.clientY), s = n.subtract(this._startPoint); (s.x || s.y) && (o.Browser.touch && Math.abs(s.x) + Math.abs(s.y) < 3 || (o.DomEvent.preventDefault(t), this._moved || (this.fire("dragstart"), this._moved = !0, this._startPos = o.DomUtil.getPosition(this._element).subtract(s), o.DomUtil.addClass(e.body, "leaflet-dragging"), this._lastTarget = t.target || t.srcElement, o.DomUtil.addClass(this._lastTarget, "leaflet-drag-target")), this._newPos = this._startPos.add(s), this._moving = !0, o.Util.cancelAnimFrame(this._animRequest), this._animRequest = o.Util.requestAnimFrame(this._updatePosition, this, !0, this._dragStartTarget))) }, _updatePosition: function () { this.fire("predrag"), o.DomUtil.setPosition(this._element, this._newPos), this.fire("drag") }, _onUp: function () { o.DomUtil.removeClass(e.body, "leaflet-dragging"), this._lastTarget && (o.DomUtil.removeClass(this._lastTarget, "leaflet-drag-target"), this._lastTarget = null); for (var t in o.Draggable.MOVE) o.DomEvent.off(e, o.Draggable.MOVE[t], this._onMove).off(e, o.Draggable.END[t], this._onUp); o.DomUtil.enableImageDrag(), o.DomUtil.enableTextSelection(), this._moved && this._moving && (o.Util.cancelAnimFrame(this._animRequest), this.fire("dragend", { distance: this._newPos.distanceTo(this._startPos) })), this._moving = !1 } }), o.Handler = o.Class.extend({ initialize: function (t) { this._map = t }, enable: function () { this._enabled || (this._enabled = !0, this.addHooks()) }, disable: function () { this._enabled && (this._enabled = !1, this.removeHooks()) }, enabled: function () { return !!this._enabled } }), o.Map.mergeOptions({ dragging: !0, inertia: !o.Browser.android23, inertiaDeceleration: 3400, inertiaMaxSpeed: 1 / 0, inertiaThreshold: o.Browser.touch ? 32 : 18, easeLinearity: .25, worldCopyJump: !1 }), o.Map.Drag = o.Handler.extend({ addHooks: function () { if (!this._draggable) { var t = this._map; this._draggable = new o.Draggable(t._mapPane, t._container), this._draggable.on({ dragstart: this._onDragStart, drag: this._onDrag, dragend: this._onDragEnd }, this), t.options.worldCopyJump && (this._draggable.on("predrag", this._onPreDrag, this), t.on("viewreset", this._onViewReset, this), t.whenReady(this._onViewReset, this)) } this._draggable.enable() }, removeHooks: function () { this._draggable.disable() }, moved: function () { return this._draggable && this._draggable._moved }, _onDragStart: function () { var t = this._map; t._panAnim && t._panAnim.stop(), t.fire("movestart").fire("dragstart"), t.options.inertia && (this._positions = [], this._times = []) }, _onDrag: function () { if (this._map.options.inertia) { var t = this._lastTime = +new Date, e = this._lastPos = this._draggable._newPos; this._positions.push(e), this._times.push(t), t - this._times[0] > 200 && (this._positions.shift(), this._times.shift()) } this._map.fire("move").fire("drag") }, _onViewReset: function () { var t = this._map.getSize()._divideBy(2), e = this._map.latLngToLayerPoint([0, 0]); this._initialWorldOffset = e.subtract(t).x, this._worldWidth = this._map.project([0, 180]).x }, _onPreDrag: function () { var t = this._worldWidth, e = Math.round(t / 2), i = this._initialWorldOffset, n = this._draggable._newPos.x, o = (n - e + i) % t + e - i, s = (n + e + i) % t - e - i, a = Math.abs(o + i) < Math.abs(s + i) ? o : s; this._draggable._newPos.x = a }, _onDragEnd: function (t) { var e = this._map, i = e.options, n = +new Date - this._lastTime, s = !i.inertia || n > i.inertiaThreshold || !this._positions[0]; if (e.fire("dragend", t), s) e.fire("moveend"); else { var a = this._lastPos.subtract(this._positions[0]), r = (this._lastTime + n - this._times[0]) / 1e3, h = i.easeLinearity, l = a.multiplyBy(h / r), u = l.distanceTo([0, 0]), c = Math.min(i.inertiaMaxSpeed, u), d = l.multiplyBy(c / u), p = c / (i.inertiaDeceleration * h), _ = d.multiplyBy(-p / 2).round(); _.x && _.y ? (_ = e._limitOffset(_, e.options.maxBounds), o.Util.requestAnimFrame(function () { e.panBy(_, { duration: p, easeLinearity: h, noMoveStart: !0 }) })) : e.fire("moveend") } } }), o.Map.addInitHook("addHandler", "dragging", o.Map.Drag), o.Map.mergeOptions({ doubleClickZoom: !0 }), o.Map.DoubleClickZoom = o.Handler.extend({ addHooks: function () { this._map.on("dblclick", this._onDoubleClick, this) }, removeHooks: function () { this._map.off("dblclick", this._onDoubleClick, this) }, _onDoubleClick: function (t) { var e = this._map, i = e.getZoom() + (t.originalEvent.shiftKey ? -1 : 1); "center" === e.options.doubleClickZoom ? e.setZoom(i) : e.setZoomAround(t.containerPoint, i) } }), o.Map.addInitHook("addHandler", "doubleClickZoom", o.Map.DoubleClickZoom), o.Map.mergeOptions({ scrollWheelZoom: !0 }), o.Map.ScrollWheelZoom = o.Handler.extend({ addHooks: function () { o.DomEvent.on(this._map._container, "mousewheel", this._onWheelScroll, this), o.DomEvent.on(this._map._container, "MozMousePixelScroll", o.DomEvent.preventDefault), this._delta = 0 }, removeHooks: function () { o.DomEvent.off(this._map._container, "mousewheel", this._onWheelScroll), o.DomEvent.off(this._map._container, "MozMousePixelScroll", o.DomEvent.preventDefault) }, _onWheelScroll: function (t) { var e = o.DomEvent.getWheelDelta(t); this._delta += e, this._lastMousePos = this._map.mouseEventToContainerPoint(t), this._startTime || (this._startTime = +new Date); var i = Math.max(40 - (+new Date - this._startTime), 0); clearTimeout(this._timer), this._timer = setTimeout(o.bind(this._performZoom, this), i), o.DomEvent.preventDefault(t), o.DomEvent.stopPropagation(t) }, _performZoom: function () { var t = this._map, e = this._delta, i = t.getZoom(); e = e > 0 ? Math.ceil(e) : Math.floor(e), e = Math.max(Math.min(e, 4), -4), e = t._limitZoom(i + e) - i, this._delta = 0, this._startTime = null, e && ("center" === t.options.scrollWheelZoom ? t.setZoom(i + e) : t.setZoomAround(this._lastMousePos, i + e)) } }), o.Map.addInitHook("addHandler", "scrollWheelZoom", o.Map.ScrollWheelZoom), o.extend(o.DomEvent, { _touchstart: o.Browser.msPointer ? "MSPointerDown" : o.Browser.pointer ? "pointerdown" : "touchstart", _touchend: o.Browser.msPointer ? "MSPointerUp" : o.Browser.pointer ? "pointerup" : "touchend", addDoubleTapListener: function (t, i, n) { function s(t) { var e; if (o.Browser.pointer ? (_.push(t.pointerId), e = _.length) : e = t.touches.length, !(e > 1)) { var i = Date.now(), n = i - (r || i); h = t.touches ? t.touches[0] : t, l = n > 0 && u >= n, r = i } } function a(t) { if (o.Browser.pointer) { var e = _.indexOf(t.pointerId); if (-1 === e) return; _.splice(e, 1) } if (l) { if (o.Browser.pointer) { var n, s = {}; for (var a in h) n = h[a], "function" == typeof n ? s[a] = n.bind(h) : s[a] = n; h = s } h.type = "dblclick", i(h), r = null } } var r, h, l = !1, u = 250, c = "_leaflet_", d = this._touchstart, p = this._touchend, _ = []; t[c + d + n] = s, t[c + p + n] = a; var m = o.Browser.pointer ? e.documentElement : t; return t.addEventListener(d, s, !1), m.addEventListener(p, a, !1), o.Browser.pointer && m.addEventListener(o.DomEvent.POINTER_CANCEL, a, !1), this }, removeDoubleTapListener: function (t, i) { var n = "_leaflet_"; return t.removeEventListener(this._touchstart, t[n + this._touchstart + i], !1), (o.Browser.pointer ? e.documentElement : t).removeEventListener(this._touchend, t[n + this._touchend + i], !1), o.Browser.pointer && e.documentElement.removeEventListener(o.DomEvent.POINTER_CANCEL, t[n + this._touchend + i], !1), this } }), o.extend(o.DomEvent, {
POINTER_DOWN: o.Browser.msPointer ? "MSPointerDown" : "pointerdown", POINTER_MOVE: o.Browser.msPointer ? "MSPointerMove" : "pointermove", POINTER_UP: o.Browser.msPointer ? "MSPointerUp" : "pointerup", POINTER_CANCEL: o.Browser.msPointer ? "MSPointerCancel" : "pointercancel", _pointers: [], _pointerDocumentListener: !1, addPointerListener: function (t, e, i, n) {
switch (e) {
case "touchstart": return this.addPointerListenerStart(t, e, i, n);
case "touchend": return this.addPointerListenerEnd(t, e, i, n); case "touchmove": return this.addPointerListenerMove(t, e, i, n); default: throw "Unknown touch event type"
}
}, addPointerListenerStart: function (t, i, n, s) { var a = "_leaflet_", r = this._pointers, h = function (t) { o.DomEvent.preventDefault(t); for (var e = !1, i = 0; i < r.length; i++) if (r[i].pointerId === t.pointerId) { e = !0; break } e || r.push(t), t.touches = r.slice(), t.changedTouches = [t], n(t) }; if (t[a + "touchstart" + s] = h, t.addEventListener(this.POINTER_DOWN, h, !1), !this._pointerDocumentListener) { var l = function (t) { for (var e = 0; e < r.length; e++) if (r[e].pointerId === t.pointerId) { r.splice(e, 1); break } }; e.documentElement.addEventListener(this.POINTER_UP, l, !1), e.documentElement.addEventListener(this.POINTER_CANCEL, l, !1), this._pointerDocumentListener = !0 } return this }, addPointerListenerMove: function (t, e, i, n) { function o(t) { if (t.pointerType !== t.MSPOINTER_TYPE_MOUSE && "mouse" !== t.pointerType || 0 !== t.buttons) { for (var e = 0; e < a.length; e++) if (a[e].pointerId === t.pointerId) { a[e] = t; break } t.touches = a.slice(), t.changedTouches = [t], i(t) } } var s = "_leaflet_", a = this._pointers; return t[s + "touchmove" + n] = o, t.addEventListener(this.POINTER_MOVE, o, !1), this }, addPointerListenerEnd: function (t, e, i, n) { var o = "_leaflet_", s = this._pointers, a = function (t) { for (var e = 0; e < s.length; e++) if (s[e].pointerId === t.pointerId) { s.splice(e, 1); break } t.touches = s.slice(), t.changedTouches = [t], i(t) }; return t[o + "touchend" + n] = a, t.addEventListener(this.POINTER_UP, a, !1), t.addEventListener(this.POINTER_CANCEL, a, !1), this }, removePointerListener: function (t, e, i) { var n = "_leaflet_", o = t[n + e + i]; switch (e) { case "touchstart": t.removeEventListener(this.POINTER_DOWN, o, !1); break; case "touchmove": t.removeEventListener(this.POINTER_MOVE, o, !1); break; case "touchend": t.removeEventListener(this.POINTER_UP, o, !1), t.removeEventListener(this.POINTER_CANCEL, o, !1) } return this }
}), o.Map.mergeOptions({ touchZoom: o.Browser.touch && !o.Browser.android23, bounceAtZoomLimits: !0 }), o.Map.TouchZoom = o.Handler.extend({ addHooks: function () { o.DomEvent.on(this._map._container, "touchstart", this._onTouchStart, this) }, removeHooks: function () { o.DomEvent.off(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 n = i.mouseEventToLayerPoint(t.touches[0]), s = i.mouseEventToLayerPoint(t.touches[1]), a = i._getCenterLayerPoint(); this._startCenter = n.add(s)._divideBy(2), this._startDist = n.distanceTo(s), this._moved = !1, this._zooming = !0, this._centerOffset = a.subtract(this._startCenter), i._panAnim && i._panAnim.stop(), o.DomEvent.on(e, "touchmove", this._onTouchMove, this).on(e, "touchend", this._onTouchEnd, this), o.DomEvent.preventDefault(t) } }, _onTouchMove: function (t) { var e = this._map; if (t.touches && 2 === t.touches.length && this._zooming) { var i = e.mouseEventToLayerPoint(t.touches[0]), n = e.mouseEventToLayerPoint(t.touches[1]); this._scale = i.distanceTo(n) / this._startDist, this._delta = i._add(n)._divideBy(2)._subtract(this._startCenter), 1 !== this._scale && (e.options.bounceAtZoomLimits || !(e.getZoom() === e.getMinZoom() && this._scale < 1 || e.getZoom() === e.getMaxZoom() && this._scale > 1)) && (this._moved || (o.DomUtil.addClass(e._mapPane, "leaflet-touching"), e.fire("movestart").fire("zoomstart"), this._moved = !0), o.Util.cancelAnimFrame(this._animRequest), this._animRequest = o.Util.requestAnimFrame(this._updateOnMove, this, !0, this._map._container), o.DomEvent.preventDefault(t)) } }, _updateOnMove: function () { var t = this._map, e = this._getScaleOrigin(), i = t.layerPointToLatLng(e), n = t.getScaleZoom(this._scale); t._animateZoom(i, n, this._startCenter, this._scale, this._delta, !1, !0) }, _onTouchEnd: function () { if (!this._moved || !this._zooming) return void (this._zooming = !1); var t = this._map; this._zooming = !1, o.DomUtil.removeClass(t._mapPane, "leaflet-touching"), o.Util.cancelAnimFrame(this._animRequest), o.DomEvent.off(e, "touchmove", this._onTouchMove).off(e, "touchend", this._onTouchEnd); var i = this._getScaleOrigin(), n = t.layerPointToLatLng(i), s = t.getZoom(), a = t.getScaleZoom(this._scale) - s, r = a > 0 ? Math.ceil(a) : Math.floor(a), h = t._limitZoom(s + r), l = t.getZoomScale(h) / this._scale; t._animateZoom(n, h, i, l) }, _getScaleOrigin: function () { var t = this._centerOffset.subtract(this._delta).divideBy(this._scale); return this._startCenter.add(t) } }), o.Map.addInitHook("addHandler", "touchZoom", o.Map.TouchZoom), o.Map.mergeOptions({ tap: !0, tapTolerance: 15 }), o.Map.Tap = o.Handler.extend({ addHooks: function () { o.DomEvent.on(this._map._container, "touchstart", this._onDown, this) }, removeHooks: function () { o.DomEvent.off(this._map._container, "touchstart", this._onDown, this) }, _onDown: function (t) { if (t.touches) { if (o.DomEvent.preventDefault(t), this._fireClick = !0, t.touches.length > 1) return this._fireClick = !1, void clearTimeout(this._holdTimeout); var i = t.touches[0], n = i.target; this._startPos = this._newPos = new o.Point(i.clientX, i.clientY), n.tagName && "a" === n.tagName.toLowerCase() && o.DomUtil.addClass(n, "leaflet-active"), this._holdTimeout = setTimeout(o.bind(function () { this._isTapValid() && (this._fireClick = !1, this._onUp(), this._simulateEvent("contextmenu", i)) }, this), 1e3), o.DomEvent.on(e, "touchmove", this._onMove, this).on(e, "touchend", this._onUp, this) } }, _onUp: function (t) { if (clearTimeout(this._holdTimeout), o.DomEvent.off(e, "touchmove", this._onMove, this).off(e, "touchend", this._onUp, this), this._fireClick && t && t.changedTouches) { var i = t.changedTouches[0], n = i.target; n && n.tagName && "a" === n.tagName.toLowerCase() && o.DomUtil.removeClass(n, "leaflet-active"), this._isTapValid() && this._simulateEvent("click", i) } }, _isTapValid: function () { return this._newPos.distanceTo(this._startPos) <= this._map.options.tapTolerance }, _onMove: function (t) { var e = t.touches[0]; this._newPos = new o.Point(e.clientX, e.clientY) }, _simulateEvent: function (i, n) { var o = e.createEvent("MouseEvents"); o._simulated = !0, n.target._simulatedClick = !0, o.initMouseEvent(i, !0, !0, t, 1, n.screenX, n.screenY, n.clientX, n.clientY, !1, !1, !1, !1, 0, null), n.target.dispatchEvent(o) } }), o.Browser.touch && !o.Browser.pointer && o.Map.addInitHook("addHandler", "tap", o.Map.Tap), o.Map.mergeOptions({ boxZoom: !0 }), o.Map.BoxZoom = o.Handler.extend({ initialize: function (t) { this._map = t, this._container = t._container, this._pane = t._panes.overlayPane, this._moved = !1 }, addHooks: function () { o.DomEvent.on(this._container, "mousedown", this._onMouseDown, this) }, removeHooks: function () { o.DomEvent.off(this._container, "mousedown", this._onMouseDown), this._moved = !1 }, moved: function () { return this._moved }, _onMouseDown: function (t) { return this._moved = !1, !t.shiftKey || 1 !== t.which && 1 !== t.button ? !1 : (o.DomUtil.disableTextSelection(), o.DomUtil.disableImageDrag(), this._startLayerPoint = this._map.mouseEventToLayerPoint(t), void o.DomEvent.on(e, "mousemove", this._onMouseMove, this).on(e, "mouseup", this._onMouseUp, this).on(e, "keydown", this._onKeyDown, this)) }, _onMouseMove: function (t) { this._moved || (this._box = o.DomUtil.create("div", "leaflet-zoom-box", this._pane), o.DomUtil.setPosition(this._box, this._startLayerPoint), this._container.style.cursor = "crosshair", this._map.fire("boxzoomstart")); var e = this._startLayerPoint, i = this._box, n = this._map.mouseEventToLayerPoint(t), s = n.subtract(e), a = new o.Point(Math.min(n.x, e.x), Math.min(n.y, e.y)); o.DomUtil.setPosition(i, a), this._moved = !0, i.style.width = Math.max(0, Math.abs(s.x) - 4) + "px", i.style.height = Math.max(0, Math.abs(s.y) - 4) + "px" }, _finish: function () { this._moved && (this._pane.removeChild(this._box), this._container.style.cursor = ""), o.DomUtil.enableTextSelection(), o.DomUtil.enableImageDrag(), o.DomEvent.off(e, "mousemove", this._onMouseMove).off(e, "mouseup", this._onMouseUp).off(e, "keydown", this._onKeyDown) }, _onMouseUp: function (t) { this._finish(); var e = this._map, i = e.mouseEventToLayerPoint(t); if (!this._startLayerPoint.equals(i)) { var n = new o.LatLngBounds(e.layerPointToLatLng(this._startLayerPoint), e.layerPointToLatLng(i)); e.fitBounds(n), e.fire("boxzoomend", { boxZoomBounds: n }) } }, _onKeyDown: function (t) { 27 === t.keyCode && this._finish() } }), o.Map.addInitHook("addHandler", "boxZoom", o.Map.BoxZoom), o.Map.mergeOptions({ keyboard: !0, keyboardPanOffset: 80, keyboardZoomOffset: 1 }), o.Map.Keyboard = o.Handler.extend({ keyCodes: { left: [37], right: [39], down: [40], up: [38], zoomIn: [187, 107, 61, 171], zoomOut: [189, 109, 173] }, initialize: function (t) { this._map = t, this._setPanOffset(t.options.keyboardPanOffset), this._setZoomOffset(t.options.keyboardZoomOffset) }, addHooks: function () { var t = this._map._container; -1 === t.tabIndex && (t.tabIndex = "0"), o.DomEvent.on(t, "focus", this._onFocus, this).on(t, "blur", this._onBlur, this).on(t, "mousedown", this._onMouseDown, this), this._map.on("focus", this._addHooks, this).on("blur", this._removeHooks, this) }, removeHooks: function () { this._removeHooks(); var t = this._map._container; o.DomEvent.off(t, "focus", this._onFocus, this).off(t, "blur", this._onBlur, this).off(t, "mousedown", this._onMouseDown, this), this._map.off("focus", this._addHooks, this).off("blur", this._removeHooks, this) }, _onMouseDown: function () { if (!this._focused) { var i = e.body, n = e.documentElement, o = i.scrollTop || n.scrollTop, s = i.scrollLeft || n.scrollLeft; this._map._container.focus(), t.scrollTo(s, o) } }, _onFocus: function () { this._focused = !0, this._map.fire("focus") }, _onBlur: function () { this._focused = !1, this._map.fire("blur") }, _setPanOffset: function (t) { var e, i, n = this._panKeys = {}, o = this.keyCodes; for (e = 0, i = o.left.length; i > e; e++) n[o.left[e]] = [-1 * t, 0]; for (e = 0, i = o.right.length; i > e; e++) n[o.right[e]] = [t, 0]; for (e = 0, i = o.down.length; i > e; e++) n[o.down[e]] = [0, t]; for (e = 0, i = o.up.length; i > e; e++) n[o.up[e]] = [0, -1 * t] }, _setZoomOffset: function (t) { var e, i, n = this._zoomKeys = {}, o = this.keyCodes; for (e = 0, i = o.zoomIn.length; i > e; e++) n[o.zoomIn[e]] = t; for (e = 0, i = o.zoomOut.length; i > e; e++) n[o.zoomOut[e]] = -t }, _addHooks: function () { o.DomEvent.on(e, "keydown", this._onKeyDown, this) }, _removeHooks: function () { o.DomEvent.off(e, "keydown", this._onKeyDown, this) }, _onKeyDown: function (t) { var e = t.keyCode, i = this._map; if (e in this._panKeys) { if (i._panAnim && i._panAnim._inProgress) return; i.panBy(this._panKeys[e]), i.options.maxBounds && i.panInsideBounds(i.options.maxBounds) } else { if (!(e in this._zoomKeys)) return; i.setZoom(i.getZoom() + this._zoomKeys[e]) } o.DomEvent.stop(t) } }), o.Map.addInitHook("addHandler", "keyboard", o.Map.Keyboard), o.Handler.MarkerDrag = o.Handler.extend({ initialize: function (t) { this._marker = t }, addHooks: function () { var t = this._marker._icon; this._draggable || (this._draggable = new o.Draggable(t, t)), this._draggable.on("dragstart", this._onDragStart, this).on("drag", this._onDrag, this).on("dragend", this._onDragEnd, this), this._draggable.enable(), o.DomUtil.addClass(this._marker._icon, "leaflet-marker-draggable") }, removeHooks: function () { this._draggable.off("dragstart", this._onDragStart, this).off("drag", this._onDrag, this).off("dragend", this._onDragEnd, this), this._draggable.disable(), o.DomUtil.removeClass(this._marker._icon, "leaflet-marker-draggable") }, moved: function () { return this._draggable && this._draggable._moved }, _onDragStart: function () { this._marker.closePopup().fire("movestart").fire("dragstart") }, _onDrag: function () { var t = this._marker, e = t._shadow, i = o.DomUtil.getPosition(t._icon), n = t._map.layerPointToLatLng(i); e && o.DomUtil.setPosition(e, i), t._latlng = n, t.fire("move", { latlng: n }).fire("drag") }, _onDragEnd: function (t) { this._marker.fire("moveend").fire("dragend", t) } }), o.Control = o.Class.extend({ options: { position: "topright" }, initialize: function (t) { o.setOptions(this, t) }, getPosition: function () { return this.options.position }, setPosition: function (t) { var e = this._map; return e && e.removeControl(this), this.options.position = t, e && e.addControl(this), this }, getContainer: function () { return this._container }, addTo: function (t) { this._map = t; var e = this._container = this.onAdd(t), i = this.getPosition(), n = t._controlCorners[i]; return o.DomUtil.addClass(e, "leaflet-control"), -1 !== i.indexOf("bottom") ? n.insertBefore(e, n.firstChild) : n.appendChild(e), this }, removeFrom: function (t) { var e = this.getPosition(), i = t._controlCorners[e]; return i.removeChild(this._container), this._map = null, this.onRemove && this.onRemove(t), this }, _refocusOnMap: function () { this._map && this._map.getContainer().focus() } }), o.control = function (t) { return new o.Control(t) }, o.Map.include({ addControl: function (t) { return t.addTo(this), this }, removeControl: function (t) { return t.removeFrom(this), this }, _initControlPos: function () { function t(t, s) { var a = i + t + " " + i + s; e[t + s] = o.DomUtil.create("div", a, n) } var e = this._controlCorners = {}, i = "leaflet-", n = this._controlContainer = o.DomUtil.create("div", i + "control-container", this._container); t("top", "left"), t("top", "right"), t("bottom", "left"), t("bottom", "right") }, _clearControlPos: function () { this._container.removeChild(this._controlContainer) } }), o.Control.Zoom = o.Control.extend({ options: { position: "topleft", zoomInText: "+", zoomInTitle: "Zoom in", zoomOutText: "-", zoomOutTitle: "Zoom out" }, onAdd: function (t) { var e = "leaflet-control-zoom", i = o.DomUtil.create("div", e + " leaflet-bar"); return this._map = t, this._zoomInButton = this._createButton(this.options.zoomInText, this.options.zoomInTitle, e + "-in", i, this._zoomIn, this), this._zoomOutButton = this._createButton(this.options.zoomOutText, this.options.zoomOutTitle, e + "-out", i, this._zoomOut, this), this._updateDisabled(), t.on("zoomend zoomlevelschange", this._updateDisabled, this), i }, onRemove: function (t) { t.off("zoomend zoomlevelschange", this._updateDisabled, this) }, _zoomIn: function (t) { this._map.zoomIn(t.shiftKey ? 3 : 1) }, _zoomOut: function (t) { this._map.zoomOut(t.shiftKey ? 3 : 1) }, _createButton: function (t, e, i, n, s, a) { var r = o.DomUtil.create("a", i, n); r.innerHTML = t, r.href = "#", r.title = e; var h = o.DomEvent.stopPropagation; return o.DomEvent.on(r, "click", h).on(r, "mousedown", h).on(r, "dblclick", h).on(r, "click", o.DomEvent.preventDefault).on(r, "click", s, a).on(r, "click", this._refocusOnMap, a), r }, _updateDisabled: function () { var t = this._map, e = "leaflet-disabled"; o.DomUtil.removeClass(this._zoomInButton, e), o.DomUtil.removeClass(this._zoomOutButton, e), t._zoom === t.getMinZoom() && o.DomUtil.addClass(this._zoomOutButton, e), t._zoom === t.getMaxZoom() && o.DomUtil.addClass(this._zoomInButton, e) } }), o.Map.mergeOptions({ zoomControl: !0 }), o.Map.addInitHook(function () { this.options.zoomControl && (this.zoomControl = new o.Control.Zoom, this.addControl(this.zoomControl)) }), o.control.zoom = function (t) { return new o.Control.Zoom(t) }, o.Control.Attribution = o.Control.extend({ options: { position: "bottomright", prefix: '' }, initialize: function (t) { o.setOptions(this, t), this._attributions = {} }, onAdd: function (t) { this._container = o.DomUtil.create("div", "leaflet-control-attribution"), o.DomEvent.disableClickPropagation(this._container); for (var e in t._layers) t._layers[e].getAttribution && this.addAttribution(t._layers[e].getAttribution()); return t.on("layeradd", this._onLayerAdd, this).on("layerremove", this._onLayerRemove, this), this._update(), this._container }, onRemove: function (t) { t.off("layeradd", this._onLayerAdd).off("layerremove", this._onLayerRemove) }, 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) : void 0 }, removeAttribution: function (t) { return t ? (this._attributions[t] && (this._attributions[t]--, this._update()), this) : void 0 }, _update: function () { if (this._map) { var t = []; for (var e in this._attributions) this._attributions[e] && t.push(e); var i = []; this.options.prefix && i.push(this.options.prefix), t.length && i.push(t.join(", ")), this._container.innerHTML = i.join(" | ") } }, _onLayerAdd: function (t) { t.layer.getAttribution && this.addAttribution(t.layer.getAttribution()) }, _onLayerRemove: function (t) { t.layer.getAttribution && this.removeAttribution(t.layer.getAttribution()) } }), o.Map.mergeOptions({ attributionControl: !0 }), o.Map.addInitHook(function () { this.options.attributionControl && (this.attributionControl = (new o.Control.Attribution).addTo(this)) }), o.control.attribution = function (t) { return new o.Control.Attribution(t) }, o.Control.Scale = o.Control.extend({ options: { position: "bottomleft", maxWidth: 100, metric: !0, imperial: !0, updateWhenIdle: !1 }, onAdd: function (t) { this._map = t; var e = "leaflet-control-scale", i = o.DomUtil.create("div", e), n = this.options; return this._addScales(n, e, i), t.on(n.updateWhenIdle ? "moveend" : "move", this._update, this), t.whenReady(this._update, this), i }, onRemove: function (t) { t.off(this.options.updateWhenIdle ? "moveend" : "move", this._update, this) }, _addScales: function (t, e, i) { t.metric && (this._mScale = o.DomUtil.create("div", e + "-line", i)), t.imperial && (this._iScale = o.DomUtil.create("div", e + "-line", i)) }, _update: function () { var t = this._map.getBounds(), e = t.getCenter().lat, i = 6378137 * Math.PI * Math.cos(e * Math.PI / 180), n = i * (t.getNorthEast().lng - t.getSouthWest().lng) / 180, o = this._map.getSize(), s = this.options, a = 0; o.x > 0 && (a = n * (s.maxWidth / o.x)), this._updateScales(s, a) }, _updateScales: function (t, e) { t.metric && e && this._updateMetric(e), t.imperial && e && this._updateImperial(e) }, _updateMetric: function (t) { var e = this._getRoundNum(t); this._mScale.style.width = this._getScaleWidth(e / t) + "px", this._mScale.innerHTML = 1e3 > e ? e + " m" : e / 1e3 + " km" }, _updateImperial: function (t) { var e, i, n, o = 3.2808399 * t, s = this._iScale; o > 5280 ? (e = o / 5280, i = this._getRoundNum(e), s.style.width = this._getScaleWidth(i / e) + "px", s.innerHTML = i + " mi") : (n = this._getRoundNum(o), s.style.width = this._getScaleWidth(n / o) + "px", s.innerHTML = n + " ft") }, _getScaleWidth: function (t) { return Math.round(this.options.maxWidth * t) - 10 }, _getRoundNum: function (t) { var e = Math.pow(10, (Math.floor(t) + "").length - 1), i = t / e; return i = i >= 10 ? 10 : i >= 5 ? 5 : i >= 3 ? 3 : i >= 2 ? 2 : 1, e * i } }), o.control.scale = function (t) { return new o.Control.Scale(t) }, o.Control.Layers = o.Control.extend({ options: { collapsed: !0, position: "topright", autoZIndex: !0 }, initialize: function (t, e, i) { o.setOptions(this, i), this._layers = {}, this._lastZIndex = 0, this._handlingClick = !1; for (var n in t) this._addLayer(t[n], n); for (n in e) this._addLayer(e[n], n, !0) }, onAdd: function (t) { return this._initLayout(), this._update(), t.on("layeradd", this._onLayerChange, this).on("layerremove", this._onLayerChange, this), this._container }, onRemove: function (t) { t.off("layeradd", this._onLayerChange, this).off("layerremove", this._onLayerChange, this) }, addBaseLayer: function (t, e) { return this._addLayer(t, e), this._update(), this }, addOverlay: function (t, e) { return this._addLayer(t, e, !0), this._update(), this }, removeLayer: function (t) { var e = o.stamp(t); return delete this._layers[e], this._update(), this }, _initLayout: function () { var t = "leaflet-control-layers", e = this._container = o.DomUtil.create("div", t); e.setAttribute("aria-haspopup", !0), o.Browser.touch ? o.DomEvent.on(e, "click", o.DomEvent.stopPropagation) : o.DomEvent.disableClickPropagation(e).disableScrollPropagation(e); var i = this._form = o.DomUtil.create("form", t + "-list"); if (this.options.collapsed) { o.Browser.android || o.DomEvent.on(e, "mouseover", this._expand, this).on(e, "mouseout", this._collapse, this); var n = this._layersLink = o.DomUtil.create("a", t + "-toggle", e); n.href = "#", n.title = "Layers", o.Browser.touch ? o.DomEvent.on(n, "click", o.DomEvent.stop).on(n, "click", this._expand, this) : o.DomEvent.on(n, "focus", this._expand, this), o.DomEvent.on(i, "click", function () { setTimeout(o.bind(this._onInputClick, this), 0) }, this), this._map.on("click", this._collapse, this) } else this._expand(); this._baseLayersList = o.DomUtil.create("div", t + "-base", i), this._separator = o.DomUtil.create("div", t + "-separator", i), this._overlaysList = o.DomUtil.create("div", t + "-overlays", i), e.appendChild(i) }, _addLayer: function (t, e, i) { var n = o.stamp(t); this._layers[n] = { layer: t, name: e, overlay: i }, this.options.autoZIndex && t.setZIndex && (this._lastZIndex++, t.setZIndex(this._lastZIndex)) }, _update: function () { if (this._container) { this._baseLayersList.innerHTML = "", this._overlaysList.innerHTML = ""; var t, e, i = !1, n = !1; for (t in this._layers) e = this._layers[t], this._addItem(e), n = n || e.overlay, i = i || !e.overlay; this._separator.style.display = n && i ? "" : "none" } }, _onLayerChange: function (t) { var e = this._layers[o.stamp(t.layer)]; if (e) { this._handlingClick || this._update(); var i = e.overlay ? "layeradd" === t.type ? "overlayadd" : "overlayremove" : "layeradd" === t.type ? "baselayerchange" : null; i && this._map.fire(i, e) } }, _createRadioElement: function (t, i) { var n = '<input type="radio" class="leaflet-control-layers-selector" name="' + t + '"'; i && (n += ' checked="checked"'), n += "/>"; var o = e.createElement("div"); return o.innerHTML = n, o.firstChild }, _addItem: function (t) { var i, n = e.createElement("label"), s = this._map.hasLayer(t.layer); t.overlay ? (i = e.createElement("input"), i.type = "checkbox", i.className = "leaflet-control-layers-selector", i.defaultChecked = s) : i = this._createRadioElement("leaflet-base-layers", s), i.layerId = o.stamp(t.layer), o.DomEvent.on(i, "click", this._onInputClick, this); var a = e.createElement("span"); a.innerHTML = " " + t.name, n.appendChild(i), n.appendChild(a); var r = t.overlay ? this._overlaysList : this._baseLayersList; return r.appendChild(n), n }, _onInputClick: function () { var t, e, i, n = this._form.getElementsByTagName("input"), o = n.length; for (this._handlingClick = !0, t = 0; o > t; t++) e = n[t], i = this._layers[e.layerId], e.checked && !this._map.hasLayer(i.layer) ? this._map.addLayer(i.layer) : !e.checked && this._map.hasLayer(i.layer) && this._map.removeLayer(i.layer); this._handlingClick = !1, this._refocusOnMap() }, _expand: function () { o.DomUtil.addClass(this._container, "leaflet-control-layers-expanded") }, _collapse: function () { this._container.className = this._container.className.replace(" leaflet-control-layers-expanded", "") } }), o.control.layers = function (t, e, i) { return new o.Control.Layers(t, e, i) }, o.PosAnimation = o.Class.extend({ includes: o.Mixin.Events, run: function (t, e, i, n) { this.stop(), this._el = t, this._inProgress = !0, this._newPos = e, this.fire("start"), t.style[o.DomUtil.TRANSITION] = "all " + (i || .25) + "s cubic-bezier(0,0," + (n || .5) + ",1)", o.DomEvent.on(t, o.DomUtil.TRANSITION_END, this._onTransitionEnd, this), o.DomUtil.setPosition(t, e), o.Util.falseFn(t.offsetWidth), this._stepTimer = setInterval(o.bind(this._onStep, this), 50) }, stop: function () { this._inProgress && (o.DomUtil.setPosition(this._el, this._getPos()), this._onTransitionEnd(), o.Util.falseFn(this._el.offsetWidth)) }, _onStep: function () { var t = this._getPos(); return t ? (this._el._leaflet_pos = t, void this.fire("step")) : void this._onTransitionEnd() }, _transformRe: /([-+]?(?:\d*\.)?\d+)\D*, ([-+]?(?:\d*\.)?\d+)\D*\)/, _getPos: function () { var e, i, n, s = this._el, a = t.getComputedStyle(s); if (o.Browser.any3d) { if (n = a[o.DomUtil.TRANSFORM].match(this._transformRe), !n) return; e = parseFloat(n[1]), i = parseFloat(n[2]) } else e = parseFloat(a.left), i = parseFloat(a.top); return new o.Point(e, i, !0) }, _onTransitionEnd: function () { o.DomEvent.off(this._el, o.DomUtil.TRANSITION_END, this._onTransitionEnd, this), this._inProgress && (this._inProgress = !1, this._el.style[o.DomUtil.TRANSITION] = "", this._el._leaflet_pos = this._newPos, clearInterval(this._stepTimer), this.fire("step").fire("end")) } }), o.Map.include({ setView: function (t, e, n) { if (e = e === i ? this._zoom : this._limitZoom(e), t = this._limitCenter(o.latLng(t), e, this.options.maxBounds), n = n || {}, this._panAnim && this._panAnim.stop(), this._loaded && !n.reset && n !== !0) { n.animate !== i && (n.zoom = o.extend({ animate: n.animate }, n.zoom), n.pan = o.extend({ animate: n.animate }, n.pan)); var s = this._zoom !== e ? this._tryAnimatedZoom && this._tryAnimatedZoom(t, e, n.zoom) : this._tryAnimatedPan(t, n.pan); if (s) return clearTimeout(this._sizeTimer), this } return this._resetView(t, e), this }, panBy: function (t, e) { if (t = o.point(t).round(), e = e || {}, !t.x && !t.y) return this; if (this._panAnim || (this._panAnim = new o.PosAnimation, this._panAnim.on({ step: this._onPanTransitionStep, end: this._onPanTransitionEnd }, this)), e.noMoveStart || this.fire("movestart"), e.animate !== !1) { o.DomUtil.addClass(this._mapPane, "leaflet-pan-anim"); var i = this._getMapPanePos().subtract(t); this._panAnim.run(this._mapPane, i, e.duration || .25, e.easeLinearity) } else this._rawPanBy(t), this.fire("move").fire("moveend"); return this }, _onPanTransitionStep: function () { this.fire("move") }, _onPanTransitionEnd: function () { o.DomUtil.removeClass(this._mapPane, "leaflet-pan-anim"), this.fire("moveend") }, _tryAnimatedPan: function (t, e) { var i = this._getCenterOffset(t)._floor(); return (e && e.animate) === !0 || this.getSize().contains(i) ? (this.panBy(i, e), !0) : !1 } }), o.PosAnimation = o.DomUtil.TRANSITION ? o.PosAnimation : o.PosAnimation.extend({ run: function (t, e, i, n) { this.stop(), this._el = t, this._inProgress = !0, this._duration = i || .25, this._easeOutPower = 1 / Math.max(n || .5, .2), this._startPos = o.DomUtil.getPosition(t), this._offset = e.subtract(this._startPos), this._startTime = +new Date, this.fire("start"), this._animate() }, stop: function () { this._inProgress && (this._step(), this._complete()) }, _animate: function () { this._animId = o.Util.requestAnimFrame(this._animate, this), this._step() }, _step: function () { var t = +new Date - this._startTime, e = 1e3 * this._duration; e > t ? this._runFrame(this._easeOut(t / e)) : (this._runFrame(1), this._complete()) }, _runFrame: function (t) { var e = this._startPos.add(this._offset.multiplyBy(t)); o.DomUtil.setPosition(this._el, e), this.fire("step") }, _complete: function () { o.Util.cancelAnimFrame(this._animId), this._inProgress = !1, this.fire("end") }, _easeOut: function (t) { return 1 - Math.pow(1 - t, this._easeOutPower) } }), o.Map.mergeOptions({ zoomAnimation: !0, zoomAnimationThreshold: 4 }), o.DomUtil.TRANSITION && o.Map.addInitHook(function () { this._zoomAnimated = this.options.zoomAnimation && o.DomUtil.TRANSITION && o.Browser.any3d && !o.Browser.android23 && !o.Browser.mobileOpera, this._zoomAnimated && o.DomEvent.on(this._mapPane, o.DomUtil.TRANSITION_END, this._catchTransitionEnd, this) }), o.Map.include(o.DomUtil.TRANSITION ? { _catchTransitionEnd: function (t) { this._animatingZoom && t.propertyName.indexOf("transform") >= 0 && this._onZoomTransitionEnd() }, _nothingToAnimate: function () { return !this._container.getElementsByClassName("leaflet-zoom-animated").length }, _tryAnimatedZoom: function (t, e, i) { if (this._animatingZoom) return !0; if (i = i || {}, !this._zoomAnimated || i.animate === !1 || this._nothingToAnimate() || Math.abs(e - this._zoom) > this.options.zoomAnimationThreshold) return !1; var n = this.getZoomScale(e), o = this._getCenterOffset(t)._divideBy(1 - 1 / n), s = this._getCenterLayerPoint()._add(o); return i.animate === !0 || this.getSize().contains(o) ? (this.fire("movestart").fire("zoomstart"), this._animateZoom(t, e, s, n, null, !0), !0) : !1 }, _animateZoom: function (t, e, i, n, s, a, r) { r || (this._animatingZoom = !0), o.DomUtil.addClass(this._mapPane, "leaflet-zoom-anim"), this._animateToCenter = t, this._animateToZoom = e, o.Draggable && (o.Draggable._disabled = !0), o.Util.requestAnimFrame(function () { this.fire("zoomanim", { center: t, zoom: e, origin: i, scale: n, delta: s, backwards: a }), setTimeout(o.bind(this._onZoomTransitionEnd, this), 250) }, this) }, _onZoomTransitionEnd: function () { this._animatingZoom && (this._animatingZoom = !1, o.DomUtil.removeClass(this._mapPane, "leaflet-zoom-anim"), this._resetView(this._animateToCenter, this._animateToZoom, !0, !0), o.Draggable && (o.Draggable._disabled = !1)) } } : {}), o.TileLayer.include({ _animateZoom: function (t) { this._animating || (this._animating = !0, this._prepareBgBuffer()); var e = this._bgBuffer, i = o.DomUtil.TRANSFORM, n = t.delta ? o.DomUtil.getTranslateString(t.delta) : e.style[i], s = o.DomUtil.getScaleString(t.scale, t.origin); e.style[i] = t.backwards ? s + " " + n : n + " " + s }, _endZoomAnim: function () { var t = this._tileContainer, e = this._bgBuffer; t.style.visibility = "", t.parentNode.appendChild(t), o.Util.falseFn(e.offsetWidth); var i = this._map.getZoom(); (i > this.options.maxZoom || i < this.options.minZoom) && this._clearBgBuffer(), this._animating = !1 }, _clearBgBuffer: function () { var t = this._map; !t || t._animatingZoom || t.touchZoom._zooming || (this._bgBuffer.innerHTML = "", this._bgBuffer.style[o.DomUtil.TRANSFORM] = "") }, _prepareBgBuffer: function () { var t = this._tileContainer, e = this._bgBuffer, i = this._getLoadedTilesPercentage(e), n = this._getLoadedTilesPercentage(t); return e && i > .5 && .5 > n ? (t.style.visibility = "hidden", void this._stopLoadingImages(t)) : (e.style.visibility = "hidden", e.style[o.DomUtil.TRANSFORM] = "", this._tileContainer = e, e = this._bgBuffer = t, this._stopLoadingImages(e), void clearTimeout(this._clearBgBufferTimer)) }, _getLoadedTilesPercentage: function (t) { var e, i, n = t.getElementsByTagName("img"), o = 0; for (e = 0, i = n.length; i > e; e++) n[e].complete && o++; return o / i }, _stopLoadingImages: function (t) { var e, i, n, s = Array.prototype.slice.call(t.getElementsByTagName("img")); for (e = 0, i = s.length; i > e; e++) n = s[e], n.complete || (n.onload = o.Util.falseFn, n.onerror = o.Util.falseFn, n.src = o.Util.emptyImageUrl, n.parentNode.removeChild(n)) } }), o.Map.include({ _defaultLocateOptions: { watch: !1, setView: !1, maxZoom: 1 / 0, timeout: 1e4, maximumAge: 0, enableHighAccuracy: !1 }, locate: function (t) { if (t = this._locateOptions = o.extend(this._defaultLocateOptions, t), !navigator.geolocation) return this._handleGeolocationError({ code: 0, message: "Geolocation not supported." }), this; var e = o.bind(this._handleGeolocationResponse, this), i = o.bind(this._handleGeolocationError, this); return t.watch ? this._locationWatchId = navigator.geolocation.watchPosition(e, i, t) : navigator.geolocation.getCurrentPosition(e, i, t), this }, stopLocate: function () { return navigator.geolocation && navigator.geolocation.clearWatch(this._locationWatchId), this._locateOptions && (this._locateOptions.setView = !1), this }, _handleGeolocationError: function (t) { var e = t.code, i = t.message || (1 === e ? "permission denied" : 2 === e ? "position unavailable" : "timeout"); this._locateOptions.setView && !this._loaded && this.fitWorld(), this.fire("locationerror", { code: e, message: "Geolocation error: " + i + "." }) }, _handleGeolocationResponse: function (t) { var e = t.coords.latitude, i = t.coords.longitude, n = new o.LatLng(e, i), s = 180 * t.coords.accuracy / 40075017, a = s / Math.cos(o.LatLng.DEG_TO_RAD * e), r = o.latLngBounds([e - s, i - a], [e + s, i + a]), h = this._locateOptions; if (h.setView) { var l = Math.min(this.getBoundsZoom(r), h.maxZoom); this.setView(n, l) } var u = { latlng: n, bounds: r, timestamp: t.timestamp }; for (var c in t.coords) "number" == typeof t.coords[c] && (u[c] = t.coords[c]); this.fire("locationfound", u) } })
}(window, document);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment