Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bompi88/pdfmerger
Node module that uses the Pdfbox library to merge PDF files into a single PDF file.
https://github.com/bompi88/pdfmerger
combine merge node nodejs npm-package pdf pdfbox pdfmerger stream
Last synced: 2 months ago
JSON representation
Node module that uses the Pdfbox library to merge PDF files into a single PDF file.
- Host: GitHub
- URL: https://github.com/bompi88/pdfmerger
- Owner: bompi88
- License: apache-2.0
- Created: 2017-03-20T17:21:16.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-10-11T21:19:52.000Z (over 7 years ago)
- Last Synced: 2024-04-14T13:08:23.654Z (9 months ago)
- Topics: combine, merge, node, nodejs, npm-package, pdf, pdfbox, pdfmerger, stream
- Language: Java
- Homepage: https://www.npmjs.com/package/pdfmerger
- Size: 6.31 MB
- Stars: 6
- Watchers: 2
- Forks: 4
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## pdfmerger
_pdfmerger_ combines multiple PDF-files into a single PDF-file. It is a node module that utilizes the
[Apache PDFBox Library](http://pdfbox.apache.org), which the required functionality are distributed along with this module. The only requirement for this module to run, is having Java 6 or higher in the path.This package is inspired from karuppiah's [easy-pdf-merge](https://github.com/karuppiah7890/easy-pdf-merge), but instead of using a callback approach, this module returns a stream interface.
## Usage:
The module can merge a provided list of PDFs, or merge all PDFs present in a directory of your choice, in alphanumeric order. You can set a file path, which will write the file to that location, or just handle the stream yourselves.
``` javascript
var pdfmerger = require('pdfmerger');// Combining pdfs by using file paths
var pdfs = [
'/path/to/pdf1.pdf',
'/path/to/pdf2.pdf'
];var pdfStream = pdfmerger(pdfs);
var writeStream = fs.createWriteStream('path/to/combined.pdf');
pdfStream.pipe(writeStream);// write the output to a file
pdfmerger(pdfs, '/path/to/combined.pdf');
// combine all pdfs in a directory
pdfmerger('/path/to/directory', '/path/to/combined.pdf');
// set max java heap limit and initial heap size in megabytes
pdfmerger('/path/to/directory', '/path/to/combined.pdf', {
maxHeap: 512,
minHeap: 32
});// Stream events
pdfStream.on('data', function(data) {
});
pdfStream.on('error', function(error) {
});
pdfStream.on('close', function(code) {
});
```
## Issues and Feature Requests
If there are issues or feature requests, go to the [github issues page of the module](https://github.com/bompi88/pdfmerger/issues).
## Licenses
### Project License - Apache License 2.0
The license is inherited from the PDFBox project.
```
Copyright 2017 Bjørn BråthenLicensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
```### Pdfs used for testing
res/pdf1.pdf - the first 20 pages of [_Making260_](https://github.com/making360/making360) - This resource is licensed under [Creative Commons - Attribution-NonCommercial-ShareAlike-4.0 International](http://creativecommons.org/licenses/by-nc-sa/4.0/).
res/pdf2.pdf - the first 20 pages of [TypeScript Deep Dive](https://github.com/basarat/typescript-book), by Barasat Ali Syed - [Creative Commons Attribution 4.0 International License](https://creativecommons.org/licenses/by/4.0/).