mirror of
https://github.com/documenso/documenso
synced 2026-04-21 13:27:18 +00:00
Upgrade @libpdf/core from 0.2.12 to 0.3.3, which includes: - WebCrypto SHA-256 replacing pure-JS @noble/hashes (10x signing speedup) - Iterative collectReachableRefs (fixes stack overflow on large PDFs) - Iterative Math.max helpers in xref writer (fixes remaining stack overflow) Extract duplicated FontLibrary.use() calls from render-certificate, render-audit-logs, and insert-field-in-pdf-v2 into a shared ensureFontLibrary() helper with has() guards so fonts are only registered once per process.
63 lines
1.5 KiB
TypeScript
63 lines
1.5 KiB
TypeScript
// sort-imports-ignore
|
|
import '../konva/skia-backend';
|
|
|
|
import Konva from 'konva';
|
|
import type { Canvas } from 'skia-canvas';
|
|
|
|
import type { FieldWithSignature } from '@documenso/prisma/types/field-with-signature';
|
|
|
|
import { renderField } from '../../universal/field-renderer/render-field';
|
|
import { ensureFontLibrary } from './helpers';
|
|
|
|
type InsertFieldInPDFV2Options = {
|
|
pageWidth: number;
|
|
pageHeight: number;
|
|
fields: FieldWithSignature[];
|
|
};
|
|
|
|
export const insertFieldInPDFV2 = async ({
|
|
pageWidth,
|
|
pageHeight,
|
|
fields,
|
|
}: InsertFieldInPDFV2Options) => {
|
|
ensureFontLibrary();
|
|
|
|
let stage: Konva.Stage | null = new Konva.Stage({ width: pageWidth, height: pageHeight });
|
|
let layer: Konva.Layer | null = new Konva.Layer();
|
|
|
|
// Render the fields onto the layer.
|
|
for (const field of fields) {
|
|
renderField({
|
|
scale: 1,
|
|
field: {
|
|
renderId: field.id.toString(),
|
|
...field,
|
|
width: Number(field.width),
|
|
height: Number(field.height),
|
|
positionX: Number(field.positionX),
|
|
positionY: Number(field.positionY),
|
|
},
|
|
translations: null,
|
|
pageLayer: layer,
|
|
pageWidth,
|
|
pageHeight,
|
|
mode: 'export',
|
|
});
|
|
}
|
|
|
|
stage.add(layer);
|
|
|
|
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
|
|
const canvas = layer.canvas._canvas as unknown as Canvas;
|
|
|
|
// Embed the SVG into the PDF
|
|
const pdf = await canvas.toBuffer('pdf');
|
|
|
|
stage.destroy();
|
|
layer.destroy();
|
|
|
|
stage = null;
|
|
layer = null;
|
|
|
|
return pdf;
|
|
};
|