import { useState } from 'react'; import { msg } from '@lingui/core/macro'; import { useLingui } from '@lingui/react'; import { Trans } from '@lingui/react/macro'; import { DocumentStatus } from '@prisma/client'; import { Copy, Download, Edit, Loader, MoreHorizontal, ScrollTextIcon, Share, Trash2, } from 'lucide-react'; import { Link, useNavigate } from 'react-router'; import { downloadPDF } from '@documenso/lib/client-only/download-pdf'; import { useSession } from '@documenso/lib/client-only/providers/session'; import type { TEnvelope } from '@documenso/lib/types/envelope'; import { isDocumentCompleted } from '@documenso/lib/utils/document'; import { mapSecondaryIdToDocumentId } from '@documenso/lib/utils/envelope'; import { formatDocumentsPath } from '@documenso/lib/utils/teams'; import { trpc as trpcClient } from '@documenso/trpc/client'; import { DocumentShareButton } from '@documenso/ui/components/document/document-share-button'; import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuLabel, DropdownMenuTrigger, } from '@documenso/ui/primitives/dropdown-menu'; import { useToast } from '@documenso/ui/primitives/use-toast'; import { DocumentDeleteDialog } from '~/components/dialogs/document-delete-dialog'; import { DocumentDuplicateDialog } from '~/components/dialogs/document-duplicate-dialog'; import { DocumentResendDialog } from '~/components/dialogs/document-resend-dialog'; import { EnvelopeDownloadDialog } from '~/components/dialogs/envelope-download-dialog'; import { DocumentRecipientLinkCopyDialog } from '~/components/general/document/document-recipient-link-copy-dialog'; import { useCurrentTeam } from '~/providers/team'; export type DocumentPageViewDropdownProps = { envelope: TEnvelope; }; export const DocumentPageViewDropdown = ({ envelope }: DocumentPageViewDropdownProps) => { const { user } = useSession(); const { toast } = useToast(); const { _ } = useLingui(); const navigate = useNavigate(); const team = useCurrentTeam(); const [isDeleteDialogOpen, setDeleteDialogOpen] = useState(false); const [isDuplicateDialogOpen, setDuplicateDialogOpen] = useState(false); const recipient = envelope.recipients.find((recipient) => recipient.email === user.email); const isOwner = envelope.userId === user.id; const isDraft = envelope.status === DocumentStatus.DRAFT; const isPending = envelope.status === DocumentStatus.PENDING; const isDeleted = envelope.deletedAt !== null; const isComplete = isDocumentCompleted(envelope); const isCurrentTeamDocument = team && envelope.teamId === team.id; const canManageDocument = Boolean(isOwner || isCurrentTeamDocument); const documentsPath = formatDocumentsPath(team.url); const onDownloadClick = async () => { try { const documentWithData = await trpcClient.document.get.query( { documentId: mapSecondaryIdToDocumentId(envelope.secondaryId), }, { context: { teamId: team?.id?.toString(), }, }, ); const documentData = documentWithData?.documentData; if (!documentData) { return; } await downloadPDF({ documentData, fileName: envelope.title }); } catch (err) { toast({ title: _(msg`Something went wrong`), description: _(msg`An error occurred while downloading your document.`), variant: 'destructive', }); } }; const onDownloadOriginalClick = async () => { try { const documentWithData = await trpcClient.document.get.query( { documentId: mapSecondaryIdToDocumentId(envelope.secondaryId), }, { context: { teamId: team?.id?.toString(), }, }, ); const documentData = documentWithData?.documentData; if (!documentData) { return; } await downloadPDF({ documentData, fileName: envelope.title, version: 'original' }); } catch (err) { toast({ title: _(msg`Something went wrong`), description: _(msg`An error occurred while downloading your document.`), variant: 'destructive', }); } }; const nonSignedRecipients = envelope.recipients.filter((item) => item.signingStatus !== 'SIGNED'); return ( Action {(isOwner || isCurrentTeamDocument) && !isComplete && ( Edit )} {envelope.internalVersion === 2 ? ( e.preventDefault()}>
Download
} /> ) : ( <> {isComplete && ( Download )} Download Original )} Audit Logs setDuplicateDialogOpen(true)}> Duplicate setDeleteDialogOpen(true)} disabled={isDeleted}> Delete Share {canManageDocument && ( e.preventDefault()} > Signing Links } /> )} ( e.preventDefault()}>
{loading ? : } Share Signing Card
)} />
{ void navigate(documentsPath); }} /> {isDuplicateDialogOpen && ( )}
); };