OSM.initializeContextMenu = function (map) {
map.contextmenu.addItem({
- text: "Directions from here",
+ text: I18n.t("javascripts.context.directions_from"),
callback: function directionsFromHere(e) {
var precision = OSM.zoomPrecision(map.getZoom()),
latlng = e.latlng.wrap(),
});
map.contextmenu.addItem({
- text: "Directions to here",
+ text: I18n.t("javascripts.context.directions_to"),
callback: function directionsToHere(e) {
var precision = OSM.zoomPrecision(map.getZoom()),
latlng = e.latlng.wrap(),
});
map.contextmenu.addItem({
- text: "Add a note here",
+ text: I18n.t("javascripts.context.add_note"),
callback: function addNoteHere(e) {
- // I'd like this, instead of panning, to pass a query parameter about where to place the marker
- map.panTo(e.latlng.wrap(), {animate: false});
- OSM.router.route("/note/new");
+ var precision = OSM.zoomPrecision(map.getZoom()),
+ latlng = e.latlng.wrap(),
+ lat = latlng.lat.toFixed(precision),
+ lng = latlng.lng.toFixed(precision);
+
+ OSM.router.route("/note/new?lat=" + lat + "&lon=" + lng);
}
});
map.contextmenu.addItem({
- text: "Show address",
+ text: I18n.t("javascripts.context.show_address"),
callback: function describeLocation(e) {
var precision = OSM.zoomPrecision(map.getZoom()),
latlng = e.latlng.wrap(),
});
map.contextmenu.addItem({
- text: "Query features",
+ text: I18n.t("javascripts.context.query_features"),
callback: function queryFeatures(e) {
var precision = OSM.zoomPrecision(map.getZoom()),
latlng = e.latlng.wrap(),
});
map.contextmenu.addItem({
- text: "Centre map here",
+ text: I18n.t("javascripts.context.centre_map"),
callback: function centreMap(e) {
map.panTo(e.latlng);
}
});
map.on("mousedown", function (e) {
- if (e.shiftKey) map.contextmenu.disable();
+ if (e.originalEvent.shiftKey) map.contextmenu.disable();
}).on("mouseup", function () {
map.contextmenu.enable();
});