Merge branch 'stirling-pdf-rewrite' into version-2

This commit is contained in:
Saud Fatayerji
2023-11-08 02:11:49 +03:00
36 changed files with 22647 additions and 100 deletions

View File

@@ -1,5 +1,6 @@
import { PDFDocument } from 'pdf-lib';
import { createSubDocument } from './createSubDocument';
export async function extractPages(snapshot, pagesToExtractArray) {
const pdfDoc = await PDFDocument.load(snapshot)
@@ -7,20 +8,3 @@ export async function extractPages(snapshot, pagesToExtractArray) {
// TODO: invent a better format for pagesToExtractArray and convert it.
return createSubDocument(pdfDoc, pagesToExtractArray);
};
export async function createSubDocument(pdfDoc, pagesToExtractArray) {
const subDocument = await PDFDocument.create();
// Check that array max number is not larger pdf pages number
if(Math.max(...pagesToExtractArray) >= pdfDoc.getPageCount()) {
throw new Error(`The PDF document only has ${pdfDoc.getPageCount()} pages and you tried to extract page ${Math.max(...pagesToExtractArray)}`);
}
const copiedPages = await subDocument.copyPages(pdfDoc, pagesToExtractArray);
for (let i = 0; i < copiedPages.length; i++) {
subDocument.addPage(copiedPages[i]);
}
return subDocument.save();
}