import { useState } from 'react'; import { msg } from '@lingui/core/macro'; import { useLingui } from '@lingui/react'; import { Trans } from '@lingui/react/macro'; import { DocumentStatus, RecipientRole } from '@prisma/client'; import { CheckCircle, Copy, Download, Edit, EyeIcon, FolderInput, Loader, MoreHorizontal, Pencil, Share, Trash2, } from 'lucide-react'; import { Link } from 'react-router'; import { useSession } from '@documenso/lib/client-only/providers/session'; import type { TDocumentMany as TDocumentRow } from '@documenso/lib/types/document'; import { isDocumentCompleted } from '@documenso/lib/utils/document'; import { formatDocumentsPath } from '@documenso/lib/utils/teams'; import { DocumentShareButton } from '@documenso/ui/components/document/document-share-button'; import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuLabel, DropdownMenuTrigger, } from '@documenso/ui/primitives/dropdown-menu'; 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 { DocumentRecipientLinkCopyDialog } from '~/components/general/document/document-recipient-link-copy-dialog'; import { useCurrentTeam } from '~/providers/team'; import { EnvelopeDownloadDialog } from '../dialogs/envelope-download-dialog'; export type DocumentsTableActionDropdownProps = { row: TDocumentRow; onMoveDocument?: () => void; }; export const DocumentsTableActionDropdown = ({ row, onMoveDocument, }: DocumentsTableActionDropdownProps) => { const { user } = useSession(); const team = useCurrentTeam(); const { _ } = useLingui(); const [isDeleteDialogOpen, setDeleteDialogOpen] = useState(false); const [isDuplicateDialogOpen, setDuplicateDialogOpen] = useState(false); const recipient = row.recipients.find((recipient) => recipient.email === user.email); const isOwner = row.user.id === user.id; // const isRecipient = !!recipient; const isDraft = row.status === DocumentStatus.DRAFT; const isPending = row.status === DocumentStatus.PENDING; const isComplete = isDocumentCompleted(row.status); // const isSigned = recipient?.signingStatus === SigningStatus.SIGNED; const isCurrentTeamDocument = team && row.team?.url === team.url; const canManageDocument = Boolean(isOwner || isCurrentTeamDocument); const documentsPath = formatDocumentsPath(team.url); const formatPath = `${documentsPath}/${row.envelopeId}/edit`; const nonSignedRecipients = row.recipients.filter((item) => item.signingStatus !== 'SIGNED'); return ( Action {!isDraft && recipient && recipient?.role !== RecipientRole.CC && recipient?.role !== RecipientRole.ASSISTANT && ( {recipient?.role === RecipientRole.VIEWER && ( <> View )} {recipient?.role === RecipientRole.SIGNER && ( <> Sign )} {recipient?.role === RecipientRole.APPROVER && ( <> Approve )} )} Edit e.preventDefault()}>
Download
} /> setDuplicateDialogOpen(true)}> Duplicate {onMoveDocument && canManageDocument && ( e.preventDefault()}> Move to Folder )} {/* No point displaying this if there's no functionality. */} {/* Void */} setDeleteDialogOpen(true)}> {canManageDocument ? _(msg`Delete`) : _(msg`Hide`)} Share {canManageDocument && ( e.preventDefault()}>
Signing Links
} /> )} ( e.preventDefault()}>
{loading ? : } Share Signing Card
)} />
); };