args.lat = lat;
args.lon = lon;
args.zoom = zoom;
+ if (objtype && objid) {
+ args[objtype] = objid;
+ }
node.href = setArgs("/edit", args);
node.style.fontStyle = 'normal';
} else {
node.style.fontStyle = 'italic';
}
}
-
+
node = document.getElementById("historyanchor");
if (node) {
if (zoom >= 11) {
typeof minlat == "number" &&
typeof maxlon == "number" &&
typeof maxlat == "number") {
-
+
minlon = Math.round(minlon * decimals) / decimals;
minlat = Math.round(minlat * decimals) / decimals;
maxlon = Math.round(maxlon * decimals) / decimals;
maxlat = Math.round(maxlat * decimals) / decimals;
args.bbox = minlon + "," + minlat + "," + maxlon + "," + maxlat;
}
-
+
node.href = setArgs("/history", args);
node.style.fontStyle = 'normal';
} else {
args[objtype] = objid;
}
- // little hack. may the gods of hardcoding please forgive me, or
- // show me the Right way to do it.
- if (layers && (layers != "B000FTF")) {
+ // This is a hack to omit the default mapnik layer (B000FTF) from
+ // the shortlink. B000FTFT is then the "Object" layer which we get
+ // on /?{node,way,relation}=id
+ if (layers && (layers != "B000FTF") && (layers != "B000FTFT")) {
args["layers"] = layers;
+ }
+ else {
+ delete args["layers"];
+ }
+
+ // Here we're assuming that all parameters but ?layers= and
+ // ?{node,way,relation}= can be safely omitted from the shortlink
+ // which encodes lat/lon/zoom. If new URL parameters are added to
+ // the main slippy map this needs to be changed.
+ if (args["layers"] || args[objtype]) {
node.href = setArgs(prefix + "/go/" + code, args);
} else {
node.href = prefix + "/go/" + code;
if (window.location.hostname.match(/^www\.openstreetmap\.org/i)) {
return "http://osm.org";
} else {
- return "";
+ return "";
}
}
for (var key in keys) {
var re_key = '\\[\\[' + key + '\\]\\]';
var re = new RegExp(re_key, "g");
-
+
string = string.replace(re, keys[key]);
}
-
+
return string;
-}
+}
function makeShortCode(lat, lon, zoom) {
char_array = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_@";
str += char_array.charAt(digit);
}
for (var i = 0; i < ((zoom + 8) % 3); ++i) {
- str += "=";
+ str += "-";
}
return str;
}