summaryrefslogtreecommitdiff
path: root/htdocs/mapscript.js
diff options
context:
space:
mode:
Diffstat (limited to 'htdocs/mapscript.js')
-rw-r--r--htdocs/mapscript.js28
1 files changed, 22 insertions, 6 deletions
diff --git a/htdocs/mapscript.js b/htdocs/mapscript.js
index 4bdec93..89d32a9 100644
--- a/htdocs/mapscript.js
+++ b/htdocs/mapscript.js
@@ -183,12 +183,14 @@ function get_current_location_str() {
function jump_to(latlng, zoom = -1) {
if (zoom == -1)
zoom = mymap.getZoom();
- document.location.hash = "#" + Math.round(latlng.lat) + "," + Math.round(latlng.lng) + "," + zoom;
+ if (!editor_mode)
+ document.location.hash = "#" + Math.round(latlng.lat) + "," + Math.round(latlng.lng) + "," + zoom;
+ else
+ mymap.setView(latlng, zoom);
}
function jump_to_marker(e) {
- if (!editor_mode)
- jump_to(e.target.getLatLng());
+ jump_to(e.target.getLatLng());
}
function prompt_location() {
@@ -244,11 +246,25 @@ function onMapClick(e) {
mymap.on('click', onMapClick);
+var is_user_drag = 0;
+
function update_hash_from_position(e) {
- document.location.hash = "#" + get_current_location_str();
+ if (is_user_drag)
+ is_user_drag = 0;
+ else
+ return;
+ if (!editor_mode)
+ document.location.hash = "#" + get_current_location_str();
}
-mymap.on('zoomend', update_hash_from_position);
-mymap.on('dragend', update_hash_from_position);
+
+function dragstart(e) {
+ is_user_drag = 1;
+}
+
+mymap.on('zoomend', function () {is_user_drag = 1; update_hash_from_position();});
+mymap.on('moveend', update_hash_from_position);
+mymap.on('dragstart', function () { is_user_drag = 1;});
+mymap.on('keydown', function (e) { if (e.originalEvent.code.match(/Arrow.*/)) is_user_drag = 1;});
function onHashChange(e) {
if (document.location.hash == "#" + get_current_location_str())