import { Table } from "@tanstack/react-table"; import { ChevronLeftIcon, ChevronRightIcon, ChevronsLeftIcon, ChevronsRightIcon } from "lucide-react"; import { Pagination, PaginationContent, PaginationItem, PaginationLink, Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@repo/shadcn-ui/components'; import { cn } from '@repo/shadcn-ui/lib/utils'; import { useTranslation } from '../../locales/i18n.ts'; import { DataTableMeta } from './data-table.tsx'; interface DataTablePaginationProps { table: Table; className?: string; } export function DataTablePagination({ table, className }: DataTablePaginationProps) { const { t } = useTranslation(); const { pageIndex: rawIndex, pageSize: rawSize } = table.getState().pagination; const totalRows = (table.options.meta as DataTableMeta)?.totalItems ?? table.getFilteredRowModel().rows.length; // Normalización segura const pageIndex = Number.isFinite(rawIndex) && rawIndex >= 0 ? rawIndex : 0; const pageSize = Number.isFinite(rawSize) && rawSize > 0 ? rawSize : 10; const pageCount = table.getPageCount() || Math.max(1, Math.ceil((totalRows || 0) / pageSize)); const hasSelected = table.getFilteredSelectedRowModel().rows.length > 0; // Rango visible (1-based en UI) const start = totalRows > 0 ? pageIndex * pageSize + 1 : 0; const end = totalRows > 0 ? Math.min(start + pageSize - 1, totalRows) : 0; return (
{/* Información izquierda */}
{/* Rango visible */} {t("components.datatable.pagination.showing_range", { start, end, total: totalRows, })} {/* Selección de filas */} {hasSelected && ( {t("components.datatable.pagination.rows_selected", { count: table.getFilteredSelectedRowModel().rows.length, total: table.getFilteredRowModel().rows.length, })} )}
{t("components.datatable.pagination.rows_per_page")}
{/* Controles derecha */}
{/* Primera página */} table.setPageIndex(0)} isActive={!table.getCanPreviousPage()} size="sm" className="px-2.5" > {/* Anterior */} table.previousPage()} isActive={!table.getCanPreviousPage()} size="sm" className="px-2.5" > {t("components.datatable.pagination.page_of", { page: pageIndex + 1, of: pageCount || 1, })} {/* Siguiente */} table.nextPage()} isActive={!table.getCanNextPage()} size="sm" className="px-2.5" > {/* Última página */} table.setPageIndex(pageCount - 1)} isActive={!table.getCanNextPage()} size="sm" className="px-2.5" >
); }