import { useState } from 'react'; import { Trans } from '@lingui/macro'; import type { Field } from '@documenso/prisma/client'; import { RecipientRole } from '@documenso/prisma/client'; import { Button } from '@documenso/ui/primitives/button'; import { Dialog, DialogContent, DialogFooter, DialogTitle, DialogTrigger, } from '@documenso/ui/primitives/dialog'; import { SigningDisclosure } from '~/components/general/signing-disclosure'; import { truncateTitle } from '~/helpers/truncate-title'; export type SignDialogProps = { isSubmitting: boolean; documentTitle: string; fields: Field[]; fieldsValidated: () => void | Promise; onSignatureComplete: () => void | Promise; role: RecipientRole; disabled?: boolean; }; export const SignDialog = ({ isSubmitting, documentTitle, fields, fieldsValidated, onSignatureComplete, role, disabled = false, }: SignDialogProps) => { const [showDialog, setShowDialog] = useState(false); const truncatedTitle = truncateTitle(documentTitle); const isComplete = fields.every((field) => field.inserted); const handleOpenChange = (open: boolean) => { if (isSubmitting || !isComplete) { return; } setShowDialog(open); }; return (
{role === RecipientRole.VIEWER && Complete Viewing} {role === RecipientRole.SIGNER && Complete Signing} {role === RecipientRole.APPROVER && Complete Approval}
{role === RecipientRole.VIEWER && ( You are about to complete viewing "{truncatedTitle}".
Are you sure?
)} {role === RecipientRole.SIGNER && ( You are about to complete signing "{truncatedTitle}".
Are you sure?
)} {role === RecipientRole.APPROVER && ( You are about to complete approving "{truncatedTitle}".
Are you sure?
)}
); };