diff --git a/src/js/components/Overview/Drawer/ManageChartsDrawer.tsx b/src/js/components/Overview/Drawer/ManageChartsDrawer.tsx index 456f930c..eff27a70 100644 --- a/src/js/components/Overview/Drawer/ManageChartsDrawer.tsx +++ b/src/js/components/Overview/Drawer/ManageChartsDrawer.tsx @@ -1,24 +1,64 @@ import React from 'react'; -import { Drawer, DrawerProps, Typography } from 'antd'; +import { Button, Drawer, DrawerProps, Flex, Space, Typography } from 'antd'; const { Title } = Typography; import ChartTree from './ChartTree'; import { ChartDataField } from '@/types/data'; -import { useAppSelector, useTranslationCustom, useTranslationDefault } from '@/hooks'; +import { useAppSelector, useAppDispatch, useTranslationCustom, useTranslationDefault } from '@/hooks'; +import { hideAllSectionCharts, setAllDisplayedCharts } from '@/features/data/data.store'; const ManageChartsDrawer = ({ onManageDrawerClose, manageDrawerVisible }: ManageChartsDrawerProps) => { const t = useTranslationCustom(); const td = useTranslationDefault(); + const dispatch = useAppDispatch(); + const sections = useAppSelector((state) => state.data.sections); return ( - + { + dispatch(setAllDisplayedCharts({})); + }} + > + Show All + + } + > {sections.map(({ sectionTitle, charts }: { sectionTitle: string; charts: ChartDataField[] }, i: number) => (
- {t(sectionTitle)} + + + {t(sectionTitle)} + + + + + +
))} diff --git a/src/js/features/data/data.store.ts b/src/js/features/data/data.store.ts index 34c697c8..45d3f966 100644 --- a/src/js/features/data/data.store.ts +++ b/src/js/features/data/data.store.ts @@ -47,6 +47,28 @@ const data = createSlice({ const chartObj = state.sections.find((e) => e.sectionTitle === section)!.charts.find((c) => c.id === chart)!; chartObj.width = width; }, + setAllDisplayedCharts: (state, { payload }: PayloadAction<{ section?: string }>) => { + if (payload.section) { + state.sections + .find((e) => e.sectionTitle === payload.section)! + .charts.forEach((_, ind, arr) => { + arr[ind].isDisplayed = true; + }); + } else { + state.sections.forEach((section) => { + section.charts.forEach((val, ind, arr) => { + arr[ind].isDisplayed = true; + }); + }); + } + }, + hideAllSectionCharts: (state, { payload }: PayloadAction<{ section: string }>) => { + state.sections + .find((e) => e.sectionTitle === payload.section)! + .charts.forEach((_, ind, arr) => { + arr[ind].isDisplayed = false; + }); + }, }, extraReducers: (builder) => { builder @@ -64,6 +86,13 @@ const data = createSlice({ }, }); -export const { rearrange, disableChart, setDisplayedCharts, setChartWidth } = data.actions; +export const { + rearrange, + disableChart, + setDisplayedCharts, + setChartWidth, + setAllDisplayedCharts, + hideAllSectionCharts, +} = data.actions; export { makeGetDataRequestThunk }; export default data.reducer;