({
data,
columns,
pagination,
paginationOptions,
filters,
onFilterChange,
sorting,
onSortingChange,
}: Props<T>)
| 26 | } |
| 27 | |
| 28 | export default function Table<T extends Record<string, string | number>>({ |
| 29 | data, |
| 30 | columns, |
| 31 | pagination, |
| 32 | paginationOptions, |
| 33 | filters, |
| 34 | onFilterChange, |
| 35 | sorting, |
| 36 | onSortingChange, |
| 37 | }: Props<T>) { |
| 38 | const table = useReactTable({ |
| 39 | data, |
| 40 | columns, |
| 41 | state: { pagination, sorting }, |
| 42 | onSortingChange, |
| 43 | ...paginationOptions, |
| 44 | manualFiltering: true, |
| 45 | manualSorting: true, |
| 46 | manualPagination: true, |
| 47 | getCoreRowModel: getCoreRowModel(), |
| 48 | }) |
| 49 | |
| 50 | return ( |
| 51 | <div> |
| 52 | <table> |
| 53 | <thead> |
| 54 | {table.getHeaderGroups().map(headerGroup => ( |
| 55 | <tr key={headerGroup.id}> |
| 56 | {headerGroup.headers.map(header => { |
| 57 | const fieldMeta = header.column.columnDef.meta |
| 58 | return ( |
| 59 | <th key={header.id} colSpan={header.colSpan}> |
| 60 | {header.isPlaceholder ? null : ( |
| 61 | <> |
| 62 | <div |
| 63 | {...{ |
| 64 | className: header.column.getCanSort() |
| 65 | ? 'cursor-pointer select-none' |
| 66 | : '', |
| 67 | onClick: header.column.getToggleSortingHandler(), |
| 68 | }} |
| 69 | > |
| 70 | {flexRender( |
| 71 | header.column.columnDef.header, |
| 72 | header.getContext() |
| 73 | )} |
| 74 | {{ |
| 75 | asc: ' 🔼', |
| 76 | desc: ' 🔽', |
| 77 | false: ' 🔃', |
| 78 | }[header.column.getIsSorted() as string] ?? null} |
| 79 | </div> |
| 80 | {header.column.getCanFilter() && |
| 81 | fieldMeta?.filterKey !== undefined ? ( |
| 82 | <DebouncedInput |
| 83 | className="w-36 border shadow rounded" |
| 84 | onChange={value => { |
| 85 | onFilterChange({ |
nothing calls this directly
no test coverage detected
searching dependent graphs…