]> git.openstreetmap.org Git - rails.git/blobdiff - app/assets/javascripts/user.js
Serve embedded maps through the assets pipeline
[rails.git] / app / assets / javascripts / user.js
index 97827fb8d3474b230c2fa7c6828cc4c4211ef913..25456d04ebb080b46564fb359b5801fac551c163 100644 (file)
@@ -1,45 +1,40 @@
-function init(){
-  var params = $("#map").data();
-  var map = createMap("map");
-
-  setMapCenter(new OpenLayers.LonLat(params.lon, params.lat), params.zoom);
+$(document).ready(function () {
+  var map = createMap("map", {
+    zoomControl: true,
+    panZoomControl: false
+  });
+
+  if (OSM.home) {
+    map.setView([OSM.home.lat, OSM.home.lon], 12);
+  } else {
+    map.setView([0, 0], 0);
+  }
 
   if ($("#map").hasClass("set_location")) {
-    var marker;
+    var marker = L.marker([0, 0], {icon: getUserIcon()});
 
-    if (params.marker) {
-      marker = addMarkerToMap(new OpenLayers.LonLat(params.lon, params.lat));
+    if (OSM.home) {
+      marker.setLatLng([OSM.home.lat, OSM.home.lon]);
+      marker.addTo(map);
     }
 
-    map.events.register("click", map, function (e) {
-      closeMapPopup();
-
-      if (document.getElementById('updatehome').checked) {
-        var lonlat = getEventPosition(e);
+    map.on("click", function (e) {
+      if ($('#updatehome').is(':checked')) {
+        $('#homerow').removeClass();
+        $('#home_lat').val(e.latlng.lat);
+        $('#home_lon').val(e.latlng.lng);
 
-        document.getElementById('homerow').className = '';
-        document.getElementById('home_lat').value = lonlat.lat;
-        document.getElementById('home_lon').value = lonlat.lon;
-
-        if (marker) {
-          removeMarkerFromMap(marker);
-        }
-
-        marker = addMarkerToMap(lonlat);
+        marker.setLatLng(e.latlng);
+        marker.addTo(map);
       }
     });
   } else {
-    addMarkerToMap(new OpenLayers.LonLat(params.lon, params.lat), null, params.marker.description);
-
     $("[data-user]").each(function () {
       var user = $(this).data('user');
       if (user.lon && user.lat) {
-        var icon = OpenLayers.Marker.defaultIcon();
-        icon.url = OpenLayers.Util.getImageLocation(user.icon);
-        addMarkerToMap(new OpenLayers.LonLat(user.lon, user.lat), icon, user.description);
+        L.marker([user.lat, user.lon], {icon: getUserIcon(user.icon)}).addTo(map)
+          .bindPopup(user.description);
       }
     });
   }
-}
-
-window.onload = init;
+});