From aba0d83511f9b3227c4fc55a62f71d2743ea2c68 Mon Sep 17 00:00:00 2001 From: Samir Kamal <1954121+skamril@users.noreply.github.com> Date: Mon, 25 Mar 2024 13:34:01 +0100 Subject: [PATCH] refactor(common-ui,clusters-ui): add `fillPendingRow` prop in GroupedDataTable and update cluster views --- .../Modelization/Areas/Renewables/index.tsx | 7 ++++- .../Modelization/Areas/Thermal/index.tsx | 7 ++++- .../common/{utils.ts => clustersUtils.ts} | 22 ++++----------- .../common/GroupedDataTable/index.tsx | 28 ++++++++++++------- 4 files changed, 35 insertions(+), 29 deletions(-) rename webapp/src/components/App/Singlestudy/explore/Modelization/Areas/common/{utils.ts => clustersUtils.ts} (87%) diff --git a/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Renewables/index.tsx b/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Renewables/index.tsx index 1e1055aa66..9c178ff914 100644 --- a/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Renewables/index.tsx +++ b/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Renewables/index.tsx @@ -21,7 +21,7 @@ import { addCapacity, capacityAggregationFn, useClusterDataWithCapacity, -} from "../common/utils"; +} from "../common/clustersUtils"; import { TRow } from "../../../../../../common/GroupedDataTable/types"; function Renewables() { @@ -154,6 +154,11 @@ function Renewables() { deleteConfirmationMessage={(count) => t("studies.modelization.clusters.question.delete", { count }) } + fillPendingRow={(row) => ({ + ...row, + enabledCapacity: 0, + installedCapacity: 0, + })} /> ); } diff --git a/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Thermal/index.tsx b/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Thermal/index.tsx index f7742c30c9..fac54effc7 100644 --- a/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Thermal/index.tsx +++ b/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/Thermal/index.tsx @@ -21,7 +21,7 @@ import { addCapacity, capacityAggregationFn, useClusterDataWithCapacity, -} from "../common/utils"; +} from "../common/clustersUtils"; import { TRow } from "../../../../../../common/GroupedDataTable/types"; function Thermal() { @@ -168,6 +168,11 @@ function Thermal() { deleteConfirmationMessage={(count) => t("studies.modelization.clusters.question.delete", { count }) } + fillPendingRow={(row) => ({ + ...row, + enabledCapacity: 0, + installedCapacity: 0, + })} /> ); } diff --git a/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/common/utils.ts b/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/common/clustersUtils.ts similarity index 87% rename from webapp/src/components/App/Singlestudy/explore/Modelization/Areas/common/utils.ts rename to webapp/src/components/App/Singlestudy/explore/Modelization/Areas/common/clustersUtils.ts index 95169a6f77..fee87bfc9f 100644 --- a/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/common/utils.ts +++ b/webapp/src/components/App/Singlestudy/explore/Modelization/Areas/common/clustersUtils.ts @@ -1,22 +1,9 @@ import { DependencyList, useMemo } from "react"; -import * as R from "ramda"; import { MRT_AggregationFn } from "material-react-table"; -import { StudyMetadata } from "../../../../../../../common/types"; -import { editStudy } from "../../../../../../../services/api/study"; import { ThermalClusterWithCapacity } from "../Thermal/utils"; import { RenewableClusterWithCapacity } from "../Renewables/utils"; import usePromiseWithSnackbarError from "../../../../../../../hooks/usePromiseWithSnackbarError"; -export const saveField = R.curry( - ( - studyId: StudyMetadata["id"], - path: string, - data: Record, - ): Promise => { - return editStudy(data, studyId, path); - }, -); - /** * Custom aggregation function summing the values of each row, * to display enabled and installed capacity in the same cell. This function is @@ -33,11 +20,12 @@ export const saveField = R.curry( export const capacityAggregationFn = < T extends ThermalClusterWithCapacity | RenewableClusterWithCapacity, >(): MRT_AggregationFn => { - return (_colHeader, rows) => { - const { enabledCapacitySum, installedCapacitySum } = rows.reduce( + return (columnId, leafRows) => { + const { enabledCapacitySum, installedCapacitySum } = leafRows.reduce( (acc, row) => { - acc.enabledCapacitySum += row.original.enabledCapacity ?? 0; - acc.installedCapacitySum += row.original.installedCapacity ?? 0; + acc.enabledCapacitySum += row.original.enabledCapacity; + acc.installedCapacitySum += row.original.installedCapacity; + return acc; }, { enabledCapacitySum: 0, installedCapacitySum: 0 }, diff --git a/webapp/src/components/common/GroupedDataTable/index.tsx b/webapp/src/components/common/GroupedDataTable/index.tsx index c52aae1c5b..d74ad143b7 100644 --- a/webapp/src/components/common/GroupedDataTable/index.tsx +++ b/webapp/src/components/common/GroupedDataTable/index.tsx @@ -45,6 +45,9 @@ export interface GroupedDataTableProps< onNameClick?: (row: MRT_Row) => void; isLoading?: boolean; deleteConfirmationMessage?: string | ((count: number) => string); + fillPendingRow?: ( + pendingRow: TRow, + ) => TRow & Partial; } // Use ids to identify default columns (instead of `accessorKey`), @@ -66,6 +69,7 @@ function GroupedDataTable< onNameClick, isLoading, deleteConfirmationMessage, + fillPendingRow, }: GroupedDataTableProps) { const { t } = useTranslation(); const [openDialog, setOpenDialog] = useState< @@ -273,14 +277,18 @@ function GroupedDataTable< //////////////////////////////////////////////////////////////// const addPendingRow = (row: TRow) => { - pendingRows.current.push(row); + const pendingRow = fillPendingRow?.(row) || row; + + pendingRows.current.push(pendingRow); + // Type can be asserted as `TData` because the row will be checked in cell renders - setTableData((prev) => [...prev, row as TData]); - }; + // and `fillPendingRow` allows to add needed data + setTableData((prev) => [...prev, pendingRow as TData]); - const removePendingRow = (row: TRow) => { - pendingRows.current = pendingRows.current.filter((r) => r !== row); - setTableData((prev) => prev.filter((r) => r !== row)); + return function removePendingRow() { + pendingRows.current = pendingRows.current.filter((r) => r !== pendingRow); + setTableData((prev) => prev.filter((r) => r !== pendingRow)); + }; }; function isPendingRow(row: TData) { @@ -305,7 +313,7 @@ function GroupedDataTable< } createOps.increment(); - addPendingRow(values); + const removePendingRow = addPendingRow(values); try { const newRow = await onCreate(values); @@ -314,7 +322,7 @@ function GroupedDataTable< enqueueErrorSnackbar(t("global.error.createFailed"), toError(error)); } - removePendingRow(values); + removePendingRow(); createOps.decrement(); }; @@ -333,7 +341,7 @@ function GroupedDataTable< }; createOps.increment(); - addPendingRow(duplicatedRow); + const removePendingRow = addPendingRow(duplicatedRow); try { const newRow = await onDuplicate(selectedRow, newName); @@ -342,7 +350,7 @@ function GroupedDataTable< enqueueErrorSnackbar(t("global.error.createFailed"), toError(error)); } - removePendingRow(duplicatedRow); + removePendingRow(); createOps.decrement(); };