+ OSM.router.route("/directions?" + Qs.stringify({
+ from: getDirectionsEndpointCoordinatesFromInput($("#route_from")),
+ to: latlng.join(",")
+ }));
+ }
+ });
+
+ map.contextmenu.addItem({
+ text: I18n.t("javascripts.context.add_note"),
+ callback: function addNoteHere(e) {
+ const [lat, lon] = OSM.cropLocation(e.latlng, map.getZoom());
+
+ OSM.router.route("/note/new?" + Qs.stringify({ lat, lon }));
+ }
+ });
+
+ map.contextmenu.addItem({
+ text: I18n.t("javascripts.context.show_address"),
+ callback: function describeLocation(e) {
+ const [lat, lon] = OSM.cropLocation(e.latlng, map.getZoom()).map(encodeURIComponent);
+
+ OSM.router.route("/search?" + Qs.stringify({ lat, lon }));
+ }
+ });
+
+ map.contextmenu.addItem({
+ text: I18n.t("javascripts.context.query_features"),
+ callback: function queryFeatures(e) {
+ const [lat, lon] = OSM.cropLocation(e.latlng, map.getZoom());
+
+ OSM.router.route("/query?" + Qs.stringify({ lat, lon }));
+ }
+ });
+
+ map.contextmenu.addItem({
+ text: I18n.t("javascripts.context.centre_map"),
+ callback: function centreMap(e) {
+ map.panTo(e.latlng);
+ }
+ });
+
+ map.on("mousedown", function (e) {
+ if (e.originalEvent.shiftKey) map.contextmenu.disable();
+ 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();
+ }
+ }