From 0cc610ae9f6ce54cd51f10a6b872b20d1858b6af Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Niccol=C3=B2=20Cant=C3=B9?= Date: Tue, 5 Mar 2024 12:13:17 +0100 Subject: [PATCH] handle map legend --- src/pages/viewer/components/LegendWidget.jsx | 69 ++++++++++++-------- 1 file changed, 43 insertions(+), 26 deletions(-) diff --git a/src/pages/viewer/components/LegendWidget.jsx b/src/pages/viewer/components/LegendWidget.jsx index 5af9c7b..7ed35d2 100644 --- a/src/pages/viewer/components/LegendWidget.jsx +++ b/src/pages/viewer/components/LegendWidget.jsx @@ -1,6 +1,6 @@ import { useContext, useMemo } from "react" import { MapContext } from "../contexts" -import { Box, Heading } from "react-bulma-components"; +import { Box } from "react-bulma-components"; import SequentialLegend from "./legend-types/Sequential"; @@ -11,39 +11,56 @@ function LegendRender({ type, ...data }) { } } -export default function LegendWidget() { - const { layers } = useContext(MapContext); - - const legend = useMemo(() => { - return Object.entries(layers).filter(([key, value]) => { - if (value && value.layout && value.layout.visibility === 'none') { - return false; - } - if (!value.metadata || !value.metadata.legend) { - return false; - } - - return true; - }).map(([key, value]) => { - return ( -
-

{value.metadata.name}

-
- -
+function getMapLegend(legends) { + return legends.map(legend => { + return ( +
+

{legend.title}

+
+
- ) +
+ ) + }); +} - }); - }, [layers]); +function getLayerLegend(layers) { + return Object.entries(layers).filter(([key, value]) => { + if (value && value.layout && value.layout.visibility === 'none') { + return false; + } + if (!value.metadata || !value.metadata.legend) { + return false; + } + + return true; + }).map(([key, value]) => { + return ( +
+

{value.metadata.name}

+
+ +
+
+ ) + }); +} + +export default function LegendWidget() { + const { layers, style } = useContext(MapContext); + const config = useMemo(() => style && style.metadata && style.metadata.legend, style.metadata.legend.config ? style.metadata.legend.config : { + layerLegend: true, + }, [style]); + const legend = useMemo(() => config.layerLegend ? getLayerLegend(layers) : null, [layers, config]); + const mapLegend = useMemo(() => style && style.metadata && style.metadata.legend && style.metadata.legend.data ? getMapLegend(style.metadata.legend.data) : null, [style]); - if (!legend || !legend.length) { + if ((!legend || !legend.length) && (!mapLegend || !mapLegend.length)) { return null; } return ( - Legend + {mapLegend} {legend} )