From a1bed8fae7f940561c007ef3d0f23ae9fee6a152 Mon Sep 17 00:00:00 2001 From: David Inga Date: Tue, 19 Mar 2024 09:06:46 +0100 Subject: [PATCH] fixed total number of suppliers --- client/next.config.js | 14 ++++++++++++-- .../supplier-list-table/table/index.tsx | 8 ++++++-- .../suppliers-stacked-bar/component.tsx | 3 ++- client/src/store/features/eudr/index.ts | 7 +++++++ 4 files changed, 27 insertions(+), 5 deletions(-) diff --git a/client/next.config.js b/client/next.config.js index 49f73d605..db7532e5d 100644 --- a/client/next.config.js +++ b/client/next.config.js @@ -8,12 +8,22 @@ const nextConfig = { return [ { source: '/', - destination: '/analysis/map', + destination: '/eurd', permanent: false, }, { source: '/analysis', - destination: '/analysis/map', + destination: '/eudr', + permanent: false, + }, + { + source: '/analysis/:id', + destination: '/eudr', + permanent: false, + }, + { + source: '/data', + destination: '/eurd', permanent: false, }, { diff --git a/client/src/containers/analysis-eudr/supplier-list-table/table/index.tsx b/client/src/containers/analysis-eudr/supplier-list-table/table/index.tsx index 787c688d3..17cbff20e 100644 --- a/client/src/containers/analysis-eudr/supplier-list-table/table/index.tsx +++ b/client/src/containers/analysis-eudr/supplier-list-table/table/index.tsx @@ -22,8 +22,8 @@ import { TableCell, } from '@/components/ui/table'; import { useEUDRData } from '@/hooks/eudr'; -import { useAppSelector } from '@/store/hooks'; -import { eudr } from '@/store/features/eudr'; +import { useAppSelector, useAppDispatch } from '@/store/hooks'; +import { eudr, setTotalSuppliers } from '@/store/features/eudr'; import type { // ColumnFiltersState, @@ -50,6 +50,7 @@ export interface Supplier { } const SuppliersListTable = (): JSX.Element => { + const dispatch = useAppDispatch(); // const [rowSelection, setRowSelection] = useState({}); // const [columnVisibility, setColumnVisibility] = useState({}); // const [columnFilters, setColumnFilters] = useState([]); @@ -68,6 +69,9 @@ const SuppliersListTable = (): JSX.Element => { }, { select: (data) => data?.table, + onSuccess: (data) => { + dispatch(setTotalSuppliers(data?.length || 0)); + }, }, ); diff --git a/client/src/containers/analysis-eudr/suppliers-stacked-bar/component.tsx b/client/src/containers/analysis-eudr/suppliers-stacked-bar/component.tsx index 329496f90..ea0c2cd26 100644 --- a/client/src/containers/analysis-eudr/suppliers-stacked-bar/component.tsx +++ b/client/src/containers/analysis-eudr/suppliers-stacked-bar/component.tsx @@ -38,6 +38,7 @@ const TOOLTIP_LABELS = { const SuppliersStackedBar = () => { const { viewBy, + totalSuppliers, filters: { dates, suppliers, origins, materials }, } = useAppSelector(eudr); const dispatch = useAppDispatch(); @@ -92,7 +93,7 @@ const SuppliersStackedBar = () => {
- Total numbers of suppliers: {parsedData?.length || '-'} + Total numbers of suppliers: {totalSuppliers}

Suppliers by category

diff --git a/client/src/store/features/eudr/index.ts b/client/src/store/features/eudr/index.ts index 82b3b0410..a7e26b46c 100644 --- a/client/src/store/features/eudr/index.ts +++ b/client/src/store/features/eudr/index.ts @@ -19,6 +19,7 @@ type LayerConfiguration = { export type EUDRState = { viewBy: (typeof VIEW_BY_OPTIONS)[number]['value']; + totalSuppliers: number; filters: { materials: Option[]; origins: Option[]; @@ -39,6 +40,7 @@ export type EUDRState = { export const initialState: EUDRState = { viewBy: 'materials', + totalSuppliers: 0, filters: { materials: [], origins: [], @@ -91,6 +93,10 @@ export const EUDRSlice = createSlice({ ...state, viewBy: action.payload, }), + setTotalSuppliers: (state, action: PayloadAction) => ({ + ...state, + totalSuppliers: action.payload, + }), setFilters: (state, action: PayloadAction>) => ({ ...state, filters: { @@ -141,6 +147,7 @@ export const EUDRSlice = createSlice({ export const { setViewBy, + setTotalSuppliers, setFilters, setBasemap, setSupplierLayer,