mirror of
https://github.com/documenso/documenso.git
synced 2025-11-12 15:53:02 +10:00
This change allows users to include the audit trail log in the completed documents; similar to the signing certificate. https://github.com/user-attachments/assets/d9ae236a-2584-4ad6-b7bc-27b3eb8c74d3 It also solves the issue with the text cutoff.
120 lines
3.9 KiB
TypeScript
120 lines
3.9 KiB
TypeScript
import { useLingui } from '@lingui/react/macro';
|
|
import { Loader } from 'lucide-react';
|
|
|
|
import { useCurrentOrganisation } from '@documenso/lib/client-only/providers/organisation';
|
|
import { useSession } from '@documenso/lib/client-only/providers/session';
|
|
import { DocumentSignatureType } from '@documenso/lib/constants/document';
|
|
import { isPersonalLayout } from '@documenso/lib/utils/organisations';
|
|
import { trpc } from '@documenso/trpc/react';
|
|
import { useToast } from '@documenso/ui/primitives/use-toast';
|
|
|
|
import {
|
|
DocumentPreferencesForm,
|
|
type TDocumentPreferencesFormSchema,
|
|
} from '~/components/forms/document-preferences-form';
|
|
import { SettingsHeader } from '~/components/general/settings-header';
|
|
import { appMetaTags } from '~/utils/meta';
|
|
|
|
export function meta() {
|
|
return appMetaTags('Document Preferences');
|
|
}
|
|
|
|
export default function OrganisationSettingsDocumentPage() {
|
|
const { organisations } = useSession();
|
|
|
|
const organisation = useCurrentOrganisation();
|
|
|
|
const { t } = useLingui();
|
|
const { toast } = useToast();
|
|
|
|
const isPersonalLayoutMode = isPersonalLayout(organisations);
|
|
|
|
const { data: organisationWithSettings, isLoading: isLoadingOrganisation } =
|
|
trpc.organisation.get.useQuery({
|
|
organisationReference: organisation.url,
|
|
});
|
|
|
|
const { mutateAsync: updateOrganisationSettings } =
|
|
trpc.organisation.settings.update.useMutation();
|
|
|
|
const onDocumentPreferencesFormSubmit = async (data: TDocumentPreferencesFormSchema) => {
|
|
try {
|
|
const {
|
|
documentVisibility,
|
|
documentLanguage,
|
|
documentTimezone,
|
|
documentDateFormat,
|
|
includeSenderDetails,
|
|
includeSigningCertificate,
|
|
includeAuditLog,
|
|
signatureTypes,
|
|
} = data;
|
|
|
|
if (
|
|
documentVisibility === null ||
|
|
documentLanguage === null ||
|
|
documentDateFormat === null ||
|
|
includeSenderDetails === null ||
|
|
includeSigningCertificate === null ||
|
|
includeAuditLog === null
|
|
) {
|
|
throw new Error('Should not be possible.');
|
|
}
|
|
|
|
await updateOrganisationSettings({
|
|
organisationId: organisation.id,
|
|
data: {
|
|
documentVisibility,
|
|
documentLanguage,
|
|
documentTimezone,
|
|
documentDateFormat,
|
|
includeSenderDetails,
|
|
includeSigningCertificate,
|
|
includeAuditLog,
|
|
typedSignatureEnabled: signatureTypes.includes(DocumentSignatureType.TYPE),
|
|
uploadSignatureEnabled: signatureTypes.includes(DocumentSignatureType.UPLOAD),
|
|
drawSignatureEnabled: signatureTypes.includes(DocumentSignatureType.DRAW),
|
|
},
|
|
});
|
|
|
|
toast({
|
|
title: t`Document preferences updated`,
|
|
description: t`Your document preferences have been updated`,
|
|
});
|
|
} catch (err) {
|
|
toast({
|
|
title: t`Something went wrong!`,
|
|
description: t`We were unable to update your document preferences at this time, please try again later`,
|
|
variant: 'destructive',
|
|
});
|
|
}
|
|
};
|
|
|
|
if (isLoadingOrganisation || !organisationWithSettings) {
|
|
return (
|
|
<div className="flex items-center justify-center rounded-lg py-32">
|
|
<Loader className="text-muted-foreground h-6 w-6 animate-spin" />
|
|
</div>
|
|
);
|
|
}
|
|
|
|
const settingsHeaderText = t`Document Preferences`;
|
|
const settingsHeaderSubtitle = isPersonalLayoutMode
|
|
? t`Here you can set your general document preferences`
|
|
: t`Here you can set document preferences for your organisation. Teams will inherit these settings by default.`;
|
|
|
|
return (
|
|
<div className="max-w-2xl">
|
|
<SettingsHeader title={settingsHeaderText} subtitle={settingsHeaderSubtitle} />
|
|
|
|
<section>
|
|
<DocumentPreferencesForm
|
|
canInherit={false}
|
|
settings={organisationWithSettings.organisationGlobalSettings}
|
|
onFormSubmit={onDocumentPreferencesFormSubmit}
|
|
/>
|
|
</section>
|
|
</div>
|
|
);
|
|
}
|