X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/cd61c8e0653b8edd5229e73f19aa89b54e5df74c..e5b5faad7228253147bc489402ef7640b071eaaf:/app/assets/javascripts/index.js diff --git a/app/assets/javascripts/index.js b/app/assets/javascripts/index.js index 8964cef1d..496ab29b9 100644 --- a/app/assets/javascripts/index.js +++ b/app/assets/javascripts/index.js @@ -76,31 +76,38 @@ $(document).ready(function () { var params = OSM.mapParams(); - // TODO consider using a separate js file for the context menu additions + // a separate js file would be nice for the context menu additions; however not clear if context menu can be added outside of context of map obj constructor var context_describe = function(e){ - var precision = OSM.zoomPrecision(map.getZoom()); - OSM.router.route("/search?query=" + encodeURIComponent( - e.latlng.lat.toFixed(precision) + "," + e.latlng.lng.toFixed(precision) - )); + var precision = OSM.zoomPrecision(map.getZoom()), + latlng = e.latlng.wrap(), + lat = latlng.lat.toFixed(precision), + lng = latlng.lng.toFixed(precision); + OSM.router.route("/search?query=" + encodeURIComponent(lat + "," + lng)); }; var context_directionsfrom = function(e){ - var precision = OSM.zoomPrecision(map.getZoom()); + var precision = OSM.zoomPrecision(map.getZoom()), + latlng = e.latlng.wrap(), + lat = latlng.lat.toFixed(precision), + lng = latlng.lng.toFixed(precision); OSM.router.route("/directions?" + querystring.stringify({ - route: e.latlng.lat.toFixed(precision) + ',' + e.latlng.lng.toFixed(precision) + ';' + $('#route_to').val() + route: lat + ',' + lng + ';' + $('#route_to').val() })); } var context_directionsto = function(e){ - var precision = OSM.zoomPrecision(map.getZoom()); + var precision = OSM.zoomPrecision(map.getZoom()), + latlng = e.latlng.wrap(), + lat = latlng.lat.toFixed(precision), + lng = latlng.lng.toFixed(precision); OSM.router.route("/directions?" + querystring.stringify({ - route: $('#route_from').val() + ';' + e.latlng.lat.toFixed(precision) + ',' + e.latlng.lng.toFixed(precision) + route: $('#route_from').val() + ';' + lat + ',' + lng })); } var context_addnote = function(e){ - // TODO this currently doesn't work correctly - I think the "route" needs to be chained to ensure it comes once the pan has finished. - map.panTo(e.latlng, {animate: false}); + // 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'); } @@ -108,6 +115,14 @@ $(document).ready(function () { map.panTo(e.latlng); } + var context_queryhere = function(e) { + var precision = OSM.zoomPrecision(map.getZoom()), + latlng = e.latlng.wrap(), + lat = latlng.lat.toFixed(precision), + lng = latlng.lng.toFixed(precision); + OSM.router.route("/query?lat=" + lat + "&lon=" + lng); + } + // TODO internationalisation of the context menu strings var map = new L.OSM.Map("map", { zoomControl: false, @@ -126,12 +141,26 @@ $(document).ready(function () { }, { text: 'Show address', callback: context_describe + }, { + text: 'Query features', + callback: context_queryhere }, { text: 'Centre map here', callback: context_centrehere }] }); + $(document).on('mousedown', function(e){ + if(e.shiftKey){ + map.contextmenu.disable(); // on firefox, shift disables our contextmenu. we explicitly do this for all browsers. + }else{ + map.contextmenu.enable(); + // we also decide whether to disable some options that only like high zoom + map.contextmenu.setDisabled(3, map.getZoom() < 12); + map.contextmenu.setDisabled(5, map.getZoom() < 14); + } + }); + map.attributionControl.setPrefix(''); map.updateLayers(params.layers);