import Link from 'next/link'; import { redirect } from 'next/navigation'; import { Trans } from '@lingui/macro'; import { ChevronLeft, LucideEdit } from 'lucide-react'; import { getRequiredServerComponentSession } from '@documenso/lib/next-auth/get-server-component-session'; import { getTemplateById } from '@documenso/lib/server-only/template/get-template-by-id'; import { formatDocumentsPath, formatTemplatesPath } from '@documenso/lib/utils/teams'; import { DocumentSigningOrder, SigningStatus, type Team } from '@documenso/prisma/client'; import { Button } from '@documenso/ui/primitives/button'; import { Card, CardContent } from '@documenso/ui/primitives/card'; import { LazyPDFViewer } from '@documenso/ui/primitives/lazy-pdf-viewer'; import { DocumentReadOnlyFields } from '~/components/document/document-read-only-fields'; import { TemplateType } from '~/components/formatter/template-type'; import { DataTableActionDropdown } from '../data-table-action-dropdown'; import { TemplateDirectLinkBadge } from '../template-direct-link-badge'; import { UseTemplateDialog } from '../use-template-dialog'; import { TemplateDirectLinkDialogWrapper } from './template-direct-link-dialog-wrapper'; import { TemplatePageViewDocumentsTable } from './template-page-view-documents-table'; import { TemplatePageViewInformation } from './template-page-view-information'; import { TemplatePageViewRecentActivity } from './template-page-view-recent-activity'; import { TemplatePageViewRecipients } from './template-page-view-recipients'; export type TemplatePageViewProps = { params: { id: string; }; team?: Team; }; export const TemplatePageView = async ({ params, team }: TemplatePageViewProps) => { const { id } = params; const templateId = Number(id); const templateRootPath = formatTemplatesPath(team?.url); const documentRootPath = formatDocumentsPath(team?.url); if (!templateId || Number.isNaN(templateId)) { redirect(templateRootPath); } const { user } = await getRequiredServerComponentSession(); const template = await getTemplateById({ id: templateId, userId: user.id, teamId: team?.id, }).catch(() => null); if (!template || !template.templateDocumentData || (template?.teamId && !team?.url)) { redirect(templateRootPath); } const { templateDocumentData, Field, Recipient: recipients, templateMeta } = template; // Remap to fit the DocumentReadOnlyFields component. const readOnlyFields = Field.map((field) => { const recipient = recipients.find((recipient) => recipient.id === field.recipientId) || { name: '', email: '', signingStatus: SigningStatus.NOT_SIGNED, }; return { ...field, Recipient: recipient, Signature: null, }; }); const mockedDocumentMeta = templateMeta ? { ...templateMeta, signingOrder: templateMeta.signingOrder || DocumentSigningOrder.SEQUENTIAL, documentId: 0, } : undefined; return (
Templates

{template.title}

{template.directLink?.token && ( )}

Template

Manage and view template

Use } />
{/* Template information section. */} {/* Recipients section. */} {/* Recent activity section. */}

Documents created from template

); };