diff --git a/modern/src/map/core/useMapStyles.js b/modern/src/map/core/useMapStyles.js index 733d8d330e..7c3412b514 100644 --- a/modern/src/map/core/useMapStyles.js +++ b/modern/src/map/core/useMapStyles.js @@ -1,3 +1,4 @@ +import { useMemo } from 'react'; import { useSelector } from 'react-redux'; import { useTranslation } from '../../common/components/LocalizationProvider'; import { useAttributePreference } from '../../common/util/preferences'; @@ -37,7 +38,7 @@ export default () => { const mapboxAccessToken = useAttributePreference('mapboxAccessToken'); const customMapUrl = useSelector((state) => state.session.server.mapUrl); - return [ + return useMemo(() => [ { id: 'locationIqStreets', title: t('mapLocationIqStreets'), @@ -254,5 +255,5 @@ export default () => { }), available: !!customMapUrl, }, - ]; + ], [t, mapTilerKey, locationIqKey, bingMapsKey, tomTomKey, hereKey, mapboxAccessToken, customMapUrl]); }; diff --git a/modern/src/map/overlay/MapOverlay.js b/modern/src/map/overlay/MapOverlay.js index 4db2153db8..e436ea8d17 100644 --- a/modern/src/map/overlay/MapOverlay.js +++ b/modern/src/map/overlay/MapOverlay.js @@ -31,7 +31,7 @@ const MapOverlay = () => { map.removeSource(id); } }; - }); + }, [id, activeOverlay]); return null; }; diff --git a/modern/src/map/overlay/useMapOverlays.js b/modern/src/map/overlay/useMapOverlays.js index 5114424bcd..dafb5f83fa 100644 --- a/modern/src/map/overlay/useMapOverlays.js +++ b/modern/src/map/overlay/useMapOverlays.js @@ -1,3 +1,4 @@ +import { useMemo } from 'react'; import { useSelector } from 'react-redux'; import { useTranslation } from '../../common/components/LocalizationProvider'; import { useAttributePreference } from '../../common/util/preferences'; @@ -21,7 +22,7 @@ export default () => { const hereKey = useAttributePreference('hereKey'); const customMapOverlay = useSelector((state) => state.session.server.overlayUrl); - return [ + return useMemo(() => [ { id: 'openSeaMap', title: t('mapOpenSeaMap'), @@ -98,5 +99,5 @@ export default () => { source: sourceCustom(customMapOverlay), available: !!customMapOverlay, }, - ]; + ], [t, openWeatherKey, tomTomKey, hereKey, customMapOverlay]); };