From 60cd9efbb7341226660c380775bdd29a970f6a02 Mon Sep 17 00:00:00 2001 From: Bartosz Prusinowski Date: Fri, 18 Nov 2022 13:45:44 +0100 Subject: [PATCH] feat: Sort columns properly in downloaded files --- CHANGELOG.md | 2 ++ app/components/data-download.tsx | 4 +++- app/configurator/components/datatable.tsx | 11 ++++++----- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0c663edf2..94dcc6b82 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,6 +12,8 @@ You can also check the [release page](https://github.com/visualize-admin/visuali - Enhancements: - Cube Checker: - Introduced a Temporal dimensions scaleType & timeFormat checks + - Data download: + - Order of columns in downloaded files now matches the order visible in the dataset preview (based on shacl:order) - Bug fixes: - Correctly retrieve min & max values for Temporal dimensions when scaleType is not equal to Interval diff --git a/app/components/data-download.tsx b/app/components/data-download.tsx index 13cbeada7..720ea6bb6 100644 --- a/app/components/data-download.tsx +++ b/app/components/data-download.tsx @@ -28,6 +28,7 @@ import { OperationResult, useClient } from "urql"; import { QueryFilters } from "@/charts/shared/chart-helpers"; import { DataSource } from "@/configurator"; +import { getSortedColumns } from "@/configurator/components/datatable"; import { useLocale } from "@/src"; import { Observation } from "../domain/data"; @@ -84,6 +85,7 @@ export type FileFormat = typeof FILE_FORMATS[number]; const makeColumnLabel = (dim: DimensionMetadataFragment) => { return `${dim.label}${dim.unit ? ` (${dim.unit})` : ""}`; }; + const prepareData = ({ dimensions, measures, @@ -93,7 +95,7 @@ const prepareData = ({ measures: DimensionMetadataFragment[]; observations: Observation[]; }) => { - const columns = keyBy([...dimensions, ...measures], (d) => d.iri); + const columns = keyBy(getSortedColumns(dimensions, measures), (d) => d.iri); const data = observations.map((obs) => Object.keys(obs).reduce((acc, key) => { const col = columns[key]; diff --git a/app/configurator/components/datatable.tsx b/app/configurator/components/datatable.tsx index f268907f5..9faa0bffe 100644 --- a/app/configurator/components/datatable.tsx +++ b/app/configurator/components/datatable.tsx @@ -187,7 +187,7 @@ export const DataSetPreviewTable = ({ observations: Observation[]; }) => { const headers = useMemo(() => { - return getSortedHeaders(dimensions, measures); + return getSortedColumns(dimensions, measures); }, [dimensions, measures]); if (observations) { @@ -231,7 +231,8 @@ export const DataSetTable = ({ if (!data?.dataCubeByIri) { return []; } - return getSortedHeaders( + + return getSortedColumns( data.dataCubeByIri.dimensions, data.dataCubeByIri.measures ); @@ -252,13 +253,13 @@ export const DataSetTable = ({ } }; -function getSortedHeaders( +export const getSortedColumns = ( dimensions: DimensionMetadataFragment[], measures: DimensionMetadataFragment[] -) { +) => { const allDimensions = [...dimensions, ...measures]; allDimensions.sort((a, b) => ascending(a.order ?? Infinity, b.order ?? Infinity) ); return allDimensions; -} +};