From b174470f068e445e5e7d15604e1ae3a27e1ced64 Mon Sep 17 00:00:00 2001 From: Hanbyul Jo Date: Fri, 13 Sep 2024 11:25:14 -0400 Subject: [PATCH] Fix compare label on block map --- .../components/common/blocks/block-map.tsx | 13 ++++++++----- app/scripts/components/sandbox/mdx-page/page.mdx | 16 ++++++++++++++++ mock/datasets/no2.data.mdx | 4 ++-- 3 files changed, 26 insertions(+), 7 deletions(-) diff --git a/app/scripts/components/common/blocks/block-map.tsx b/app/scripts/components/common/blocks/block-map.tsx index 906ed4ebc..a26c46624 100644 --- a/app/scripts/components/common/blocks/block-map.tsx +++ b/app/scripts/components/common/blocks/block-map.tsx @@ -1,6 +1,7 @@ import React, { useMemo, useState, useEffect } from 'react'; import styled from 'styled-components'; import { MapboxOptions } from 'mapbox-gl'; +import * as dateFns from 'date-fns'; import { convertProjectionToMapbox, projectionDefault, @@ -162,7 +163,6 @@ function MapBlock(props: MapBlockProps) { } const datasetLayers = getDatasetLayers(datasets); - const layersToFetch = useMemo(() => { const [baseMapStaticData] = reconcileDatasets([layerId], datasetLayers, []); let totalLayers = [baseMapStaticData]; @@ -259,9 +259,12 @@ function MapBlock(props: MapBlockProps) { const computedCompareLabel = useMemo(() => { // Use a provided label if it exist. - if (compareLabel && compareDataLayer) { - const providedLabel = compareDataLayer.data.mapLabel as string; - return providedLabel; + if (compareLabel) return compareLabel as string; + // Use label function from originalData.Compare + else if (baseDataLayer?.data.compare?.mapLabel) { + if (typeof baseDataLayer.data.compare.mapLabel === 'string') return baseDataLayer.data.compare.mapLabel; + const labelFn = baseDataLayer.data.compare.mapLabel as (unknown) => string; + return labelFn({dateFns, datetime: selectedDatetime, compareDatetime: compareToDate }); } // Default to date comparison. @@ -275,7 +278,7 @@ function MapBlock(props: MapBlockProps) { : null; }, [ compareLabel, - compareDataLayer, + baseDataLayer, selectedDatetime, compareToDate, baseTimeDensity, diff --git a/app/scripts/components/sandbox/mdx-page/page.mdx b/app/scripts/components/sandbox/mdx-page/page.mdx index bdeea48b4..dbc322dae 100644 --- a/app/scripts/components/sandbox/mdx-page/page.mdx +++ b/app/scripts/components/sandbox/mdx-page/page.mdx @@ -33,6 +33,22 @@ + +
+ + Comparing dates set manually +
+
+
{ - return `${dateFns.format(datetime, 'LLL yyyy')} VS ${dateFns.format(compareDatetime, 'LLL yyyy')}`; + return `${dateFns.format(datetime, 'yyyy')} VS ${dateFns.format(compareDatetime, 'LLL yyyy')}`; } legend: unit: @@ -163,7 +163,7 @@ layers: layerId: no2-monthly-diff mapLabel: | ::js ({ dateFns, datetime, compareDatetime }) => { - return `${dateFns.format(datetime, 'LLL yyyy')} VS ${dateFns.format(compareDatetime, 'LLL yyyy')}`; + return `${dateFns.format(datetime, 'yyyy')} VS ${dateFns.format(compareDatetime, 'LLL yyyy')}`; } legend: unit: