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 { Select, SelectContent, SelectGroup, SelectItem, SelectLabel, SelectTrigger, SelectValue, } from "../../components/ui/select"; 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; height?: string; pageSize?: number; }; export default function LstTable({ className = "", tableClassName = "", data, columns, height = "h-full", pageSize = 5, }: LstTableType) { const [sorting, setSorting] = useState([]); const [columnFilters, setColumnFilters] = useState([]); const [pagination, setPagination] = useState({ pageIndex: 0, //initial page index pageSize: pageSize, //default page size }); //console.log(data); const table = useReactTable({ data, columns, getCoreRowModel: getCoreRowModel(), getPaginationRowModel: getPaginationRowModel(), onSortingChange: setSorting, getSortedRowModel: getSortedRowModel(), onColumnFiltersChange: setColumnFilters, getFilteredRowModel: getFilteredRowModel(), onPaginationChange: setPagination, //renderSubComponent: ({ row }: { row: any }) => , //getRowCanExpand: () => true, // columnResizeMode: "onChange", filterFns: {}, state: { sorting, pagination, columnFilters, }, }); return (
{/* TODO: Add table header in here like title */}
{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. )}
); }