"use client"; import { ColumnDef, flexRender, getCoreRowModel, useReactTable, getSortedRowModel, SortingState, } from "@tanstack/react-table"; import { useState } from "react"; import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow, } from "@/components/ui/table"; import { ArrowUpDown, ArrowUp, ArrowDown } from "lucide-react"; interface DrawingListTableProps { columns: ColumnDef[]; data: TData[]; onRowClick?: (row: TData) => void; selectedRow?: TData; getRowId?: (row: TData) => string; } export function DrawingListTable({ columns, data, onRowClick, selectedRow, getRowId, }: DrawingListTableProps) { const [sorting, setSorting] = useState([]); const table = useReactTable({ data, columns, getCoreRowModel: getCoreRowModel(), getSortedRowModel: getSortedRowModel(), onSortingChange: setSorting, state: { sorting, }, }); // 행이 선택되었는지 확인하는 함수 const isRowSelected = (row: TData): boolean => { if (!selectedRow || !getRowId) return false; return getRowId(row) === getRowId(selectedRow); }; return (
{table.getHeaderGroups().map((headerGroup) => ( {headerGroup.headers.map((header) => { const isSorted = header.column.getIsSorted(); const canSort = header.column.getCanSort(); return ( {header.isPlaceholder ? null : (
{flexRender( header.column.columnDef.header, header.getContext() )} {canSort && ( {isSorted === "asc" ? ( ) : isSorted === "desc" ? ( ) : ( )} )}
)}
); })}
))}
{table.getRowModel().rows?.length ? ( table.getRowModel().rows.map((row) => { const isSelected = isRowSelected(row.original); return ( onRowClick?.(row.original)} className={`cursor-pointer transition-colors ${ isSelected ? "bg-accent hover:bg-accent" : "hover:bg-muted/50" }`} > {row.getVisibleCells().map((cell) => ( {flexRender(cell.column.columnDef.cell, cell.getContext())} ))} ); }) ) : ( 데이터가 없습니다. )}
); }