From 33d44aeca78f0a46a651960535022888d8dbac57 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Simen=20Heggest=C3=B8yl?= Date: Wed, 21 Aug 2024 15:10:11 +0200 Subject: [PATCH] Fix map scales The map coloring scales have been totally misleading. Revamp the whole implementation to make them (hopefully) make more sense. The scales are now linear from 0% to 200% compared to the Oslo average (so that 100% = the Oslo average = the middle of the scale). The (few) values above 200% are simply clamped down to 200%. --- src/components/VLeaflet.vue | 35 +++++++++++++++--------------- src/config/topics/alder.js | 1 - src/config/topics/husholdninger.js | 1 - 3 files changed, 18 insertions(+), 19 deletions(-) diff --git a/src/components/VLeaflet.vue b/src/components/VLeaflet.vue index f345c913..1fea8ad0 100644 --- a/src/components/VLeaflet.vue +++ b/src/components/VLeaflet.vue @@ -79,7 +79,6 @@ export default { touchZoom: true, gestureHandling: true, }, - scale: null, }), computed: { @@ -184,19 +183,20 @@ export default { }, createChoropleth(data) { - if (this.meta.scale && this.meta.scale.length !== 0) { - if (this.settings.method === 'value') this.scale = this.meta.scale.value; - else this.scale = this.meta.scale.ratio; - } else { - this.scale = this.settings.scale; - } - - // Color calulator defined by the scale set in the map settings - const colorStrength = scaleLinear().range([0, 1]).domain(this.scale); + const colorStrength = scaleLinear().domain([0, 2]).range([0, 1]); + const totalRow = data.find((geo) => geo.totalRow); // Store data to create const allLayerData = []; + let osloValue; + if (this.settings.method === 'avg') { + const osloValues = totalRow.values.map((d) => d.value); + osloValue = sum(osloValues.map((val, i) => val * i)) / sum(osloValues); + } else { + osloValue = totalRow.values[0][this.settings.method]; + } + // Map layers in the map with the data returned this.geojsonLayer.eachLayer((layer) => { const layerId = layer.feature.properties.id; @@ -205,21 +205,22 @@ export default { const { geography } = dataObj; - // The data value depends on the method and/or series defined on the map settings object + // The data value depends on the method defined on the map settings object let dataValue; if (this.settings.method === 'avg') { const values = dataObj.values.map((d) => d.value); dataValue = sum(values.map((val, i) => val * i)) / sum(values); - } else if (this.settings.series) { - dataValue = dataObj.values[this.settings.series][this.settings.method]; } else { dataValue = dataObj.values[0][this.settings.method]; } + // Clamp the upper Oslo ratio to 200% + const osloRatio = Math.min(dataValue / osloValue, 2); + // Calculate the fill color based on the value const fill = this.settings.reverse - ? interpolator(1 - colorStrength(dataValue)) - : interpolator(colorStrength(dataValue)); + ? interpolator(1 - colorStrength(osloRatio)) + : interpolator(colorStrength(osloRatio)); // Set number formatting for popup @@ -237,7 +238,7 @@ export default { layer.setStyle({ fillColor: fill, fillOpacity: 0.6, weight: 1 }).bindPopup(popupContent); // Store the layer data for use in legend - allLayerData.push({ dataValue, geography, layer }); + allLayerData.push({ osloRatio, geography, layer }); }); // For each layer add an interactive dot on the legend. @@ -248,7 +249,7 @@ export default { .join('div') .attr('class', 'legend__dot') .transition() - .style('left', (d) => `${colorStrength(d.dataValue) * 100}%`) + .style('left', (d) => `${colorStrength(d.osloRatio) * 100}%`) .each((d, i, j) => { j[i].addEventListener('click', () => { d.layer.openPopup(); diff --git a/src/config/topics/alder.js b/src/config/topics/alder.js index 71c20f34..b86998a6 100644 --- a/src/config/topics/alder.js +++ b/src/config/topics/alder.js @@ -70,7 +70,6 @@ export default { }, map: { labels: ['Lavere gjennomsnittsalder', 'Høyere gjennomsnittsalder'], - scale: [32, 43], reverse: true, method: 'avg', url: `${API}/alder-distribusjon-status`, diff --git a/src/config/topics/husholdninger.js b/src/config/topics/husholdninger.js index 0426f60a..b38e84ed 100644 --- a/src/config/topics/husholdninger.js +++ b/src/config/topics/husholdninger.js @@ -21,7 +21,6 @@ export default { url: `${API}/husholdningstyper-status`, heading: 'Énpersonshusholdninger', method: 'ratio', - series: 0, }, tabs: [ {