import { msg } from '@lingui/core/macro'; import { useLingui } from '@lingui/react'; import { Trans } from '@lingui/react/macro'; import type { Document, Recipient, Team, User } from '@prisma/client'; import { DocumentStatus, RecipientRole, SigningStatus } from '@prisma/client'; import { CheckCircle, Download, EyeIcon, Pencil } from 'lucide-react'; import { Link } from 'react-router'; import { match } from 'ts-pattern'; import { downloadPDF } from '@documenso/lib/client-only/download-pdf'; import { useSession } from '@documenso/lib/client-only/providers/session'; import { isDocumentCompleted } from '@documenso/lib/utils/document'; import { formatDocumentsPath } from '@documenso/lib/utils/teams'; import { trpc as trpcClient } from '@documenso/trpc/client'; import { Button } from '@documenso/ui/primitives/button'; import { useToast } from '@documenso/ui/primitives/use-toast'; export type DocumentPageViewButtonProps = { document: Document & { user: Pick; recipients: Recipient[]; team: Pick; }; }; export const DocumentPageViewButton = ({ document }: DocumentPageViewButtonProps) => { const { user } = useSession(); const { toast } = useToast(); const { _ } = useLingui(); const recipient = document.recipients.find((recipient) => recipient.email === user.email); const isRecipient = !!recipient; const isPending = document.status === DocumentStatus.PENDING; const isComplete = isDocumentCompleted(document); const isSigned = recipient?.signingStatus === SigningStatus.SIGNED; const role = recipient?.role; const documentsPath = formatDocumentsPath(document.team.url); const formatPath = `${documentsPath}/${document.id}/edit`; const onDownloadClick = async () => { try { const documentWithData = await trpcClient.document.getDocumentById.query( { documentId: document.id, }, { context: { teamId: document.team?.id?.toString(), }, }, ); const documentData = documentWithData?.documentData; if (!documentData) { throw new Error('No document available'); } await downloadPDF({ documentData, fileName: documentWithData.title }); } catch (err) { toast({ title: _(msg`Something went wrong`), description: _(msg`An error occurred while downloading your document.`), variant: 'destructive', }); } }; return match({ isRecipient, isPending, isComplete, isSigned, }) .with({ isRecipient: true, isPending: true, isSigned: false }, () => ( )) .with({ isComplete: false }, () => ( )) .with({ isComplete: true }, () => ( )) .otherwise(() => null); };