From 91ade35b8c310929a010a7255ad98d7104e35da1 Mon Sep 17 00:00:00 2001 From: Edoardo Sabadelli Date: Wed, 20 Dec 2023 15:42:51 +0100 Subject: [PATCH] feat: add plugin component for outliers table (DHIS2-16356) --- .../OutliersTablePlugin.js | 90 ++++++++++++++++++ .../VisualizationPlugin.js | 91 ++++++++++++------- 2 files changed, 147 insertions(+), 34 deletions(-) create mode 100644 src/components/VisualizationPlugin/OutliersTablePlugin.js diff --git a/src/components/VisualizationPlugin/OutliersTablePlugin.js b/src/components/VisualizationPlugin/OutliersTablePlugin.js new file mode 100644 index 0000000000..9ecb867067 --- /dev/null +++ b/src/components/VisualizationPlugin/OutliersTablePlugin.js @@ -0,0 +1,90 @@ +import { + DataTable, + DataTableBody, + DataTableCell, + DataTableColumnHeader, + DataTableHead, + DataTableRow, +} from '@dhis2/ui' +import PropTypes from 'prop-types' +import React from 'react' + +const OutliersTablePlugin = ({ + responses, + // XXX needed? + //legendSets, + //visualization, + style, + //id: renderCounter, + //onToggleContextualMenu, +}) => { + const data = responses[0] + + const renderCellContent = ({ columnIndex, value }) => ( + {value} + ) + + return ( + // + // +
+ + + + {data.headers.map((header) => ( + + {header.name} + + ))} + + + {/* https://jira.dhis2.org/browse/LIBS-278 */} + + {data.rows.map((row, rowIndex) => ( + + {row.map((value, columnIndex) => + renderCellContent({ + columnIndex, + value, + }) + )} + + ))} + + +
+ ) +} + +OutliersTablePlugin.defaultProps = { + style: {}, +} + +OutliersTablePlugin.propTypes = { + // legendSets: PropTypes.arrayOf(PropTypes.object).isRequired, + responses: PropTypes.arrayOf(PropTypes.object).isRequired, + // visualization: PropTypes.object.isRequired, + // id: PropTypes.number, + style: PropTypes.object, + // onToggleContextualMenu: PropTypes.func, +} + +export default OutliersTablePlugin diff --git a/src/components/VisualizationPlugin/VisualizationPlugin.js b/src/components/VisualizationPlugin/VisualizationPlugin.js index 5875e674ae..101c9bd02b 100644 --- a/src/components/VisualizationPlugin/VisualizationPlugin.js +++ b/src/components/VisualizationPlugin/VisualizationPlugin.js @@ -1,4 +1,5 @@ import { + VIS_TYPE_OUTLIERS_TABLE, VIS_TYPE_PIVOT_TABLE, apiFetchOrganisationUnitLevels, convertOuLevelsToUids, @@ -22,6 +23,7 @@ import { fetchData } from '../../modules/fetchData.js' import { getOptionsFromVisualization } from '../../modules/options.js' import ChartPlugin from './ChartPlugin.js' import ContextualMenu from './ContextualMenu.js' +import OutliersTablePlugin from './OutliersTablePlugin.js' import PivotPlugin from './PivotPlugin.js' import styles from './styles/VisualizationPlugin.module.css' @@ -384,42 +386,63 @@ export const VisualizationPlugin = ({ } } + const renderPlugin = () => { + if ( + !fetchResult.visualization.type || + fetchResult.visualization.type === VIS_TYPE_PIVOT_TABLE + ) { + return ( + + ) + } else if (fetchResult.visualization.type === VIS_TYPE_OUTLIERS_TABLE) { + return ( + + ) + } else { + return ( + + ) + } + } + return (
-
- {!fetchResult.visualization.type || - fetchResult.visualization.type === VIS_TYPE_PIVOT_TABLE ? ( - - ) : ( - - )} -
+
{renderPlugin()}
{getLegendKey()} {contextualMenuRect && (