'use client'; import Link from 'next/link'; import { Edit, Pencil, Share } from 'lucide-react'; import { useSession } from 'next-auth/react'; import { match } from 'ts-pattern'; import { Document, DocumentStatus, Recipient, SigningStatus, User } from '@documenso/prisma/client'; import { Button } from '@documenso/ui/primitives/button'; export type DataTableActionButtonProps = { row: Document & { User: Pick; Recipient: Recipient[]; }; }; export const DataTableActionButton = ({ row }: DataTableActionButtonProps) => { const { data: session } = useSession(); if (!session) { return null; } const recipient = row.Recipient.find((recipient) => recipient.email === session.user.email); const isOwner = row.User.id === session.user.id; const isRecipient = !!recipient; const isDraft = row.status === DocumentStatus.DRAFT; const isPending = row.status === DocumentStatus.PENDING; const isComplete = row.status === DocumentStatus.COMPLETED; const isSigned = recipient?.signingStatus === SigningStatus.SIGNED; return match({ isOwner, isRecipient, isDraft, isPending, isComplete, isSigned, }) .with({ isOwner: true, isDraft: true }, () => ( )) .with({ isRecipient: true, isPending: true, isSigned: false }, () => ( )) .otherwise(() => ( )); };