UNPKG

@netdata/netdata-ui

Version:

netdata UI kit

90 lines 3.25 kB
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } import { useMemo } from "react"; import useRowSelection from "./useRowSelection"; import useRowActions from "./useRowActions"; export default (function (dataColumns, _ref) { var rowActions = _ref.rowActions, enableSelection = _ref.enableSelection, singleRowSelection = _ref.singleRowSelection, enableResizing = _ref.enableResizing, enableSorting = _ref.enableSorting, testPrefix = _ref.testPrefix, tableMeta = _ref.tableMeta; var rowActionsColumn = useRowActions(rowActions, { testPrefix: testPrefix, tableMeta: tableMeta }); var selectionColumn = useRowSelection(enableSelection, { testPrefix: testPrefix, tableMeta: tableMeta, singleRowSelection: singleRowSelection }); return useMemo(function () { if (!dataColumns || dataColumns.length < 1) return []; var isGrouped = false; dataColumns = dataColumns.map(function (col, index) { if (Array.isArray(col.columns)) { isGrouped = true; return _extends({ id: index }, col, { columns: col.columns.map(function (subCol, index) { if (!subCol.id) throw new Error("Please provide id at " + index); return _extends({ enableColumnFilter: false, enableGlobalFilter: true, enableSorting: enableSorting, enableMultiSort: enableSorting }, enableResizing ? { size: 120, maxSize: 5000, minSize: 60 } : {}, { enableHiding: true, enableResizing: enableResizing, footer: function footer(props) { return props.column.id; }, tableMeta: tableMeta }, subCol, { accessorKey: subCol.accessorKey || subCol.id }); }) }); } if (!col.id) throw new Error("Please provide id at " + index); return _extends({ enableColumnFilter: false, enableGlobalFilter: true, enableSorting: enableSorting, enableMultiSort: enableSorting }, enableResizing ? { size: 120, maxSize: 5000, minSize: 10 } : {}, { enableHiding: true, enableResizing: enableResizing, footer: function footer(props) { return props.column.id; }, tableMeta: tableMeta }, col, { accessorKey: col.accessorKey || col.id }); }); if (selectionColumn) dataColumns.unshift(isGrouped ? { id: "selectionColumn", isPlaceholder: true, size: selectionColumn.size, columns: [selectionColumn] } : selectionColumn); if (rowActionsColumn) dataColumns.push(isGrouped ? { id: "rowActionsColumn", isPlaceholder: true, size: rowActionsColumn.size, columns: [rowActionsColumn] } : rowActionsColumn); return dataColumns; }, [dataColumns, rowActionsColumn, selectionColumn]); });