Files
sign/apps/web/src/app/(dashboard)/documents/data-table-action-button.tsx

109 lines
3.2 KiB
TypeScript
Raw Normal View History

2023-08-29 14:30:57 +10:00
'use client';
import Link from 'next/link';
import { Download, Edit, Pencil } from 'lucide-react';
2023-08-29 14:30:57 +10:00
import { useSession } from 'next-auth/react';
import { match } from 'ts-pattern';
2024-01-02 04:38:35 +00:00
import { downloadPDF } from '@documenso/lib/client-only/download-pdf';
import type { Document, Recipient, User } from '@documenso/prisma/client';
import { DocumentStatus, SigningStatus } from '@documenso/prisma/client';
import type { DocumentWithData } from '@documenso/prisma/types/document-with-data';
import { trpc as trpcClient } from '@documenso/trpc/client';
2023-08-29 14:30:57 +10:00
import { Button } from '@documenso/ui/primitives/button';
2024-01-02 04:38:35 +00:00
import { useToast } from '@documenso/ui/primitives/use-toast';
2023-09-21 00:51:02 +00:00
2023-08-29 14:30:57 +10:00
export type DataTableActionButtonProps = {
row: Document & {
User: Pick<User, 'id' | 'name' | 'email'>;
Recipient: Recipient[];
};
};
export const DataTableActionButton = ({ row }: DataTableActionButtonProps) => {
const { data: session } = useSession();
2024-01-02 04:38:35 +00:00
const { toast } = useToast();
2023-08-29 14:30:57 +10:00
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;
const onDownloadClick = async () => {
2024-01-02 04:38:35 +00:00
try {
let document: DocumentWithData | null = null;
2024-01-02 04:38:35 +00:00
if (!recipient) {
document = await trpcClient.document.getDocumentById.query({
id: row.id,
});
} else {
document = await trpcClient.document.getDocumentByToken.query({
token: recipient.token,
});
}
2024-01-02 04:38:35 +00:00
const documentData = document?.documentData;
2024-01-02 04:38:35 +00:00
if (!documentData) {
throw Error('No document available');
}
2024-01-02 04:38:35 +00:00
await downloadPDF({ documentData, fileName: row.title });
} catch (err) {
toast({
title: 'Something went wrong',
description: 'An error occurred while downloading your document.',
variant: 'destructive',
});
}
};
2023-08-29 14:30:57 +10:00
return match({
isOwner,
isRecipient,
isDraft,
isPending,
isComplete,
isSigned,
})
.with({ isOwner: true, isDraft: true }, () => (
<Button className="w-32" asChild>
2023-08-29 14:30:57 +10:00
<Link href={`/documents/${row.id}`}>
<Edit className="-ml-1 mr-2 h-4 w-4" />
Edit
</Link>
</Button>
))
.with({ isRecipient: true, isPending: true, isSigned: false }, () => (
<Button className="w-32" asChild>
2023-08-29 14:30:57 +10:00
<Link href={`/sign/${recipient?.token}`}>
<Pencil className="-ml-1 mr-2 h-4 w-4" />
Sign
</Link>
</Button>
))
.with({ isPending: true, isSigned: true }, () => (
<Button className="w-32" disabled={true}>
<Pencil className="-ml-1 mr-2 inline h-4 w-4" />
Sign
</Button>
))
.with({ isComplete: true }, () => (
<Button className="w-32" onClick={onDownloadClick}>
<Download className="-ml-1 mr-2 inline h-4 w-4" />
Download
</Button>
))
.otherwise(() => <div></div>);
2023-08-29 14:30:57 +10:00
};