UNPKG

@adaptabletools/adaptable

Version:

Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements

74 lines (73 loc) 3.02 kB
import * as React from 'react'; import { DataSource, InfiniteTable } from '../../components/InfiniteTable'; import { useAdaptable } from '../AdaptableContext'; const tableDOMProps = { style: { height: '100%', minWidth: '10rem', minHeight: 300, }, }; const columnTypes = { default: { defaultFlex: 1, }, }; export const PivotDetailsPopoup = (props) => { const adaptable = useAdaptable(); const adaptableApi = adaptable.api; const primaryKey = adaptableApi.optionsApi.getPrimaryKey(); const { hasPivotValue, rows, rowGroups, columnId, layout, aggColumn, pivotValue, pivotColumnId, } = props.popupProps; let data = rows; const columns = React.useMemo(() => { const getFriendlyName = (columnId) => adaptableApi.columnApi.getFriendlyNameForColumnId(columnId); const pivotPreviewOptionColumn = adaptableApi.optionsApi.getLayoutOptions()?.pivotPreviewColumns; let pivotPreviewExtraColumns = []; if (typeof pivotPreviewOptionColumn === 'function') { const pivotPreviewColumnsContext = { layout: layout, columnId: columnId, ...adaptableApi.internalApi.buildBaseContext(), }; pivotPreviewExtraColumns = pivotPreviewOptionColumn(pivotPreviewColumnsContext); } else if (Array.isArray(pivotPreviewOptionColumn)) { pivotPreviewExtraColumns = pivotPreviewOptionColumn; } let columns = { [primaryKey]: { field: primaryKey, header: getFriendlyName(primaryKey) }, }; if (hasPivotValue) { // pivot_license_MIT License_stargazers_count // splitting by _ does not work columns = { ...columns, [aggColumn]: { field: aggColumn, header: getFriendlyName(aggColumn) }, [pivotColumnId]: { field: pivotColumnId, header: getFriendlyName(pivotColumnId) }, }; data = rows.filter((row) => row?.[pivotColumnId] === pivotValue); } else { columns = { ...columns, [columnId]: { field: columnId, header: getFriendlyName(columnId) }, }; } const extraColumns = []; if (Array.isArray(rowGroups) && rowGroups.length > 0) { extraColumns.push(...rowGroups); } if (Array.isArray(pivotPreviewExtraColumns) && pivotPreviewExtraColumns.length > 0) { extraColumns.push(...pivotPreviewExtraColumns); } return { ...columns, ...extraColumns.reduce((acc, colId) => ({ ...acc, [colId]: { field: colId, header: getFriendlyName(colId) }, }), {}), }; }, [props.popupProps]); return (React.createElement(DataSource, { data: data, primaryKey: columnId }, React.createElement(InfiniteTable, { columnTypes: columnTypes, domProps: tableDOMProps, columns: columns }))); };