2023-10-22 00:55:28 +02:00
|
|
|
export async function extractPages(snapshot, pagesToExtractArray, PDFLib) {
|
|
|
|
const pdfDoc = await PDFLib.PDFDocument.load(snapshot)
|
2023-10-17 03:40:54 +02:00
|
|
|
|
|
|
|
// TODO: invent a better format for pagesToExtractArray and convert it.
|
2023-10-22 00:55:28 +02:00
|
|
|
return createSubDocument(pdfDoc, pagesToExtractArray, PDFLib);
|
2023-10-17 03:40:54 +02:00
|
|
|
};
|
|
|
|
|
2023-10-22 00:55:28 +02:00
|
|
|
export async function createSubDocument(pdfDoc, pagesToExtractArray, PDFLib) {
|
|
|
|
const subDocument = await PDFLib.PDFDocument.create();
|
2023-10-17 03:40:54 +02:00
|
|
|
|
|
|
|
// 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();
|
|
|
|
}
|