From 81e11276b21c1350bf5d5427cdb1a1df31ef16ce Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Prod=27homme?= Date: Fri, 11 Oct 2024 11:30:10 +0200 Subject: [PATCH] Only reset to default layers when the tab changes --- .../map/sidebar/layers-panel/index.tsx | 36 ++++++++++--------- 1 file changed, 20 insertions(+), 16 deletions(-) diff --git a/frontend/src/containers/map/sidebar/layers-panel/index.tsx b/frontend/src/containers/map/sidebar/layers-panel/index.tsx index 49221c75..5a51cf7e 100644 --- a/frontend/src/containers/map/sidebar/layers-panel/index.tsx +++ b/frontend/src/containers/map/sidebar/layers-panel/index.tsx @@ -1,6 +1,7 @@ import { ComponentProps, useCallback, useEffect, useMemo } from 'react'; import { useLocale, useTranslations } from 'next-intl'; +import { usePreviousImmediate } from 'rooks'; import TooltipButton from '@/components/tooltip-button'; import { Label } from '@/components/ui/label'; @@ -20,6 +21,7 @@ const LayersPanel: FCWithMessages = (): JSX.Element => { const [, setMapLayers] = useSyncMapLayers(); const [{ labels }, setMapSettings] = useSyncMapSettings(); const [{ tab }] = useSyncMapContentSettings(); + const previousTab = usePreviousImmediate(tab); const { data: datasetsData, @@ -122,23 +124,25 @@ const LayersPanel: FCWithMessages = (): JSX.Element => { // Set map layers to the corresponding defaults when the user switches tabs useEffect(() => { - let mapLayers = []; - switch (tab) { - case 'summary': - mapLayers = ['terrestrial', 'marine', 'basemap']?.reduce( - (ids, dataset) => [...ids, ...defaultLayersIds[dataset]], - [] - ); - break; - case 'terrestrial': - mapLayers = defaultLayersIds.terrestrial; - break; - case 'marine': - mapLayers = defaultLayersIds.marine; - break; + if (tab !== previousTab && !!previousTab) { + let mapLayers = []; + switch (tab) { + case 'summary': + mapLayers = ['terrestrial', 'marine', 'basemap']?.reduce( + (ids, dataset) => [...ids, ...defaultLayersIds[dataset]], + [] + ); + break; + case 'terrestrial': + mapLayers = defaultLayersIds.terrestrial; + break; + case 'marine': + mapLayers = defaultLayersIds.marine; + break; + } + setMapLayers(mapLayers); } - setMapLayers(mapLayers); - }, [defaultLayersIds, setMapLayers, tab]); + }, [defaultLayersIds, setMapLayers, tab, previousTab]); const handleLabelsChange = useCallback( (active: Parameters['onCheckedChange']>[0]) => {