"use client" import * as React from "react" import { type DataTableRowAction } from "@/types/table" import { type ColumnDef } from "@tanstack/react-table" import { InfoIcon, PenIcon } from "lucide-react" import { formatDate } from "@/lib/utils" import { Button } from "@/components/ui/button" import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger, } from "@/components/ui/tooltip" import { DataTableColumnHeaderSimple } from "@/components/data-table/data-table-column-simple-header" import { poColumnsConfig } from "@/config/poColumnsConfig" import { ContractDetail } from "@/db/schema/contract" interface GetColumnsProps { setRowAction: React.Dispatch | null>> } /** * tanstack table column definitions with nested headers */ export function getColumns({ setRowAction }: GetColumnsProps): ColumnDef[] { // ---------------------------------------------------------------- // 1) select column (checkbox) - if needed // ---------------------------------------------------------------- // ---------------------------------------------------------------- // 2) actions column (buttons for item info and signature request) // ---------------------------------------------------------------- const actionsColumn: ColumnDef = { id: "actions", enableHiding: false, cell: function Cell({ row }) { // Check if this contract already has a signature envelope const hasSignature = row.original.hasSignature; return (
{/* Item Info Button */} View Item Info {/* Signature Request Button - only show if no signature exists */} {!hasSignature && ( Request Electronic Signature )}
); }, size: 80, // Increased width to accommodate both buttons }; // ---------------------------------------------------------------- // 3) Regular columns grouped by group name // ---------------------------------------------------------------- // 3-1) groupMap: { [groupName]: ColumnDef[] } const groupMap: Record[]> = {}; poColumnsConfig.forEach((cfg) => { // Use "_noGroup" if no group is specified const groupName = cfg.group || "_noGroup"; if (!groupMap[groupName]) { groupMap[groupName] = []; } // Child column definition const childCol: ColumnDef = { accessorKey: cfg.id, enableResizing: true, header: ({ column }) => ( ), meta: { excelHeader: cfg.excelHeader, group: cfg.group, type: cfg.type, }, cell: ({ row, cell }) => { if (cfg.id === "createdAt" || cfg.id === "updatedAt") { const dateVal = cell.getValue() as Date; return formatDate(dateVal); } return row.getValue(cfg.id) ?? ""; }, }; groupMap[groupName].push(childCol); }); // ---------------------------------------------------------------- // 3-2) Create actual parent columns (groups) from the groupMap // ---------------------------------------------------------------- const nestedColumns: ColumnDef[] = []; // Order can be fixed by pre-defining group order or sorting // Here we just use Object.entries order Object.entries(groupMap).forEach(([groupName, colDefs]) => { if (groupName === "_noGroup") { // No group → Add as top-level columns nestedColumns.push(...colDefs); } else { // Parent column nestedColumns.push({ id: groupName, header: groupName, // "Basic Info", "Metadata", etc. columns: colDefs, }); } }); // ---------------------------------------------------------------- // 4) Final column array: nestedColumns + actionsColumn // ---------------------------------------------------------------- return [ ...nestedColumns, actionsColumn, ]; }