mirror of
https://github.com/documenso/documenso.git
synced 2025-11-09 20:12:31 +10:00
118 lines
3.7 KiB
TypeScript
118 lines
3.7 KiB
TypeScript
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<User, 'id' | 'name' | 'email'>;
|
|
recipients: Recipient[];
|
|
team: Pick<Team, 'id' | 'url'>;
|
|
};
|
|
};
|
|
|
|
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 }, () => (
|
|
<Button className="w-full" asChild>
|
|
<Link to={`/sign/${recipient?.token}`}>
|
|
{match(role)
|
|
.with(RecipientRole.SIGNER, () => (
|
|
<>
|
|
<Pencil className="-ml-1 mr-2 h-4 w-4" />
|
|
<Trans>Sign</Trans>
|
|
</>
|
|
))
|
|
.with(RecipientRole.APPROVER, () => (
|
|
<>
|
|
<CheckCircle className="-ml-1 mr-2 h-4 w-4" />
|
|
<Trans>Approve</Trans>
|
|
</>
|
|
))
|
|
.otherwise(() => (
|
|
<>
|
|
<EyeIcon className="-ml-1 mr-2 h-4 w-4" />
|
|
<Trans>View</Trans>
|
|
</>
|
|
))}
|
|
</Link>
|
|
</Button>
|
|
))
|
|
.with({ isComplete: false }, () => (
|
|
<Button className="w-full" asChild>
|
|
<Link to={formatPath}>
|
|
<Trans>Edit</Trans>
|
|
</Link>
|
|
</Button>
|
|
))
|
|
.with({ isComplete: true }, () => (
|
|
<Button className="w-full" onClick={onDownloadClick}>
|
|
<Download className="-ml-1 mr-2 inline h-4 w-4" />
|
|
<Trans>Download</Trans>
|
|
</Button>
|
|
))
|
|
.otherwise(() => null);
|
|
};
|