mirror of
https://github.com/documenso/documenso.git
synced 2025-11-12 07:43:16 +10:00
## Description General enhancements for templates. ## Changes Made Added the following changes to the template flow: - Allow adding document meta settings - Allow adding email settings - Allow adding document access & action authentication - Allow adding recipient action authentication - Save the state between template steps similar to how it works for documents Other changes: - Extract common fields between document and template flows - Remove the title field from "Use template" since we now have it as part of the template flow - Add new API endpoint for generating templates ## Testing Performed Added E2E tests for templates and creating documents from templates
75 lines
2.2 KiB
TypeScript
75 lines
2.2 KiB
TypeScript
import React from 'react';
|
|
|
|
import Link from 'next/link';
|
|
import { redirect } from 'next/navigation';
|
|
|
|
import { ChevronLeft } from 'lucide-react';
|
|
|
|
import { isUserEnterprise } from '@documenso/ee/server-only/util/is-document-enterprise';
|
|
import { getRequiredServerComponentSession } from '@documenso/lib/next-auth/get-server-component-session';
|
|
import { getTemplateWithDetailsById } from '@documenso/lib/server-only/template/get-template-with-details-by-id';
|
|
import { formatTemplatesPath } from '@documenso/lib/utils/teams';
|
|
import type { Team } from '@documenso/prisma/client';
|
|
|
|
import { TemplateType } from '~/components/formatter/template-type';
|
|
|
|
import { EditTemplateForm } from './edit-template';
|
|
|
|
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);
|
|
|
|
if (!templateId || Number.isNaN(templateId)) {
|
|
redirect(templateRootPath);
|
|
}
|
|
|
|
const { user } = await getRequiredServerComponentSession();
|
|
|
|
const template = await getTemplateWithDetailsById({
|
|
id: templateId,
|
|
userId: user.id,
|
|
}).catch(() => null);
|
|
|
|
if (!template || !template.templateDocumentData) {
|
|
redirect(templateRootPath);
|
|
}
|
|
|
|
const isTemplateEnterprise = await isUserEnterprise({
|
|
userId: user.id,
|
|
teamId: team?.id,
|
|
});
|
|
|
|
return (
|
|
<div className="mx-auto -mt-4 max-w-screen-xl px-4 md:px-8">
|
|
<Link href="/templates" className="flex items-center text-[#7AC455] hover:opacity-80">
|
|
<ChevronLeft className="mr-2 inline-block h-5 w-5" />
|
|
Templates
|
|
</Link>
|
|
|
|
<h1 className="mt-4 truncate text-2xl font-semibold md:text-3xl" title={template.title}>
|
|
{template.title}
|
|
</h1>
|
|
|
|
<div className="mt-2.5 flex items-center gap-x-6">
|
|
<TemplateType inheritColor type={template.type} className="text-muted-foreground" />
|
|
</div>
|
|
|
|
<EditTemplateForm
|
|
className="mt-6"
|
|
initialTemplate={template}
|
|
templateRootPath={templateRootPath}
|
|
isEnterprise={isTemplateEnterprise}
|
|
/>
|
|
</div>
|
|
);
|
|
};
|