Skip to content

Commit

Permalink
refactor: Use DataCubeMetadata + Components queries
Browse files Browse the repository at this point in the history
  • Loading branch information
bprusinowski committed Apr 13, 2023
1 parent c1cbf7a commit a8b5bac
Show file tree
Hide file tree
Showing 18 changed files with 159 additions and 217 deletions.
30 changes: 16 additions & 14 deletions app/charts/index.spec.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { TableFields } from "@/configurator";
import { DataCubeMetadataWithComponentValuesQuery } from "@/graphql/query-hooks";
import { DataCubeMetadata } from "@/graphql/types";
import { ComponentsQuery } from "@/graphql/query-hooks";

import bathingWaterData from "../test/__fixtures/data/DataCubeMetadataWithComponentValues-bathingWater.json";
import forestAreaData from "../test/__fixtures/data/forest-area-by-production-region.json";
Expand All @@ -12,10 +11,10 @@ describe("initial config", () => {
const config = getInitialConfig({
chartType: "table",
dimensions: forestAreaData.data.dataCubeByIri.dimensions as NonNullable<
DataCubeMetadataWithComponentValuesQuery["dataCubeByIri"]
ComponentsQuery["dataCubeByIri"]
>["dimensions"],
measures: forestAreaData.data.dataCubeByIri.measures as NonNullable<
DataCubeMetadataWithComponentValuesQuery["dataCubeByIri"]
ComponentsQuery["dataCubeByIri"]
>["measures"],
});
expect(
Expand All @@ -40,28 +39,31 @@ describe("possible chart types", () => {
it("should allow appropriate chart types based on available dimensions", () => {
const expectedChartTypes = ["area", "column", "line", "pie", "table"];
const possibleChartTypes = getPossibleChartType({
metadata: bathingWaterData.data.dataCubeByIri as DataCubeMetadata,
dimensions: bathingWaterData.data.dataCubeByIri.dimensions as NonNullable<
ComponentsQuery["dataCubeByIri"]
>["dimensions"],
measures: bathingWaterData.data.dataCubeByIri.measures as NonNullable<
ComponentsQuery["dataCubeByIri"]
>["measures"],
}).sort();

expect(possibleChartTypes).toEqual(expectedChartTypes);
});

it("should only allow table if there are only measures available", () => {
const metadata = {
const possibleChartTypes = getPossibleChartType({
dimensions: [],
measures: [{ __typename: "NumericalMeasure" }],
} as any;
const possibleChartTypes = getPossibleChartType({ metadata }).sort();
measures: [{ __typename: "NumericalMeasure" }] as any,
});

expect(possibleChartTypes).toEqual(["table"]);
});

it("should only allow column, map, pie and table if only geo dimensions are available", () => {
const metadata = {
dimensions: [{ __typename: "GeoShapesDimension" }],
measures: [{ __typename: "NumericalMeasure" }],
} as any;
const possibleChartTypes = getPossibleChartType({ metadata }).sort();
const possibleChartTypes = getPossibleChartType({
dimensions: [{ __typename: "GeoShapesDimension" }] as any,
measures: [{ __typename: "NumericalMeasure" }] as any,
}).sort();

expect(possibleChartTypes).toEqual(["column", "map", "pie", "table"]);
});
Expand Down
8 changes: 4 additions & 4 deletions app/charts/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1108,12 +1108,12 @@ const adjustSegmentSorting = ({

// Helpers
export const getPossibleChartType = ({
metadata,
dimensions,
measures,
}: {
metadata: DataCubeMetadata;
dimensions: DimensionMetadataFragment[];
measures: DimensionMetadataFragment[];
}): ChartType[] => {
const { measures, dimensions } = metadata;

const numericalMeasures = measures.filter(isNumericalMeasure);
const ordinalMeasures = measures.filter(isOrdinalMeasure);
const categoricalDimensions = getCategoricalDimensions(dimensions);
Expand Down
4 changes: 2 additions & 2 deletions app/components/chart-filters-list.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { OpenMetadataPanelWrapper } from "@/components/metadata-panel";
import { ChartConfig, DataSource } from "@/configurator";
import { isTemporalDimension } from "@/domain/data";
import { useTimeFormatUnit } from "@/formatters";
import { useDataCubeMetadataWithComponentValuesQuery } from "@/graphql/query-hooks";
import { useComponentsQuery } from "@/graphql/query-hooks";
import { useLocale } from "@/locales/use-locale";

export const ChartFiltersList = ({
Expand All @@ -21,7 +21,7 @@ export const ChartFiltersList = ({
const locale = useLocale();
const timeFormatUnit = useTimeFormatUnit();

const [{ data }] = useDataCubeMetadataWithComponentValuesQuery({
const [{ data }] = useComponentsQuery({
variables: {
iri: dataSetIri,
sourceType: dataSource.type,
Expand Down
32 changes: 22 additions & 10 deletions app/components/chart-preview.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,8 @@ import { MetadataPanel } from "@/components/metadata-panel";
import { ChartConfig, DataSource, useConfiguratorState } from "@/configurator";
import { DataSetTable } from "@/configurator/components/datatable";
import {
DimensionMetadataFragment,
useDataCubeMetadataWithComponentValuesQuery,
useComponentsQuery,
useDataCubeMetadataQuery,
} from "@/graphql/query-hooks";
import { DataCubePublicationStatus } from "@/graphql/resolver-types";
import { useLocale } from "@/locales/use-locale";
Expand Down Expand Up @@ -72,7 +72,15 @@ export const ChartPreviewInner = ({
const [state, dispatch] = useConfiguratorState();
const locale = useLocale();
const classes = useStyles();
const [{ data: metaData }] = useDataCubeMetadataWithComponentValuesQuery({
const [{ data: metadata }] = useDataCubeMetadataQuery({
variables: {
iri: dataSetIri,
sourceType: dataSource.type,
sourceUrl: dataSource.url,
locale,
},
});
const [{ data: components }] = useComponentsQuery({
variables: {
iri: dataSetIri,
sourceType: dataSource.type,
Expand All @@ -89,12 +97,16 @@ export const ChartPreviewInner = ({

const handleToggleTableView = useEvent(() => setIsTablePreview((c) => !c));

const allDimensions: DimensionMetadataFragment[] = useMemo(() => {
const allComponents = useMemo(() => {
if (!components?.dataCubeByIri) {
return [];
}

return [
...(metaData?.dataCubeByIri?.dimensions ?? []),
...(metaData?.dataCubeByIri?.measures ?? []),
...components.dataCubeByIri.dimensions,
...components.dataCubeByIri.measures,
];
}, [metaData?.dataCubeByIri?.dimensions, metaData?.dataCubeByIri?.measures]);
}, [components?.dataCubeByIri]);

return (
<Flex
Expand All @@ -108,7 +120,7 @@ export const ChartPreviewInner = ({
}}
>
<ChartErrorBoundary resetKeys={[state]}>
{metaData?.dataCubeByIri?.publicationStatus ===
{metadata?.dataCubeByIri?.publicationStatus ===
DataCubePublicationStatus.Draft && (
<Box sx={{ mb: 4 }}>
<HintYellow iconName="datasetError" iconSize={64}>
Expand Down Expand Up @@ -154,14 +166,14 @@ export const ChartPreviewInner = ({
<MetadataPanel
datasetIri={dataSetIri}
dataSource={dataSource}
dimensions={allDimensions}
dimensions={allComponents}
top={96}
/>
</Flex>
<Head>
<title key="title">
{state.meta.title[locale] === ""
? metaData?.dataCubeByIri?.title
? metadata?.dataCubeByIri?.title
: state.meta.title[locale]}{" "}
- visualize.admin.ch
</title>
Expand Down
32 changes: 22 additions & 10 deletions app/components/chart-published.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,8 @@ import {
useIsTrustedDataSource,
} from "@/domain/datasource";
import {
DimensionMetadataFragment,
useDataCubeMetadataWithComponentValuesQuery,
useComponentsQuery,
useDataCubeMetadataQuery,
} from "@/graphql/query-hooks";
import { DataCubePublicationStatus } from "@/graphql/resolver-types";
import { useLocale } from "@/locales/use-locale";
Expand Down Expand Up @@ -139,7 +139,15 @@ export const ChartPublishedInner = ({
const locale = useLocale();
const isTrustedDataSource = useIsTrustedDataSource(dataSource);

const [{ data: metaData }] = useDataCubeMetadataWithComponentValuesQuery({
const [{ data: metadata }] = useDataCubeMetadataQuery({
variables: {
iri: dataSet,
sourceType: dataSource.type,
sourceUrl: dataSource.url,
locale,
},
});
const [{ data: components }] = useComponentsQuery({
variables: {
iri: dataSet,
sourceType: dataSource.type,
Expand All @@ -157,20 +165,24 @@ export const ChartPublishedInner = ({
}, [chartConfig, dataSource]);
const handleToggleTableView = useEvent(() => setIsTablePreview((c) => !c));

const allDimensions: DimensionMetadataFragment[] = useMemo(() => {
const allComponents = useMemo(() => {
if (!components?.dataCubeByIri) {
return [];
}

return [
...(metaData?.dataCubeByIri?.dimensions ?? []),
...(metaData?.dataCubeByIri?.measures ?? []),
...components.dataCubeByIri.dimensions,
...components.dataCubeByIri.measures,
];
}, [metaData?.dataCubeByIri?.dimensions, metaData?.dataCubeByIri?.measures]);
}, [components?.dataCubeByIri]);

const [{ showDownload }] = useEmbedOptions();

return (
<MetadataPanelStoreContext.Provider value={metadataPanelStore}>
<Box className={classes.root} ref={rootRef}>
<ChartErrorBoundary resetKeys={[chartConfig]}>
{metaData?.dataCubeByIri?.publicationStatus ===
{metadata?.dataCubeByIri?.publicationStatus ===
DataCubePublicationStatus.Draft && (
<Box sx={{ mb: 4 }}>
<HintRed iconName="datasetError" iconSize={64}>
Expand All @@ -182,7 +194,7 @@ export const ChartPublishedInner = ({
</HintRed>
</Box>
)}
{metaData?.dataCubeByIri?.expires && (
{metadata?.dataCubeByIri?.expires && (
<Box sx={{ mb: 4 }}>
<HintRed iconName="datasetError" iconSize={64}>
<Trans id="dataset.publicationStatus.expires.warning">
Expand Down Expand Up @@ -220,7 +232,7 @@ export const ChartPublishedInner = ({
<MetadataPanel
datasetIri={dataSet}
dataSource={dataSource}
dimensions={allDimensions}
dimensions={allComponents}
container={rootRef.current}
/>
</Flex>
Expand Down
29 changes: 22 additions & 7 deletions app/components/chart-selection-tabs.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import { Trans } from "@lingui/macro";
import { Box, Popover, Tab, Tabs, Theme, Button } from "@mui/material";
import { Box, Button, Popover, Tab, Tabs, Theme } from "@mui/material";
import { makeStyles } from "@mui/styles";
import React, {
createContext,
Dispatch,
ReactNode,
createContext,
useContext,
useEffect,
useState,
Expand All @@ -18,7 +18,10 @@ import {
} from "@/configurator";
import { ChartTypeSelector } from "@/configurator/components/chart-type-selector";
import { getIconName } from "@/configurator/components/ui-helpers";
import { useDataCubeMetadataWithComponentValuesQuery } from "@/graphql/query-hooks";
import {
useComponentsQuery,
useDataCubeMetadataQuery,
} from "@/graphql/query-hooks";
import { Icon, IconName } from "@/icons";
import { useLocale } from "@/src";
import useEvent from "@/utils/use-event";
Expand Down Expand Up @@ -155,7 +158,16 @@ const PublishChartButton = () => {
| ConfiguratorStatePublishing
| ConfiguratorStateConfiguringChart;
const locale = useLocale();
const [{ data }] = useDataCubeMetadataWithComponentValuesQuery({
const [{ data: metadata }] = useDataCubeMetadataQuery({
variables: {
iri: dataSetIri ?? "",
sourceType: state.dataSource.type,
sourceUrl: state.dataSource.url,
locale,
},
pause: !dataSetIri,
});
const [{ data: components }] = useComponentsQuery({
variables: {
iri: dataSetIri ?? "",
sourceType: state.dataSource.type,
Expand All @@ -165,10 +177,13 @@ const PublishChartButton = () => {
pause: !dataSetIri,
});
const goNext = useEvent(() => {
if (data?.dataCubeByIri) {
if (metadata?.dataCubeByIri && components?.dataCubeByIri) {
dispatch({
type: "STEP_NEXT",
dataSetMetadata: data?.dataCubeByIri,
dataSetMetadata: {
...metadata.dataCubeByIri,
...components.dataCubeByIri,
},
});
}
});
Expand All @@ -177,7 +192,7 @@ const PublishChartButton = () => {
<Button
color="primary"
variant="contained"
onClick={data ? goNext : undefined}
onClick={metadata && components ? goNext : undefined}
>
<Trans id="button.publish">Publish the chart</Trans>
</Button>
Expand Down
5 changes: 1 addition & 4 deletions app/configurator/components/chart-configurator.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,6 @@ import {
} from "@/configurator/configurator-state";
import { isStandardErrorDimension, isTemporalDimension } from "@/domain/data";
import {
DataCubeMetadataWithComponentValuesQuery,
HierarchyValue,
PossibleFiltersDocument,
PossibleFiltersQuery,
Expand Down Expand Up @@ -266,9 +265,7 @@ const useEnsurePossibleFilters = ({
};

type Dimension = NonNullable<
NonNullable<
DataCubeMetadataWithComponentValuesQuery["dataCubeByIri"]
>["dimensions"]
NonNullable<DataCubeMetadata>["dimensions"]
>[number];

const useFilterReorder = ({
Expand Down
12 changes: 7 additions & 5 deletions app/configurator/components/chart-type-selector.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { ControlSectionSkeleton } from "@/configurator/components/chart-controls
import { getFieldLabel } from "@/configurator/components/field-i18n";
import { getIconName } from "@/configurator/components/ui-helpers";
import { FieldProps, useChartType } from "@/configurator/config-form";
import { useDataCubeMetadataWithComponentValuesQuery } from "@/graphql/query-hooks";
import { useComponentsQuery } from "@/graphql/query-hooks";
import { Icon } from "@/icons";
import { useLocale } from "@/locales/use-locale";

Expand Down Expand Up @@ -109,21 +109,23 @@ export const ChartTypeSelector = ({
} & BoxProps) => {
const locale = useLocale();
const { value: chartType, onChange: onChangeChartType } = useChartType();
const [{ data }] = useDataCubeMetadataWithComponentValuesQuery({
const [{ data }] = useComponentsQuery({
variables: {
iri: state.dataSet,
sourceType: state.dataSource.type,
sourceUrl: state.dataSource.url,
locale,
},
});
const metadata = data?.dataCubeByIri;

if (!metadata) {
if (!data?.dataCubeByIri) {
return <ControlSectionSkeleton />;
}

const possibleChartTypes = getPossibleChartType({ metadata });
const possibleChartTypes = getPossibleChartType({
dimensions: data.dataCubeByIri.dimensions,
measures: data.dataCubeByIri.measures,
});

return (
<Box sx={sx} {...props}>
Expand Down
Loading

0 comments on commit a8b5bac

Please sign in to comment.