#!/usr/bin/env node // Imports var fs = require('fs'); var pdf = require('html-pdf'); var yargs = require('yargs'); // Understanding var argv = yargs .usage("Usage: $0 -o out.pdf [options]") .example('$0 -i doc.pdf -o doc.pdf', 'Convert doc.html to PDF using the default values') .help('h') .alias('h', 'help') .describe('i', 'Input file') .alias('i', 'input') .default('i', '/dev/stdin') .describe('o', 'Output file') .alias('o', 'output') .describe('t', 'Title of file') .alias('t', 'title') .default('t', 'Sans titre') .describe('b', 'Border') .alias('b', 'border') .default('b', '2cm') .demandOption(['o']) .argv; // Settings options = { "base": "file://" + process.cwd() + '/', "format": "A4", "orientation": "portrait", "border": argv.border, "footer": { "height": "10mm", "contents": { default: '<div style="text-align: left; float: left;">' + argv.title + '</div> <div style="text-align:right; float: right;">{{page}}/{{pages}}</div>', } }, } // Reading htmlString = fs.readFileSync(argv.i, "utf8"); // Conversion pdf.create(htmlString, options).toFile(argv.o, function(err, res) { if (err) console.error(err); });