X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/babefbba6c9c6d7d2ed944bda7aa3634d0b917e6..8aa6d575fff4fc850464f704282811208ae6f5e1:/app/assets/javascripts/map.js.erb?ds=inline diff --git a/app/assets/javascripts/map.js.erb b/app/assets/javascripts/map.js.erb index b8e53d5e0..6701cf740 100644 --- a/app/assets/javascripts/map.js.erb +++ b/app/assets/javascripts/map.js.erb @@ -42,6 +42,8 @@ L.Bounds.include({ } }); +L.Icon.Default.imagePath = <%= "#{asset_prefix}/images".to_json %>; + var map; var layers = [ @@ -76,15 +78,22 @@ var layers = [ ]; function createMap(divName, options) { - map = L.map(divName, options); + options = $.extend({zoomControl: false, panZoomControl: true, layerControl: true}, options); + + map = L.map(divName, $.extend({}, options, {panControl: false, zoomsliderControl: false, maxZoom: 18})); if (map.attributionControl) { map.attributionControl.setPrefix(''); // For tmcw } + if (options.panZoomControl) { + new L.Control.Pan().addTo(map); + new L.Control.Zoomslider({stepHeight: 7}).addTo(map); + } + var layersControl = L.control.layers(); - if (!options || options.layerControl !== false) { + if (options.layerControl) { layersControl.addTo(map); } @@ -103,28 +112,17 @@ function createMap(divName, options) { return map; } -function getArrowIcon() { +function getUserIcon(url) { return L.icon({ - iconUrl: <%= asset_path('arrow.png').to_json %>, - iconSize: [25, 22], - iconAnchor: [22, 20] + iconUrl: url || <%= asset_path('marker-red.png').to_json %>, + iconSize: [25, 41], + iconAnchor: [12, 41], + popupAnchor: [1, -34], + shadowUrl: <%= asset_path('images/marker-shadow.png').to_json %>, + shadowSize: [41, 41] }); } -function addMarkerToMap(position, icon, description) { - var marker = L.marker(position, icon ? {icon: icon} : null).addTo(map); - - if (description) { - marker.bindPopup(description); - } - - return marker; -} - -function removeMarkerFromMap(marker) { - map.removeLayer(marker); -} - function addObjectToMap(object, zoom, callback) { $.ajax({ url: OSM.apiUrl(object),