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');
}
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,
}, {
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);