From 0987dd7a61ac2c9d964d435a236687e5965044f3 Mon Sep 17 00:00:00 2001 From: Nicolas Dufrane Date: Mon, 3 Apr 2017 15:51:45 +0200 Subject: [PATCH] WMS legend is taking in account the current scale of the map (#1669) --- web/client/components/TOC/DefaultLayer.jsx | 6 +++-- .../components/TOC/fragments/WMSLegend.jsx | 6 +++-- .../TOC/fragments/legend/Legend.jsx | 8 ++++--- web/client/plugins/TOC.jsx | 22 ++++++++++++++----- 4 files changed, 30 insertions(+), 12 deletions(-) diff --git a/web/client/components/TOC/DefaultLayer.jsx b/web/client/components/TOC/DefaultLayer.jsx index 03106e4783..d40466b5e1 100644 --- a/web/client/components/TOC/DefaultLayer.jsx +++ b/web/client/components/TOC/DefaultLayer.jsx @@ -48,7 +48,9 @@ var DefaultLayer = React.createClass({ settingsOptions: React.PropTypes.object, visibilityCheckType: React.PropTypes.string, includeDeleteButtonInSettings: React.PropTypes.bool, - groups: React.PropTypes.array + groups: React.PropTypes.array, + currentZoomLvl: React.PropTypes.number, + scales: React.PropTypes.array }, getDefaultProps() { return { @@ -135,7 +137,7 @@ var DefaultLayer = React.createClass({ } return (
{tools}
-
+
); }, renderTools() { diff --git a/web/client/components/TOC/fragments/WMSLegend.jsx b/web/client/components/TOC/fragments/WMSLegend.jsx index 420b4e6bde..9d4517a8eb 100644 --- a/web/client/components/TOC/fragments/WMSLegend.jsx +++ b/web/client/components/TOC/fragments/WMSLegend.jsx @@ -12,7 +12,9 @@ var Legend = require('./legend/Legend'); var WMSLegend = React.createClass({ propTypes: { node: React.PropTypes.object, - showOnlyIfVisible: React.PropTypes.bool + showOnlyIfVisible: React.PropTypes.bool, + currentZoomLvl: React.PropTypes.number, + scales: React.PropTypes.array }, getDefaultProps() { return { @@ -22,7 +24,7 @@ var WMSLegend = React.createClass({ render() { let node = this.props.node || {}; if (this.canShow(node) && node.type === "wms" && node.group !== "background") { - return
; + return
; } return null; }, diff --git a/web/client/components/TOC/fragments/legend/Legend.jsx b/web/client/components/TOC/fragments/legend/Legend.jsx index 7f29744308..dc119d2081 100644 --- a/web/client/components/TOC/fragments/legend/Legend.jsx +++ b/web/client/components/TOC/fragments/legend/Legend.jsx @@ -11,7 +11,9 @@ const Legend = React.createClass({ layer: React.PropTypes.object, legendHeigth: React.PropTypes.number, legendWidth: React.PropTypes.number, - legendOptions: React.PropTypes.string + legendOptions: React.PropTypes.string, + currentZoomLvl: React.PropTypes.number, + scales: React.PropTypes.array }, getDefaultProps() { return { @@ -39,10 +41,10 @@ const Legend = React.createClass({ version: layer.version || "1.3.0", SLD_VERSION: "1.1.0", LEGEND_OPTIONS: this.props.legendOptions - // SCALE TODO }, layer.legendParams || {}, layer.params || {}, - layer.params && layer.params.SLD_BODY ? {SLD_BODY: layer.params.SLD_BODY} : {}); + layer.params && layer.params.SLD_BODY ? {SLD_BODY: layer.params.SLD_BODY} : {}, + this.props.scales && this.props.currentZoomLvl ? {SCALE: Math.round(this.props.scales[this.props.currentZoomLvl])} : {}); SecurityUtils.addAuthenticationParameter(url, query); let legendUrl = urlUtil.format({ diff --git a/web/client/plugins/TOC.jsx b/web/client/plugins/TOC.jsx index 4214680339..2e6730b834 100644 --- a/web/client/plugins/TOC.jsx +++ b/web/client/plugins/TOC.jsx @@ -15,8 +15,10 @@ const {changeLayerProperties, changeGroupProperties, toggleNode, const {getLayerCapabilities} = require('../actions/layerCapabilities'); const {zoomToExtent} = require('../actions/map'); const {groupsSelector} = require('../selectors/layers'); +const {mapSelector} = require('../selectors/map'); const LayersUtils = require('../utils/LayersUtils'); +const mapUtils = require('../utils/MapUtils'); const Message = require('./locale/Message'); const assign = require('object-assign'); @@ -127,12 +129,18 @@ const tocSelector = createSelector( (state) => state.controls && state.controls.toolbar && state.controls.toolbar.active === 'toc', groupsSelector, (state) => state.layers && state.layers.settings || {expanded: false, options: {opacity: 1}}, - (state) => state.controls && state.controls.queryPanel && state.controls.queryPanel.enabled || false - ], (enabled, groups, settings, querypanelEnabled) => ({ + (state) => state.controls && state.controls.queryPanel && state.controls.queryPanel.enabled || false, + mapSelector + ], (enabled, groups, settings, querypanelEnabled, map) => ({ enabled, groups, settings, - querypanelEnabled + querypanelEnabled, + currentZoomLvl: map && map.zoom, + scales: mapUtils.getScales( + map && map.projection || 'EPSG:3857', + map && map.mapOptions && map.mapOptions.view && map.mapOptions.view.DPI || null + ) }) ); @@ -168,7 +176,9 @@ const LayerTree = React.createClass({ activateQueryTool: React.PropTypes.bool, activateSettingsTool: React.PropTypes.bool, visibilityCheckType: React.PropTypes.string, - settingsOptions: React.PropTypes.object + settingsOptions: React.PropTypes.object, + currentZoomLvl: React.PropTypes.number, + scales: React.PropTypes.array }, getDefaultProps() { return { @@ -230,7 +240,9 @@ const LayerTree = React.createClass({ opacityText={} saveText={} closeText={} - groups={this.props.groups}/>); + groups={this.props.groups} + currentZoomLvl={this.props.currentZoomLvl} + scales={this.props.scales}/>); return (