Improve zoom handling, cleanup

This commit is contained in:
amercader 2022-12-16 15:46:56 +01:00
parent 998f3bcb38
commit c41e361499
2 changed files with 9 additions and 73 deletions

View File

@ -76,6 +76,7 @@ this.ckan.module('spatial-query', function ($, _) {
this.modal.on('shown.bs.modal', function () { this.modal.on('shown.bs.modal', function () {
if (module.drawMap) { if (module.drawMap) {
module._setPreviousBBBox(map, zoom=false); module._setPreviousBBBox(map, zoom=false);
map.fitBounds(module.mainMap.getBounds());
$('a.leaflet-draw-draw-rectangle>span', element).trigger('click'); $('a.leaflet-draw-draw-rectangle>span', element).trigger('click');
return return
@ -115,11 +116,6 @@ this.ckan.module('spatial-query', function ($, _) {
element.find('.btn-primary').removeClass('disabled').addClass('btn-primary'); element.find('.btn-primary').removeClass('disabled').addClass('btn-primary');
}); });
// Record the current map view so we can replicate it after submitting
map.on('moveend', function(e) {
$('#ext_prev_extent').val(map.getBounds().toBBoxString());
});
$('a.leaflet-draw-draw-rectangle>span', element).trigger('click'); $('a.leaflet-draw-draw-rectangle>span', element).trigger('click');
element.find('.btn-primary').focus() element.find('.btn-primary').focus()
}) })
@ -185,38 +181,23 @@ this.ckan.module('spatial-query', function ($, _) {
this.extentLayer = this._drawExtentFromCoords(previous_bbox.split(',')) this.extentLayer = this._drawExtentFromCoords(previous_bbox.split(','))
map.addLayer(this.extentLayer); map.addLayer(this.extentLayer);
if (zoom) { if (zoom) {
map.fitBounds(this.extentLayer.getBounds()); map.fitBounds(this.extentLayer.getBounds(), {"animate": false, "padding": [20, 20]});
} }
}
},
// Is there an existing extent from a previous search?
_setPreviousExtent: function(map) {
previous_extent = this._getParameterByName('ext_prev_extent');
if (previous_extent) {
coords = previous_extent.split(',');
map.fitBounds([[coords[1], coords[0]], [coords[3], coords[2]]], {"animate": false});
} else { } else {
if (!previous_bbox){ map.fitBounds(this.options.default_extent, {"animate": false});
map.fitBounds(this.options.default_extent, {"animate": false});
}
} }
}, },
_onReady: function() { _onReady: function() {
var module = this; let module = this;
var map; let map;
var extentLayer; let form = $(".search-form");
var form = $("#dataset-search");
// CKAN 2.1
if (!form.length) {
form = $(".search-form");
}
var buttons; var buttons;
// Add necessary fields to the search form if not already created // Add necessary fields to the search form if not already created
$(['ext_bbox', 'ext_prev_extent']).each(function(index, item){ $(['ext_bbox']).each(function(index, item){
if ($("#" + item).length === 0) { if ($("#" + item).length === 0) {
$('<input type="hidden" />').attr({'id': item, 'name': item}).appendTo(form); $('<input type="hidden" />').attr({'id': item, 'name': item}).appendTo(form);
} }
@ -225,9 +206,6 @@ this.ckan.module('spatial-query', function ($, _) {
// OK map time // OK map time
this.mainMap = map = this._createMap('dataset-map-container'); this.mainMap = map = this._createMap('dataset-map-container');
// OK add the expander
var module = this;
var expandButton = L.Control.extend({ var expandButton = L.Control.extend({
position: 'topright', position: 'topright',
onAdd: function(map) { onAdd: function(map) {
@ -248,25 +226,7 @@ this.ckan.module('spatial-query', function ($, _) {
}); });
map.addControl(new expandButton()); map.addControl(new expandButton());
// When user finishes drawing the box, record it and add it to the map
map.on('draw:created', function (e) {
if (extentLayer) {
map.removeLayer(extentLayer);
}
extentLayer = e.layer;
$('#ext_bbox').val(extentLayer.getBounds().toBBoxString());
map.addLayer(extentLayer);
$('.apply', buttons).removeClass('disabled').addClass('btn-primary');
});
// Record the current map view so we can replicate it after submitting
map.on('moveend', function(e) {
$('#ext_prev_extent').val(map.getBounds().toBBoxString());
});
module._setPreviousBBBox(map); module._setPreviousBBBox(map);
module._setPreviousExtent(map);
} }
} }

View File

@ -12,35 +12,11 @@ e.g.
#} #}
<!--
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Modal title</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
HOLA
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Save changes</button>
</div>
</div>
</div>
</div>
Modal -->
<section id="dataset-map" class="module module-narrow module-shallow"> <section id="dataset-map" class="module module-narrow module-shallow">
<h2 class="module-heading"> <h2 class="module-heading">
<i class="icon-medium icon-globe"></i> <i class="icon-medium icon-globe"></i>
{{ _('Filter by location') }} {{ _('Filter by location') }}
<a href="{{ h.remove_url_param(['ext_bbox','ext_prev_extent', 'ext_location']) }}" class="action">{{ _('Clear') }}</a> <a href="{{ h.remove_url_param(['ext_bbox']) }}" class="action">{{ _('Clear') }}</a>
</h2> </h2>
{% set map_config = h.get_common_map_config() %} {% set map_config = h.get_common_map_config() %}
<div class="dataset-map" data-module="spatial-query" data-default_extent="{{ default_extent }}" data-module-map_config="{{ h.dump_json(map_config) }}"> <div class="dataset-map" data-module="spatial-query" data-default_extent="{{ default_extent }}" data-module-map_config="{{ h.dump_json(map_config) }}">