X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/5bd59e19368d8761a7dbaa5db0e8833174c11f36..8f7f02b025f59db466fdb22ea3686cb6c5adc400:/app/assets/javascripts/index/contextmenu.js
diff --git a/app/assets/javascripts/index/contextmenu.js b/app/assets/javascripts/index/contextmenu.js
index e3e30ce6b..51ec87723 100644
--- a/app/assets/javascripts/index/contextmenu.js
+++ b/app/assets/javascripts/index/contextmenu.js
@@ -1,15 +1,14 @@
+//= require qs/dist/qs
+
OSM.initializeContextMenu = function (map) {
map.contextmenu.addItem({
text: I18n.t("javascripts.context.directions_from"),
callback: function directionsFromHere(e) {
- var precision = OSM.zoomPrecision(map.getZoom()),
- latlng = e.latlng.wrap(),
- lat = latlng.lat.toFixed(precision),
- lng = latlng.lng.toFixed(precision);
+ const latlng = OSM.cropLocation(e.latlng, map.getZoom());
- OSM.router.route("/directions?" + querystring.stringify({
- from: lat + "," + lng,
- to: $("#route_to").val()
+ OSM.router.route("/directions?" + Qs.stringify({
+ from: latlng.join(","),
+ to: getDirectionsEndpointCoordinatesFromInput($("#route_to"))
}));
}
});
@@ -17,14 +16,11 @@ OSM.initializeContextMenu = function (map) {
map.contextmenu.addItem({
text: I18n.t("javascripts.context.directions_to"),
callback: function directionsToHere(e) {
- var precision = OSM.zoomPrecision(map.getZoom()),
- latlng = e.latlng.wrap(),
- lat = latlng.lat.toFixed(precision),
- lng = latlng.lng.toFixed(precision);
+ const latlng = OSM.cropLocation(e.latlng, map.getZoom());
- OSM.router.route("/directions?" + querystring.stringify({
- from: $("#route_from").val(),
- to: lat + "," + lng
+ OSM.router.route("/directions?" + Qs.stringify({
+ from: getDirectionsEndpointCoordinatesFromInput($("#route_from")),
+ to: latlng.join(",")
}));
}
});
@@ -32,36 +28,27 @@ OSM.initializeContextMenu = function (map) {
map.contextmenu.addItem({
text: I18n.t("javascripts.context.add_note"),
callback: function addNoteHere(e) {
- var precision = OSM.zoomPrecision(map.getZoom()),
- latlng = e.latlng.wrap(),
- lat = latlng.lat.toFixed(precision),
- lng = latlng.lng.toFixed(precision);
+ const [lat, lon] = OSM.cropLocation(e.latlng, map.getZoom());
- OSM.router.route("/note/new?lat=" + lat + "&lon=" + lng);
+ OSM.router.route("/note/new?" + Qs.stringify({ lat, lon }));
}
});
map.contextmenu.addItem({
text: I18n.t("javascripts.context.show_address"),
callback: function describeLocation(e) {
- var precision = OSM.zoomPrecision(map.getZoom()),
- latlng = e.latlng.wrap(),
- lat = latlng.lat.toFixed(precision),
- lng = latlng.lng.toFixed(precision);
+ const [lat, lon] = OSM.cropLocation(e.latlng, map.getZoom()).map(encodeURIComponent);
- OSM.router.route("/search?whereami=1&query=" + encodeURIComponent(lat + "," + lng));
+ OSM.router.route("/search?" + Qs.stringify({ lat, lon }));
}
});
map.contextmenu.addItem({
text: I18n.t("javascripts.context.query_features"),
callback: function queryFeatures(e) {
- var precision = OSM.zoomPrecision(map.getZoom()),
- latlng = e.latlng.wrap(),
- lat = latlng.lat.toFixed(precision),
- lng = latlng.lng.toFixed(precision);
+ const [lat, lon] = OSM.cropLocation(e.latlng, map.getZoom());
- OSM.router.route("/query?lat=" + lat + "&lon=" + lng);
+ OSM.router.route("/query?" + Qs.stringify({ lat, lon }));
}
});
@@ -77,6 +64,14 @@ OSM.initializeContextMenu = function (map) {
else map.contextmenu.enable();
});
+ function getDirectionsEndpointCoordinatesFromInput(input) {
+ if (input.attr("data-lat") && input.attr("data-lon")) {
+ return input.attr("data-lat") + "," + input.attr("data-lon");
+ } else {
+ return $(input).val();
+ }
+ }
+
var updateMenu = function updateMenu() {
map.contextmenu.setDisabled(2, map.getZoom() < 12);
map.contextmenu.setDisabled(4, map.getZoom() < 14);