first commit
This commit is contained in:
10
frontend/node_modules/rc-table/es/Header/Header.d.ts
generated
vendored
Normal file
10
frontend/node_modules/rc-table/es/Header/Header.d.ts
generated
vendored
Normal file
@@ -0,0 +1,10 @@
|
||||
import * as React from 'react';
|
||||
import type { ColumnsType, ColumnType, GetComponentProps, StickyOffsets } from '../interface';
|
||||
export interface HeaderProps<RecordType> {
|
||||
columns: ColumnsType<RecordType>;
|
||||
flattenColumns: readonly ColumnType<RecordType>[];
|
||||
stickyOffsets: StickyOffsets;
|
||||
onHeaderRow: GetComponentProps<readonly ColumnType<RecordType>[]>;
|
||||
}
|
||||
declare const _default: <RecordType extends unknown>(props: HeaderProps<RecordType>) => React.JSX.Element;
|
||||
export default _default;
|
||||
95
frontend/node_modules/rc-table/es/Header/Header.js
generated
vendored
Normal file
95
frontend/node_modules/rc-table/es/Header/Header.js
generated
vendored
Normal file
@@ -0,0 +1,95 @@
|
||||
import { useContext } from '@rc-component/context';
|
||||
import * as React from 'react';
|
||||
import TableContext, { responseImmutable } from "../context/TableContext";
|
||||
import devRenderTimes from "../hooks/useRenderTimes";
|
||||
import HeaderRow from "./HeaderRow";
|
||||
function parseHeaderRows(rootColumns) {
|
||||
var rows = [];
|
||||
function fillRowCells(columns, colIndex) {
|
||||
var rowIndex = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
|
||||
// Init rows
|
||||
rows[rowIndex] = rows[rowIndex] || [];
|
||||
var currentColIndex = colIndex;
|
||||
var colSpans = columns.filter(Boolean).map(function (column) {
|
||||
var cell = {
|
||||
key: column.key,
|
||||
className: column.className || '',
|
||||
children: column.title,
|
||||
column: column,
|
||||
colStart: currentColIndex
|
||||
};
|
||||
var colSpan = 1;
|
||||
var subColumns = column.children;
|
||||
if (subColumns && subColumns.length > 0) {
|
||||
colSpan = fillRowCells(subColumns, currentColIndex, rowIndex + 1).reduce(function (total, count) {
|
||||
return total + count;
|
||||
}, 0);
|
||||
cell.hasSubColumns = true;
|
||||
}
|
||||
if ('colSpan' in column) {
|
||||
colSpan = column.colSpan;
|
||||
}
|
||||
if ('rowSpan' in column) {
|
||||
cell.rowSpan = column.rowSpan;
|
||||
}
|
||||
cell.colSpan = colSpan;
|
||||
cell.colEnd = cell.colStart + colSpan - 1;
|
||||
rows[rowIndex].push(cell);
|
||||
currentColIndex += colSpan;
|
||||
return colSpan;
|
||||
});
|
||||
return colSpans;
|
||||
}
|
||||
|
||||
// Generate `rows` cell data
|
||||
fillRowCells(rootColumns, 0);
|
||||
|
||||
// Handle `rowSpan`
|
||||
var rowCount = rows.length;
|
||||
var _loop = function _loop(rowIndex) {
|
||||
rows[rowIndex].forEach(function (cell) {
|
||||
if (!('rowSpan' in cell) && !cell.hasSubColumns) {
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
cell.rowSpan = rowCount - rowIndex;
|
||||
}
|
||||
});
|
||||
};
|
||||
for (var rowIndex = 0; rowIndex < rowCount; rowIndex += 1) {
|
||||
_loop(rowIndex);
|
||||
}
|
||||
return rows;
|
||||
}
|
||||
var Header = function Header(props) {
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
devRenderTimes(props);
|
||||
}
|
||||
var stickyOffsets = props.stickyOffsets,
|
||||
columns = props.columns,
|
||||
flattenColumns = props.flattenColumns,
|
||||
onHeaderRow = props.onHeaderRow;
|
||||
var _useContext = useContext(TableContext, ['prefixCls', 'getComponent']),
|
||||
prefixCls = _useContext.prefixCls,
|
||||
getComponent = _useContext.getComponent;
|
||||
var rows = React.useMemo(function () {
|
||||
return parseHeaderRows(columns);
|
||||
}, [columns]);
|
||||
var WrapperComponent = getComponent(['header', 'wrapper'], 'thead');
|
||||
var trComponent = getComponent(['header', 'row'], 'tr');
|
||||
var thComponent = getComponent(['header', 'cell'], 'th');
|
||||
return /*#__PURE__*/React.createElement(WrapperComponent, {
|
||||
className: "".concat(prefixCls, "-thead")
|
||||
}, rows.map(function (row, rowIndex) {
|
||||
var rowNode = /*#__PURE__*/React.createElement(HeaderRow, {
|
||||
key: rowIndex,
|
||||
flattenColumns: flattenColumns,
|
||||
cells: row,
|
||||
stickyOffsets: stickyOffsets,
|
||||
rowComponent: trComponent,
|
||||
cellComponent: thComponent,
|
||||
onHeaderRow: onHeaderRow,
|
||||
index: rowIndex
|
||||
});
|
||||
return rowNode;
|
||||
}));
|
||||
};
|
||||
export default responseImmutable(Header);
|
||||
16
frontend/node_modules/rc-table/es/Header/HeaderRow.d.ts
generated
vendored
Normal file
16
frontend/node_modules/rc-table/es/Header/HeaderRow.d.ts
generated
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
import * as React from 'react';
|
||||
import type { CellType, ColumnType, CustomizeComponent, GetComponentProps, StickyOffsets } from '../interface';
|
||||
export interface RowProps<RecordType> {
|
||||
cells: readonly CellType<RecordType>[];
|
||||
stickyOffsets: StickyOffsets;
|
||||
flattenColumns: readonly ColumnType<RecordType>[];
|
||||
rowComponent: CustomizeComponent;
|
||||
cellComponent: CustomizeComponent;
|
||||
onHeaderRow: GetComponentProps<readonly ColumnType<RecordType>[]>;
|
||||
index: number;
|
||||
}
|
||||
declare const HeaderRow: {
|
||||
<RecordType extends unknown>(props: RowProps<RecordType>): React.JSX.Element;
|
||||
displayName: string;
|
||||
};
|
||||
export default HeaderRow;
|
||||
51
frontend/node_modules/rc-table/es/Header/HeaderRow.js
generated
vendored
Normal file
51
frontend/node_modules/rc-table/es/Header/HeaderRow.js
generated
vendored
Normal file
@@ -0,0 +1,51 @@
|
||||
import _extends from "@babel/runtime/helpers/esm/extends";
|
||||
import * as React from 'react';
|
||||
import Cell from "../Cell";
|
||||
import TableContext from "../context/TableContext";
|
||||
import { useContext } from '@rc-component/context';
|
||||
import { getCellFixedInfo } from "../utils/fixUtil";
|
||||
import { getColumnsKey } from "../utils/valueUtil";
|
||||
var HeaderRow = function HeaderRow(props) {
|
||||
var cells = props.cells,
|
||||
stickyOffsets = props.stickyOffsets,
|
||||
flattenColumns = props.flattenColumns,
|
||||
RowComponent = props.rowComponent,
|
||||
CellComponent = props.cellComponent,
|
||||
onHeaderRow = props.onHeaderRow,
|
||||
index = props.index;
|
||||
var _useContext = useContext(TableContext, ['prefixCls', 'direction']),
|
||||
prefixCls = _useContext.prefixCls,
|
||||
direction = _useContext.direction;
|
||||
var rowProps;
|
||||
if (onHeaderRow) {
|
||||
rowProps = onHeaderRow(cells.map(function (cell) {
|
||||
return cell.column;
|
||||
}), index);
|
||||
}
|
||||
var columnsKey = getColumnsKey(cells.map(function (cell) {
|
||||
return cell.column;
|
||||
}));
|
||||
return /*#__PURE__*/React.createElement(RowComponent, rowProps, cells.map(function (cell, cellIndex) {
|
||||
var column = cell.column;
|
||||
var fixedInfo = getCellFixedInfo(cell.colStart, cell.colEnd, flattenColumns, stickyOffsets, direction);
|
||||
var additionalProps;
|
||||
if (column && column.onHeaderCell) {
|
||||
additionalProps = cell.column.onHeaderCell(column);
|
||||
}
|
||||
return /*#__PURE__*/React.createElement(Cell, _extends({}, cell, {
|
||||
scope: column.title ? cell.colSpan > 1 ? 'colgroup' : 'col' : null,
|
||||
ellipsis: column.ellipsis,
|
||||
align: column.align,
|
||||
component: CellComponent,
|
||||
prefixCls: prefixCls,
|
||||
key: columnsKey[cellIndex]
|
||||
}, fixedInfo, {
|
||||
additionalProps: additionalProps,
|
||||
rowType: "header"
|
||||
}));
|
||||
}));
|
||||
};
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
HeaderRow.displayName = 'HeaderRow';
|
||||
}
|
||||
export default HeaderRow;
|
||||
Reference in New Issue
Block a user