import type { MessageDescriptor } from '@lingui/core'; import { msg } from '@lingui/core/macro'; import { useLingui } from '@lingui/react'; import { Trans } from '@lingui/react/macro'; import type { Recipient } from '@prisma/client'; import { ChevronLeft } from 'lucide-react'; import { DateTime } from 'luxon'; import { Link, redirect } from 'react-router'; import { getSession } from '@documenso/auth/server/lib/utils/get-session'; import { getDocumentById } from '@documenso/lib/server-only/document/get-document-by-id'; import { getRecipientsForDocument } from '@documenso/lib/server-only/recipient/get-recipients-for-document'; import { type TGetTeamByUrlResponse, getTeamByUrl } from '@documenso/lib/server-only/team/get-team'; import { formatDocumentsPath } from '@documenso/lib/utils/teams'; import { Card } from '@documenso/ui/primitives/card'; import { DocumentAuditLogDownloadButton } from '~/components/general/document/document-audit-log-download-button'; import { DocumentCertificateDownloadButton } from '~/components/general/document/document-certificate-download-button'; import { DocumentStatus as DocumentStatusComponent, FRIENDLY_STATUS_MAP, } from '~/components/general/document/document-status'; import { DocumentLogsTable } from '~/components/tables/document-logs-table'; import type { Route } from './+types/documents.f.$folderId.$id.logs'; export async function loader({ params, request }: Route.LoaderArgs) { const { user } = await getSession(request); let team: TGetTeamByUrlResponse | null = null; if (params.teamUrl) { team = await getTeamByUrl({ userId: user.id, teamUrl: params.teamUrl }); } const { id, folderId } = params; const documentId = Number(id); const documentRootPath = formatDocumentsPath(team?.url); if (!documentId || Number.isNaN(documentId)) { throw redirect(folderId ? `${documentRootPath}/f/${folderId}` : documentRootPath); } if (!folderId) { throw redirect(documentRootPath); } // Todo: Get full document instead? const [document, recipients] = await Promise.all([ getDocumentById({ documentId, userId: user.id, teamId: team?.id, folderId, }).catch(() => null), getRecipientsForDocument({ documentId, userId: user.id, teamId: team?.id, }), ]); if (!document || !document.documentData) { throw redirect(folderId ? `${documentRootPath}/f/${folderId}` : documentRootPath); } if (document.folderId !== folderId) { throw redirect(documentRootPath); } return { document, documentRootPath, recipients, folderId, }; } export default function DocumentsLogsPage({ loaderData }: Route.ComponentProps) { const { document, documentRootPath, recipients, folderId } = loaderData; const { _, i18n } = useLingui(); const documentInformation: { description: MessageDescriptor; value: string }[] = [ { description: msg`Document title`, value: document.title, }, { description: msg`Document ID`, value: document.id.toString(), }, { description: msg`Document status`, value: _(FRIENDLY_STATUS_MAP[document.status].label), }, { description: msg`Created by`, value: document.user.name ? `${document.user.name} (${document.user.email})` : document.user.email, }, { description: msg`Date created`, value: DateTime.fromJSDate(document.createdAt) .setLocale(i18n.locales?.[0] || i18n.locale) .toLocaleString(DateTime.DATETIME_MED_WITH_SECONDS), }, { description: msg`Last updated`, value: DateTime.fromJSDate(document.updatedAt) .setLocale(i18n.locales?.[0] || i18n.locale) .toLocaleString(DateTime.DATETIME_MED_WITH_SECONDS), }, { description: msg`Time zone`, value: document.documentMeta?.timezone ?? 'N/A', }, ]; const formatRecipientText = (recipient: Recipient) => { let text = recipient.email; if (recipient.name) { text = `${recipient.name} (${recipient.email})`; } return `[${recipient.role}] ${text}`; }; return (
Document

{document.title}

{documentInformation.map((info, i) => (

{_(info.description)}

{info.value}

))}

Recipients

    {recipients.map((recipient) => (
  • {formatRecipientText(recipient)}
  • ))}
); }