Merge PDF files using JavaScript
The importDocument
operation allows you to add an existing PDF to your document. It’ll be added either before or after the specified page index, depending on if afterPageIndex
or beforePageIndex
is used.
By setting the treatImportedDocumentAsOnePage
flag, you can make sure that, as far as all follow-up operations are concerned, the imported document is only treated as a single page that makes specifying indices easier.
importedPageIndexes
may be used to import specific pages or a range of pages. If this parameter is omitted, the entire document will be imported.
To merge or combine documents, you can use the importDocument
operation to import another document and combine it with the currently loaded document.
If the same document’s Blob
object is used in the same operations array for different operations, the same Blob
object will be reused for all of them:
instance.applyOperations([ { type: "importDocument", afterPageIndex: 10, // Import document after page 10. treatImportedDocumentAsOnePage: false, // All the imported document pages will be treated separately for other operations. document: blob // Document to import. } ]);
If the treatImportedDocumentAsOnePage
property is set to true
, all of the imported document pages will be treated as a single one for the other operations that are about to be performed. This can be useful for some situations (e.g. you want to apply a rotation to all of the pages of the imported document). After all the current operations are applied to the document, the imported pages will behave like regular pages in the document.
Here’s an example that uses fetch
to retrieve an external document, converts it to a Blob
, and passes it in an importDocument
operation:
fetch("imported.pdf") .then((res) => { if (!res.ok) { throw res; } return res; }) .then((res) => res.blob()) .then((blob) => { instance.applyOperations([ { type: "importDocument", importedPageIndexes: [2, 4, [7, 10]], beforePageIndex: 3, document: blob, treatImportedDocumentAsOnePage: false } ]); });
It’s not possible to import the same document more than once in the same Document Editor UI operations block (see the Document Editing UI guide for more on this). However, it’s still possible to do it programmatically by chaining
importDocument
operations with the sameBlob
object.
Exporting a PDF
After this operation is complete, you can call instance#exportPDF
to get an ArrayBuffer
containing the data for the final PDF.
If you need to apply this operation and export the resulting document in one step, you can provide the same argument passed to instance#applyOperations
to instance#exportPDFWithOperations
instead, and it’ll resolve to an ArrayBuffer
containing the final PDF.