@cn-ui/table-core
Version:
Headless UI for building powerful tables & datagrids for TS/JS.
83 lines (72 loc) • 2.35 kB
text/typescript
import { createRow } from '../core/row'
import { Table, Row, RowModel, RowData } from '../types'
import { getMemoOptions, memo } from '../utils'
export function getCoreRowModel<TData extends RowData>(): (
table: Table<TData>
) => () => RowModel<TData> {
return table =>
memo(
() => [table.options.data],
(
data
): {
rows: Row<TData>[]
flatRows: Row<TData>[]
rowsById: Record<string, Row<TData>>
} => {
const rowModel: RowModel<TData> = {
rows: [],
flatRows: [],
rowsById: {},
}
const accessRows = (
originalRows: TData[],
depth = 0,
parentRow?: Row<TData>
): Row<TData>[] => {
const rows = [] as Row<TData>[]
for (let i = 0; i < originalRows.length; i++) {
// This could be an expensive check at scale, so we should move it somewhere else, but where?
// if (!id) {
// if (process.env.NODE_ENV !== 'production') {
// throw new Error(`getRowId expected an ID, but got ${id}`)
// }
// }
// Make the row
const row = createRow(
table,
table._getRowId(originalRows[i]!, i, parentRow),
originalRows[i]!,
i,
depth,
undefined,
parentRow?.id
)
// Keep track of every row in a flat array
rowModel.flatRows.push(row)
// Also keep track of every row by its ID
rowModel.rowsById[row.id] = row
// Push table row into parent
rows.push(row)
// Get the original subrows
if (table.options.getSubRows) {
row.originalSubRows = table.options.getSubRows(
originalRows[i]!,
i
)
// Then recursively access them
if (row.originalSubRows?.length) {
row.subRows = accessRows(row.originalSubRows, depth + 1, row)
}
}
}
return rows
}
rowModel.rows = accessRows(data)
return rowModel
},
getMemoOptions(table.options, 'debugTable', 'getRowModel', () =>
table._autoResetPageIndex()
)
)
}