From 29734fd88bf3cebb653e798909883ca39c16a5aa Mon Sep 17 00:00:00 2001 From: hvangeffen Date: Wed, 24 Apr 2024 09:56:02 +0200 Subject: [PATCH 1/2] Fix legend title and inactive updates, move legend utils to lib --- .../SpatialDisplayComponent.vue | 46 +++++++------------ src/lib/legend/index.ts | 29 ++++++++++++ src/services/useWms/index.ts | 11 +++++ 3 files changed, 57 insertions(+), 29 deletions(-) create mode 100644 src/lib/legend/index.ts diff --git a/src/components/spatialdisplay/SpatialDisplayComponent.vue b/src/components/spatialdisplay/SpatialDisplayComponent.vue index 06a4ea40..c637acfb 100644 --- a/src/components/spatialdisplay/SpatialDisplayComponent.vue +++ b/src/components/spatialdisplay/SpatialDisplayComponent.vue @@ -132,19 +132,20 @@ import debounce from 'lodash-es/debounce' import { useUserSettingsStore } from '@/stores/userSettings' import type { MapLayerMouseEvent, MapLayerTouchEvent } from 'maplibre-gl' import { configManager } from '@/services/application-config' -import type { - GetLegendGraphicResponse, - Layer, -} from '@deltares/fews-wms-requests' +import type { Layer } from '@deltares/fews-wms-requests' import { LayerKind } from '@/lib/streamlines' -import { Style } from '@deltares/fews-wms-requests' -import { ColourMap } from '@deltares/fews-web-oc-charts' import { pointToGeoJson } from '@/lib/topology/coordinates' import { SecondaryWorkflowGroupItem } from '@deltares/fews-pi-requests' -import { Range, useColourScalesStore } from '@/stores/colourScales' +import { useColourScalesStore } from '@/stores/colourScales' import { useDisplay } from 'vuetify' import { useFilterLocations } from '@/services/useFilterLocations' import ColourLegend from '@/components/wms/ColourLegend.vue' +import { + getLegendTitle, + legendToRange, + rangeToString, + styleToId, +} from '@/lib/legend' interface ElevationWithUnitSymbol { units?: string @@ -247,7 +248,10 @@ watch( const legend = initialLegendGraphic.legend const newColourScale = reactive({ - title: getLegendTitle(initialLegendGraphic), + title: getLegendTitle( + props.layerCapabilities?.title ?? '', + initialLegendGraphic, + ), style: style, colourMap: legend, range: legendToRange(legend), @@ -263,10 +267,15 @@ watch( () => settings.useDisplayUnits, () => rangeToString(newColourScale.range), style, + () => props.layerCapabilities?.styles ?? [], ) watch(newLegendGraphic, () => { if (newLegendGraphic.value?.legend === undefined) return + colourScalesStore.scales[styleId].title = getLegendTitle( + props.layerCapabilities?.title ?? '', + newLegendGraphic.value, + ) colourScalesStore.scales[styleId].colourMap = newLegendGraphic.value.legend }) @@ -297,21 +306,6 @@ function onLocationChange(locationId: string | null): void { emit('changeLocationId', locationId) } -function styleToId(style: Style) { - return style.name ?? style.title -} - -function rangeToString(range: Range): string { - return `${range.min},${range.max}` -} - -function legendToRange(legend: ColourMap): Range { - return { - min: legend[0].lowerValue, - max: legend[legend.length - 1].lowerValue, - } -} - const canUseStreamlines = computed( () => props.layerCapabilities?.animatedVectors !== undefined, ) @@ -418,12 +412,6 @@ function setLayerOptions(): void { } } -function getLegendTitle(legendGraphic: GetLegendGraphicResponse): string { - if (!props.layerCapabilities) return '' - const unitString = legendGraphic.unit ? ` [${legendGraphic.unit}]` : '' - return `${props.layerCapabilities.title}${unitString}` -} - function onCoordinateClick( event: MapLayerMouseEvent | MapLayerTouchEvent, ): void { diff --git a/src/lib/legend/index.ts b/src/lib/legend/index.ts new file mode 100644 index 00000000..eab55598 --- /dev/null +++ b/src/lib/legend/index.ts @@ -0,0 +1,29 @@ +import type { + Style, + GetLegendGraphicResponse, +} from '@deltares/fews-wms-requests' +import type { ColourMap } from '@deltares/fews-web-oc-charts' +import type { Range } from '@/stores/colourScales' + +export function rangeToString(range: Range): string { + return `${range.min},${range.max}` +} + +export function getLegendTitle( + layerTitle: string, + legendGraphic: GetLegendGraphicResponse, +) { + const unitString = legendGraphic.unit ? ` [${legendGraphic.unit}]` : '' + return `${layerTitle}${unitString}` +} + +export function styleToId(style: Style) { + return style.name ?? style.title +} + +export function legendToRange(legend: ColourMap): Range { + return { + min: legend[0].lowerValue, + max: legend[legend.length - 1].lowerValue, + } +} diff --git a/src/services/useWms/index.ts b/src/services/useWms/index.ts index dd0183d4..74ffb11c 100644 --- a/src/services/useWms/index.ts +++ b/src/services/useWms/index.ts @@ -13,6 +13,7 @@ import { LngLatBounds } from 'maplibre-gl' import { GetLegendGraphicResponse } from '@deltares/fews-wms-requests/src/response/getLegendGraphicResponse.ts' import { createTransformRequestFn } from '@/lib/requests/transformRequest' import { Style } from '@deltares/fews-wms-requests' +import { styleToId } from '@/lib/legend' export interface UseWmsReturn { layerCapabilities: Ref @@ -89,6 +90,7 @@ export function useWmsLegend( useDisplayUnits: MaybeRefOrGetter, colorScaleRange?: MaybeRefOrGetter, style?: MaybeRefOrGetter