From eb1cb2fdb25dfd5c89a5743623d516cc341552f7 Mon Sep 17 00:00:00 2001 From: Francesco Boccacci Date: Mon, 13 Feb 2023 08:59:12 +0100 Subject: [PATCH] Keep layer legend visible in a separate TAB regardless of layer scale dependency visibility (#328) * Fix legend on separate tab when layer change visibility due scale depend visibility. * Update src/components/CatalogLayersLegendItems.vue Co-authored-by: Raruto * reduce inline comments pollution --------- Co-authored-by: Raruto --- src/components/CatalogLayersLegendItems.vue | 68 ++++++++++----------- 1 file changed, 33 insertions(+), 35 deletions(-) diff --git a/src/components/CatalogLayersLegendItems.vue b/src/components/CatalogLayersLegendItems.vue index d4caee4a6..d78c88711 100644 --- a/src/components/CatalogLayersLegendItems.vue +++ b/src/components/CatalogLayersLegendItems.vue @@ -6,22 +6,21 @@ @@ -53,12 +52,11 @@ export default { watch: { /** - * It changes when check/uncheck layer on toc + * It changes when change layer visibility */ layers: { handler() { - //reset the legend urls array - this.legendurls = []; + this.getLegendSrc(); }, immediate: false }, @@ -91,22 +89,30 @@ export default { return catalogLayer && catalogLayer.getLegendUrl(params, { format: 'image/png', categories: layer.categories }); }, - async getLegendSrc(_layers) { + /** + * get legend src for visible layers + * @returns {Promise} + */ + async getLegendSrc() { + + // reset layers url + this.legendurls = []; + + await this.$nextTick(); + // skip if not active if (!this.active) { return } + const urlMethodsLayersName = { GET: {}, POST: {} }; const self = this; - this.legendurls = []; - - await this.$nextTick(); // filter geolayer - const layers = _layers.filter(layer => layer.geolayer); + const layers = this.layers.filter(layer => layer.geolayer); for (let i=0; i < layers.length; i++) { const layer = layers[i]; @@ -136,7 +142,7 @@ export default { this.legendurls.push({ loading: true, url: (urlLayersName[url].length) - ? `${url}&LAYER=${encodeURIComponent(urlLayersName[url].map(layerObj => layerObj.layerName).join(','))}&STYLES=${encodeURIComponent(urlLayersName[url].map(layerObj => layerObj.style).join(','))}${ApplicationService.getFilterToken() ? '&filtertoken=' + ApplicationService.getFilterToken() : '' }` + ? `${url}LAYERS=${encodeURIComponent(urlLayersName[url].map(layerObj => layerObj.layerName).join(','))}&STYLES=${encodeURIComponent(urlLayersName[url].map(layerObj => layerObj.style).join(','))}${ApplicationService.getFilterToken() ? '&filtertoken=' + ApplicationService.getFilterToken() : '' }` : url, error: false }) @@ -197,19 +203,11 @@ export default { */ this.dynamic = ProjectsRegistry.getCurrentProject().getContextBaseLegend(); this.mapReady = false; + /** + * listen when layer has changed style + */ CatalogEventHub.$on('layer-change-style', (options={}) => { - let changeLayersLegend =[]; - if (options.layerId) { - const layer = this.layers.find(layer => options.layerId == layer.id); - if (layer) { - changeLayersLegend.push(layer); - } - } else { - changeLayersLegend = this.layers; - } - if (changeLayersLegend.length) { - this.getLegendSrc(changeLayersLegend); - } + this.getLegendSrc(); }); }, @@ -221,7 +219,7 @@ export default { if (this.dynamic) { GUI.getService('map').on('change-map-legend-params', ()=>{ this.mapReady = true; - this.getLegendSrc(this.layers); + this.getLegendSrc(); }); } else { this.mapReady = true;