X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/e813a31d7a7d6f2fe7944543dd2a65f899c36dc5..6ad4260d2d9a40a9e6d1e1d5a7140563bc332792:/app/assets/javascripts/index/contextmenu.js diff --git a/app/assets/javascripts/index/contextmenu.js b/app/assets/javascripts/index/contextmenu.js index 1ee703e60..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?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,7 +64,15 @@ OSM.initializeContextMenu = function (map) { else map.contextmenu.enable(); }); - var updateMenu = function updateMenu () { + 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); };