import { type ColumnFiltersState, flexRender, getCoreRowModel, getFilteredRowModel, getPaginationRowModel, getSortedRowModel, type SortingState, useReactTable, } from "@tanstack/react-table"; import React, { useState } from "react"; import { Button } from "../../components/ui/button"; import { ScrollArea, ScrollBar } from "../../components/ui/scroll-area"; import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow, } from "../../components/ui/table"; import { cn } from "../utils"; type LstTableType = { className?: string; tableClassName?: string; data: any; columns: any; }; export default function LstTable({ className = "", tableClassName = "", data, columns, }: LstTableType) { const [sorting, setSorting] = useState([]); const [columnFilters, setColumnFilters] = useState([]); //console.log(data); const table = useReactTable({ data, columns, getCoreRowModel: getCoreRowModel(), getPaginationRowModel: getPaginationRowModel(), onSortingChange: setSorting, getSortedRowModel: getSortedRowModel(), onColumnFiltersChange: setColumnFilters, getFilteredRowModel: getFilteredRowModel(), //renderSubComponent: ({ row }: { row: any }) => , //getRowCanExpand: () => true, filterFns: {}, state: { sorting, columnFilters, }, }); return (
{table.getHeaderGroups().map((headerGroup) => ( {headerGroup.headers.map((header) => { return ( {header.isPlaceholder ? null : flexRender( header.column.columnDef.header, header.getContext(), )} ); })} ))} {table.getRowModel().rows.length ? ( table.getRowModel().rows.map((row) => ( {row.getVisibleCells().map((cell) => ( {flexRender( cell.column.columnDef.cell, cell.getContext(), )} ))} )) ) : ( No results. )}
); }