aboutsummaryrefslogtreecommitdiffstats
path: root/web/js/duplicates.js
diff options
context:
space:
mode:
authorMatthew Somerville <matthew@mysociety.org>2019-08-08 16:38:38 +0100
committerMatthew Somerville <matthew@mysociety.org>2019-08-08 16:38:38 +0100
commit80131ff0362b161c8a3f082e6f81ea9ff1693402 (patch)
tree9c85984f2e1ac8b6ba4d38b497e26b0fdf6439e5 /web/js/duplicates.js
parentc193d4136a2dfb1a849cfccbbcacc4937931e54a (diff)
parentea7c5b5ff6657af974bc64e1fa4618cb6a241e7b (diff)
Merge branch 'issues/commercial/1480-asset-duplicate-interaction'
Diffstat (limited to 'web/js/duplicates.js')
-rw-r--r--web/js/duplicates.js18
1 files changed, 17 insertions, 1 deletions
diff --git a/web/js/duplicates.js b/web/js/duplicates.js
index b8bb35246..188459565 100644
--- a/web/js/duplicates.js
+++ b/web/js/duplicates.js
@@ -8,7 +8,11 @@
// but undefined on new report page.
var report_id = $("#report_inspect_form .js-report-id").text() || undefined;
- function refresh_duplicate_list() {
+ function refresh_duplicate_list(evt, params) {
+ if (params && params.skip_duplicates) {
+ return;
+ }
+
var category = $('select[name="category"]').val();
if (category === '-- Pick a category --') {
return;
@@ -129,6 +133,14 @@
fixmystreet.markers.removeFeatures( current_duplicate_markers );
fixmystreet.markers.addFeatures( markers );
current_duplicate_markers = markers;
+
+ // Hide any asset layer that might be visible and get confused with the duplicates
+ var layers = fixmystreet.map.getLayersBy('assets', true);
+ for (var i = 0; i<layers.length; i++) {
+ if (!layers[i].fixmystreet.always_visible && layers[i].getVisibility()) {
+ layers[i].setVisibility(false);
+ }
+ }
}
function remove_duplicate_list() {
@@ -147,6 +159,10 @@
return;
}
fixmystreet.markers.removeFeatures( current_duplicate_markers );
+
+ // In order to reinstate a hidden assets layer, let's pretend we've
+ // just picked the category anew, but skip ourselves
+ $(fixmystreet).trigger('report_new:category_change', { skip_duplicates: true });
}
function inspect_form_state_change() {