Socket
Socket
Sign inDemoInstall

pdf-node

Package Overview
Dependencies
96
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 0.0.2 to 1.0.0

.prettierrc

28

index.js
#!/usr/bin/env node
(async () => {
console.log("start");
})();
const pdf = require('html-pdf');
const Handlebars = require('handlebars');
const handleError = require('cli-error-handler');
module.exports = (doc, options) => {
return new Promise((resolve, reject) => {
if (!doc || !doc.html || !doc.data) {
reject(new Error('Some, or all, options are missing.'));
}
if (doc.type === 'pdf') {
// Create PDF from html template generated by handlebars
// Output will be PDF file
let html = Handlebars.compile(doc.html)(doc.data);
let filepath = doc.path;
pdf.create(html).toFile(filepath, function (err, res) {
if (err) handleError('error in creating file', err);
console.log('file generated:', res.filename);
resolve(res);
});
} else {
reject('only pdf file type supported');
}
});
};

119

package.json
{
"name": "pdf-node",
"version": "0.0.2",
"description": "A JavaScript PDF generation library for NodeJs",
"main": "index.js",
"scripts": {
"start": "node index.js",
"test": "node test.js",
"format": "prettier --write \"./**/*.{js,json}\""
},
"keywords": [
"pdf",
"generator",
"node pdf generator",
"html2pdf",
"htmltopdf",
"Pdf generator",
"node pdf",
"npm node pdf",
"pdf node",
"node pdf parser",
"node pdf npm",
"node pdf generator from html",
"node pdf generator",
"node js api pdf",
"node pdf converter",
"node pdf create",
"node pdf export",
"node express pdf",
"node pdf from html",
"node fs pdf",
"node generate pdf from html",
"node generate pdf report",
"node get pdf file",
"node js pdf generation",
"node js pdf generator module",
"node pdf html",
"pdf in node js",
"node pdf js",
"node"
],
"repository": {
"type": "git",
"url": "git+https://github.com/tawseefnabi/pdf-node.git"
},
"bugs": {
"url": "https://github.com/tawseefnabi/pdf-node/issues"
},
"homepage": "https://github.com/tawseefnabi/pdf-node#readme",
"author": "tawseef <tawseefnabi9@gmail.com> (https://twitter.com/NabiTowseef)",
"license": "MIT",
"publishConfig": {
"@tawseef:registry": "https://npm.pkg.github.com/",
"access": "public"
},
"devDependencies": {
"prettier": "^2.3.2"
}
"name": "pdf-node",
"version": "1.0.0",
"description": "A JavaScript PDF generation library for NodeJs",
"main": "index.js",
"scripts": {
"start": "node index.js",
"test": "node test.js",
"format": "prettier --write \"./**/*.{js,json}\""
},
"keywords": [
"pdf",
"generator",
"node pdf generator",
"html2pdf",
"htmltopdf",
"Pdf generator",
"node pdf",
"npm node pdf",
"pdf node",
"node pdf parser",
"node pdf npm",
"node pdf generator from html",
"node pdf generator",
"node js api pdf",
"node pdf converter",
"node pdf create",
"node pdf export",
"node express pdf",
"node pdf from html",
"node fs pdf",
"node generate pdf from html",
"node generate pdf report",
"node get pdf file",
"node js pdf generation",
"node js pdf generator module",
"node pdf html",
"pdf in node js",
"node pdf js",
"node"
],
"repository": {
"type": "git",
"url": "git+https://github.com/tawseefnabi/pdf-node.git"
},
"bugs": {
"url": "https://github.com/tawseefnabi/pdf-node/issues"
},
"homepage": "https://github.com/tawseefnabi/pdf-node#readme",
"author": "tawseef <tawseefnabi9@gmail.com> (https://twitter.com/NabiTowseef)",
"license": "MIT",
"publishConfig": {
"@tawseef:registry": "https://npm.pkg.github.com/",
"access": "public"
},
"dependencies": {
"cli-error-handler": "^1.0.3",
"handlebars": "^4.7.7",
"html-pdf": "^3.0.1"
},
"devDependencies": {
"prettier": "^2.3.2"
}
}

@@ -14,3 +14,118 @@ # pdf-node

- Step 1 - Add required packages and read HTML template
```javascript
//Required package
var pdf = require("pdf--node");
var fs = require("fs");
// Read HTML Template
var html = fs.readFileSync("template.html", "utf8");
```
- Step 2 - Create your HTML Template
```html
<!DOCTYPE html>
<html>
<head>
<mate charest="utf-8" />
<title>Hello world!</title>
</head>
<body>
<h1>User List</h1>
<ul>
{{#each users}}
<li>Name: {{this.name}}</li>
<li>Age: {{this.age}}</li>
<br />
{{/each}}
</ul>
</body>
</html>
```
- Step 3 - Provide format and orientation as per your need
> "height": "10.5in", // allowed units: mm, cm, in, px
> "width": "8in", // allowed units: mm, cm, in, px
- or -
> "format": "Letter", // allowed units: A3, A4, A5, Legal, Letter, Tabloid
> "orientation": "portrait", // portrait or landscape
```javascript
var options = {
format: "A3",
orientation: "portrait",
border: "10mm",
header: {
height: "45mm",
contents: '<div style="text-align: center;">Author: Shyam Hajare</div>'
},
footer: {
height: "28mm",
contents: {
first: 'Cover page',
2: 'Second page', // Any page number is working. 1-based index
default: '<span style="color: #444;">{{page}}</span>/<span>{{pages}}</span>', // fallback value
last: 'Last Page'
}
}
};
```
- Step 4 - Provide HTML, user data and PDF path for output
```javascript
var users = [
{
name: "tom",
age: "21",
},
{
name: "dick",
age: "23",
},
{
name: "harry",
age: "29",
},
];
var document = {
html: html,
data: {
users: users,
},
path: "./output.pdf",
type: "",
};
// By default a file is created but you could switch between Buffer and Streams by using "buffer" or "stream" respectively.
```
- Step 5- After setting all parameters, just pass document and options to `pdf.create` method.
```javascript
pdf
.create(document, options)
.then((res) => {
console.log(res);
})
.catch((error) => {
console.error(error);
});
```
## Reference
Please refer to the following if you want to use conditions in your HTML template:
- https://handlebarsjs.com/builtin_helpers.html
<br>
## Connect

@@ -17,0 +132,0 @@

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc