$(document).ready(function() { var self = this; fetchLayers(); var map = L.map( 'map', { zoom: 12, layers: [self.tileLayer], }); function addHospitalLayer(){ L.control.layers(null, { "Hospitals" : self.hospitalLayer }).addTo(map); // display layer $('.leaflet-control-layers-selector').first().trigger('click') } $('body').bind('hospitalsfetched', addHospitalLayer); map.on('locationfound', onLocationFound); map.on('locationerror', onLocationError); map.on('moveend', function(e) { var zoom = map.getZoom(); if (zoom < 10) { return; } if (!self.hospitalLayer) return; var bounds = map.getBounds(); var sw = bounds.getSouthWest(); var ne = bounds.getNorthEast(); bbox = [sw.lat, sw.lng, ne.lat, ne.lng].join(','); var url = "http://overpass-api.de/api/interpreter?data=[out:json];node[amenity=hospital](" + bbox + ");out;"; converter = new op2geojson(); converter.fetch(url, function(data) { layer = L.geoJson(data, { onEachFeature: function(feature, layer) { layer.bindPopup(feature.properties.name); } }); self.hospitalLayer.addData(data); }); }) map.locate({setView: true, maxZoom: 12}); function geojsonLayer() { url = "http://overpass-api.de/api/interpreter?data=[out:json];node[amenity=hospital](52.34,13.3,52.52,13.6);out;"; converter = new op2geojson(); converter.fetch(url, function(data) { layer = L.geoJson(data, { onEachFeature: function(feature, layer) { layer.bindPopup(feature.properties.name); } }); self.hospitalLayer = layer; $('body').trigger('hospitalsfetched'); }); } function fetchLayers() { geojsonLayer(); self.tileLayer = L.tileLayer('http://{s}.www.toolserver.org/tiles/osm-no-labels/{z}/{x}/{y}.png', { maxZoom: 18, attribution: 'Map data © OpenStreetMap contributors' }); } function onLocationFound(e) { self.currentLocation = e.latlng; var radius = e.accuracy / 2; L.marker(e.latlng).addTo(map) .bindPopup("You are within " + radius + " meters from this point").openPopup(); } function onLocationError(e) { alert(e.message); } function renderHospitalIcon() { var hospitalIcon = L.icon({ iconUrl: 'resources/img/hospital.png' }); self.hospitalLayer.addTo(map); // if (self.currentLocation) { // L.marker([self.currentLocation.lat, self.currentLocation.lng], {icon: hospitalIcon}) // .addTo(self.hospitalLayer) // .bindPopup('Hospital 1'); // } } });