diff --git a/src/explore-education-statistics-admin/src/pages/release/datablocks/components/DataBlockPageTabs.tsx b/src/explore-education-statistics-admin/src/pages/release/datablocks/components/DataBlockPageTabs.tsx index 4fcdba099ce..0c6f4ebecde 100644 --- a/src/explore-education-statistics-admin/src/pages/release/datablocks/components/DataBlockPageTabs.tsx +++ b/src/explore-education-statistics-admin/src/pages/release/datablocks/components/DataBlockPageTabs.tsx @@ -9,11 +9,13 @@ import dataBlocksService, { CreateReleaseDataBlock, ReleaseDataBlock, } from '@admin/services/dataBlockService'; +import featuredTableService from '@admin/services/featuredTableService'; import LoadingSpinner from '@common/components/LoadingSpinner'; import Tabs from '@common/components/Tabs'; import TabsSection from '@common/components/TabsSection'; import WarningMessage from '@common/components/WarningMessage'; import useAsyncRetry from '@common/hooks/useAsyncRetry'; +import getMapInitialBoundaryLevel from '@common/modules/charts/components/utils/getMapInitialBoundaryLevel'; import isOrphanedDataSet from '@common/modules/charts/util/isOrphanedDataSet'; import { InitialTableToolState } from '@common/modules/table-tool/components/TableToolWizard'; import getInitialStepSubjectMeta from '@common/modules/table-tool/components/utils/getInitialStepSubjectMeta'; @@ -29,7 +31,6 @@ import minDelay from '@common/utils/minDelay'; import { produce } from 'immer'; import omit from 'lodash/omit'; import React, { useCallback, useState } from 'react'; -import featuredTableService from '@admin/services/featuredTableService'; export type SavedDataBlock = CreateReleaseDataBlock & { id?: string; @@ -78,14 +79,10 @@ const DataBlockPageTabs = ({ releaseId, }; - const boundaryLevel = - dataBlock.charts[0]?.type === 'map' - ? dataBlock.charts[0].boundaryLevel - : undefined; const tableData = await tableBuilderService.getTableData( query, releaseId, - boundaryLevel, + getMapInitialBoundaryLevel(dataBlock.charts), ); const { initialStep, subjectMeta } = await getInitialStepSubjectMeta( diff --git a/src/explore-education-statistics-common/src/modules/charts/components/utils/getMapInitialBoundaryLevel.ts b/src/explore-education-statistics-common/src/modules/charts/components/utils/getMapInitialBoundaryLevel.ts new file mode 100644 index 00000000000..7f591ecf537 --- /dev/null +++ b/src/explore-education-statistics-common/src/modules/charts/components/utils/getMapInitialBoundaryLevel.ts @@ -0,0 +1,18 @@ +import { Chart } from '@common/services/types/blocks'; +import isEqual from 'lodash/isEqual'; +import sortBy from 'lodash/sortBy'; + +export default function getMapInitialBoundaryLevel( + charts: Chart[], +): number | undefined { + if (charts.length === 0 || charts[0].type !== 'map') return undefined; + const chart = charts[0]; + + // data set options are ordered alphabetically based on their label text + const firstDataSet = sortBy(chart.legend.items, 'label')[0].dataSet; + const firstDataSetConfig = chart.map?.dataSetConfigs.find(({ dataSet }) => { + return isEqual(dataSet, firstDataSet); + }); + + return firstDataSetConfig?.boundaryLevel ?? chart.boundaryLevel; +} diff --git a/src/explore-education-statistics-common/src/modules/find-statistics/components/DataBlockTabs.tsx b/src/explore-education-statistics-common/src/modules/find-statistics/components/DataBlockTabs.tsx index f09b6a8c623..083c9f64563 100644 --- a/src/explore-education-statistics-common/src/modules/find-statistics/components/DataBlockTabs.tsx +++ b/src/explore-education-statistics-common/src/modules/find-statistics/components/DataBlockTabs.tsx @@ -6,6 +6,7 @@ import WarningMessage from '@common/components/WarningMessage'; import withLazyLoad from '@common/hocs/withLazyLoad'; import ChartRenderer from '@common/modules/charts/components/ChartRenderer'; import { GetInfographic } from '@common/modules/charts/components/InfographicBlock'; +import getMapInitialBoundaryLevel from '@common/modules/charts/components/utils/getMapInitialBoundaryLevel'; import { AxesConfiguration } from '@common/modules/charts/types/chart'; import TimePeriodDataTable from '@common/modules/table-tool/components/TimePeriodDataTable'; import getDefaultTableHeaderConfig from '@common/modules/table-tool/utils/getDefaultTableHeadersConfig'; @@ -43,9 +44,7 @@ const DataBlockTabs = ({ onToggle, }: DataBlockTabsProps) => { const [selectedBoundaryLevel, setSelectedBoundaryLevel] = useState( - dataBlock.charts[0]?.type === 'map' - ? dataBlock.charts[0].boundaryLevel - : undefined, + getMapInitialBoundaryLevel(dataBlock.charts), ); const {