From 8b9303344e6f14d82ac97c966b2ccc0c36b1e5e4 Mon Sep 17 00:00:00 2001 From: Bartosz Prusinowski Date: Mon, 29 Jan 2024 09:25:37 +0100 Subject: [PATCH 1/2] perf: Specify component iris in query filters --- app/browse/datatable.tsx | 1 + app/charts/shared/chart-data-filters.tsx | 5 +++-- app/charts/shared/chart-helpers.tsx | 8 ++++---- app/components/chart-filters-list.tsx | 6 +++++- app/components/chart-footnotes.tsx | 6 +++++- app/components/chart-with-filters.tsx | 1 + 6 files changed, 19 insertions(+), 8 deletions(-) diff --git a/app/browse/datatable.tsx b/app/browse/datatable.tsx index f0aadb926..e370b28e1 100644 --- a/app/browse/datatable.tsx +++ b/app/browse/datatable.tsx @@ -285,6 +285,7 @@ export const DataSetTable = ({ chartConfig, dimensions: componentsData?.dataCubesComponents?.dimensions, measures: componentsData?.dataCubesComponents?.measures, + componentIris, }); const [{ data: observationsData }] = useDataCubesObservationsQuery({ variables: { diff --git a/app/charts/shared/chart-data-filters.tsx b/app/charts/shared/chart-data-filters.tsx index 18f7514e2..ecf3522ac 100644 --- a/app/charts/shared/chart-data-filters.tsx +++ b/app/charts/shared/chart-data-filters.tsx @@ -71,14 +71,15 @@ export const ChartDataFilters = (props: ChartDataFiltersProps) => { const { dataSource, chartConfig, dimensions, measures } = props; const { loading } = useLoadingState(); const dataFilters = useInteractiveFilters((d) => d.dataFilters); + const componentIris = chartConfig.interactiveFiltersConfig?.dataFilters + .componentIris as string[]; const queryFilters = useQueryFilters({ chartConfig, dimensions, measures, allowNoneValues: true, + componentIris, }); - const componentIris = chartConfig.interactiveFiltersConfig?.dataFilters - .componentIris as string[]; const [filtersVisible, setFiltersVisible] = React.useState(false); React.useEffect(() => { diff --git a/app/charts/shared/chart-helpers.tsx b/app/charts/shared/chart-helpers.tsx index 34a9ed9cd..9676c1088 100644 --- a/app/charts/shared/chart-helpers.tsx +++ b/app/charts/shared/chart-helpers.tsx @@ -71,11 +71,13 @@ export const useQueryFilters = ({ dimensions, measures, allowNoneValues, + componentIris, }: { chartConfig: ChartConfig; dimensions?: Dimension[]; measures?: Measure[]; allowNoneValues?: boolean; + componentIris?: string[]; }): DataCubeObservationFilter[] | undefined => { const allDataFilters = useInteractiveFilters((d) => d.dataFilters); @@ -94,10 +96,7 @@ export const useQueryFilters = ({ return { iri: cube.iri, - // componentIris: getComponentIris(cube.iri, { - // dimensions, - // measures, - // }), + componentIris, filters: prepareQueryFilters( chartConfig.chartType, filters, @@ -116,6 +115,7 @@ export const useQueryFilters = ({ allowNoneValues, dimensions, measures, + componentIris, ]); }; diff --git a/app/components/chart-filters-list.tsx b/app/components/chart-filters-list.tsx index fd9cdd09b..98c9c89f6 100644 --- a/app/components/chart-filters-list.tsx +++ b/app/components/chart-filters-list.tsx @@ -1,7 +1,10 @@ import { Box, Typography } from "@mui/material"; import React, { Fragment } from "react"; -import { useQueryFilters } from "@/charts/shared/chart-helpers"; +import { + extractChartConfigComponentIris, + useQueryFilters, +} from "@/charts/shared/chart-helpers"; import { OpenMetadataPanelWrapper } from "@/components/metadata-panel"; import { ChartConfig, @@ -38,6 +41,7 @@ export const ChartFiltersList = (props: ChartFiltersListProps) => { chartConfig, dimensions, measures, + componentIris: extractChartConfigComponentIris(chartConfig), }); const [{ data }] = useDataCubesComponentsQuery({ variables: { diff --git a/app/components/chart-footnotes.tsx b/app/components/chart-footnotes.tsx index 6860906ba..10b526d46 100644 --- a/app/components/chart-footnotes.tsx +++ b/app/components/chart-footnotes.tsx @@ -3,7 +3,10 @@ import { Box, Button, Link, Theme, Typography } from "@mui/material"; import { makeStyles } from "@mui/styles"; import { PropsWithChildren, useEffect, useState } from "react"; -import { useQueryFilters } from "@/charts/shared/chart-helpers"; +import { + extractChartConfigComponentIris, + useQueryFilters, +} from "@/charts/shared/chart-helpers"; import { useChartTablePreview } from "@/components/chart-table-preview"; import { DataDownloadMenu, RunSparqlQuery } from "@/components/data-download"; import { ChartConfig, DataSource } from "@/configurator"; @@ -73,6 +76,7 @@ export const ChartFootnotes = ({ chartConfig, dimensions, measures, + componentIris: extractChartConfigComponentIris(chartConfig), }); const commonQueryVariables = { sourceType: dataSource.type, diff --git a/app/components/chart-with-filters.tsx b/app/components/chart-with-filters.tsx index 1d3ab49b2..ca84531b5 100644 --- a/app/components/chart-with-filters.tsx +++ b/app/components/chart-with-filters.tsx @@ -86,6 +86,7 @@ const GenericChart = (props: GenericChartProps) => { chartConfig, dimensions, measures, + componentIris, }); const commonProps = { dataSource, From 8aa3aeedce43b53faaab74c16a9a3294d6a460df Mon Sep 17 00:00:00 2001 From: Bartosz Prusinowski Date: Mon, 29 Jan 2024 09:27:02 +0100 Subject: [PATCH 2/2] chore: Remove unused --- app/charts/shared/chart-helpers.tsx | 36 ----------------------------- 1 file changed, 36 deletions(-) diff --git a/app/charts/shared/chart-helpers.tsx b/app/charts/shared/chart-helpers.tsx index 9676c1088..c6ae4d66e 100644 --- a/app/charts/shared/chart-helpers.tsx +++ b/app/charts/shared/chart-helpers.tsx @@ -119,42 +119,6 @@ export const useQueryFilters = ({ ]); }; -// Handle correctly when improving performance of data fetching! -// const getComponentIris = ( -// cubeIri: string, -// options: { -// dimensions: Dimension[]; -// measures: Measure[]; -// } -// ) => { -// const { dimensions, measures } = options; - -// if (dimensions.length === 0 && measures.length === 0) { -// return; -// } - -// const filteredDimensionIris: string[] = []; - -// for (const dimension of dimensions) { -// if (dimension.isJoinByDimension) { -// if (dimension.originalIris.some((d) => d.cubeIri === cubeIri)) { -// filteredDimensionIris.push( -// ...dimension.originalIris.map((d) => d.dimensionIri) -// ); -// } -// } else { -// if (dimension.cubeIri === cubeIri) { -// filteredDimensionIris.push(dimension.iri); -// } -// } -// } - -// return [ -// ...filteredDimensionIris, -// ...measures.filter((d) => d.cubeIri === cubeIri).map((d) => d.iri), -// ]; -// }; - type IFKey = keyof NonNullable; export const getChartConfigFilterComponentIris = ({ cubes }: ChartConfig) => {