]> git.openstreetmap.org Git - rails.git/blobdiff - public/javascripts/site.js
Copying across fix for #1547 from trunk
[rails.git] / public / javascripts / site.js
index 95ef1f53631f34627d04c8762b0ca59e1ef3bcf9..95c0b938e3938fe89675fbabd2d55302ccef78b2 100644 (file)
@@ -1,13 +1,43 @@
 function updatelinks(lon,lat,zoom,layers) {
+  var decimals = Math.pow(10, Math.floor(zoom/3));
   var node;
 
+  lat = Math.round(lat * decimals) / decimals;
+  lon = Math.round(lon * decimals) / decimals;
+
+  node = document.getElementById("permalinkanchor");
+  if (node) {
+    var args = getArgs(node.href);
+    args["lat"] = lat;
+    args["lon"] = lon;
+    args["zoom"] = zoom;
+    if (layers) {
+      args["layers"] = layers;
+    }
+    node.href = setArgs(node.href, args);
+  }
+
   node = document.getElementById("viewanchor");
   if (node) {
     var args = getArgs(node.href);
     args["lat"] = lat;
     args["lon"] = lon;
     args["zoom"] = zoom;
-    args["layers"] = layers;
+    if (layers) {
+      args["layers"] = layers;
+    }
+    node.href = setArgs(node.href, args);
+  }
+
+  node = document.getElementById("exportanchor");
+  if (node) {
+    var args = getArgs(node.href);
+    args["lat"] = lat;
+    args["lon"] = lon;
+    args["zoom"] = zoom;
+    if (layers) {
+      args["layers"] = layers;
+    }
     node.href = setArgs(node.href, args);
   }
 
@@ -18,7 +48,7 @@ function updatelinks(lon,lat,zoom,layers) {
       args.lat = lat;
       args.lon = lon;
       args.zoom = zoom;
-      node.href = setArgs("/edit.html", args);
+      node.href = setArgs("/edit", args);
       node.style.fontStyle = 'normal';
     } else {
       node.href = 'javascript:alert("zoom in to edit map");';