()
| 3 | import { filterRows } from './filterRowsUtils' |
| 4 | |
| 5 | export function getFacetedRowModel<TData extends RowData>(): ( |
| 6 | table: Table<TData>, |
| 7 | columnId: string |
| 8 | ) => () => RowModel<TData> { |
| 9 | return (table, columnId) => |
| 10 | memo( |
| 11 | () => [ |
| 12 | table.getPreFilteredRowModel(), |
| 13 | table.getState().columnFilters, |
| 14 | table.getState().globalFilter, |
| 15 | table.getFilteredRowModel(), |
| 16 | ], |
| 17 | (preRowModel, columnFilters, globalFilter) => { |
| 18 | if ( |
| 19 | !preRowModel.rows.length || |
| 20 | (!columnFilters?.length && !globalFilter) |
| 21 | ) { |
| 22 | return preRowModel |
| 23 | } |
| 24 | |
| 25 | const filterableIds = [ |
| 26 | ...columnFilters.map(d => d.id).filter(d => d !== columnId), |
| 27 | globalFilter ? '__global__' : undefined, |
| 28 | ].filter(Boolean) as string[] |
| 29 | |
| 30 | const filterRowsImpl = (row: Row<TData>) => { |
| 31 | // Horizontally filter rows through each column |
| 32 | for (let i = 0; i < filterableIds.length; i++) { |
| 33 | if (row.columnFilters[filterableIds[i]!] === false) { |
| 34 | return false |
| 35 | } |
| 36 | } |
| 37 | return true |
| 38 | } |
| 39 | |
| 40 | return filterRows(preRowModel.rows, filterRowsImpl, table) |
| 41 | }, |
| 42 | getMemoOptions(table.options, 'debugTable', 'getFacetedRowModel') |
| 43 | ) |
| 44 | } |
no test coverage detected
searching dependent graphs…