markdown-pdf

Node module that converts Markdown files to PDFs.
The PDF looks great because it is styled by HTML5 Boilerplate. What? - Yes! Your Markdown is first converted to HTML, then pushed into the HTML5 Boilerplate index.html
. Phantomjs renders the page and saves it to a PDF. You can even customise the style of the PDF by passing an optional path to your CSS and you can pre-process your markdown file before it is converted to a PDF by passing in a pre-processing function, for templating.
Getting started
npm install markdown-pdf
Example Usage
Pass markdown-pdf a path to a markdown document or an array of paths and you'll be given back a path or an array of paths to temporary files that contain your converted PDFs.
var markdownpdf = require("markdown-pdf")
, fs = require("fs")
markdownpdf("/path/to/document.md", function (er, pdfPath) {
if (er) return console.error(er)
fs.rename(pdfPath, "/path/to/document.pdf", function() {
console.log("done")
})
})
Options
Pass options to markdown-pdf like so:
var markdownpdf = require("markdown-pdf")
, opts = {}
markdownpdf("/path/to/document.md", opts, function (er, pdfs) {})
options.phantomPath
Type: String
Default value: Path provided by phantomjs module
Path to phantom binary
options.concatFiles
Type: Boolean
Default value: false
If set to true, a single PDF will be created containing the contents of all of the Markdown files.
options.cssPath
Type: String
Default value: ../pdf.css
Path to custom CSS file, relative to the current working directory
options.paperFormat
Type: String
Default value: A4
'A3', 'A4', 'A5', 'Legal', 'Letter' or 'Tabloid'
options.paperOrientation
Type: String
Default value: portrait
'portrait' or 'landscape'
options.paperBorder
Type: String
Default value: 1cm
Supported dimension units are: 'mm', 'cm', 'in', 'px'
options.renderDelay
Type: Number
Default value: 1000
Delay in millis before rendering the PDF (give HTML and CSS a chance to load)
options.preProcessMd
Type: Function
Default value: null
Function to call before Markdown is converted to HTML. It is passed the Markdown file contents and must return a string
options.preProcessHtml
Type: Function
Default value: null
Function to call after Markdown has been converted to HTML but before it is converted to PDF. It is passed the Markdown file contents and must return a string
CLI Interface
Installation
To use markdown-pdf as a standalone program from the terminal run
npm install -g markdown-pdf
Usage
Usage: markdown-pdf [options] <markdown-file-path>
Options:
-h, --help output usage information
-V, --version output the version number
<markdown-file-path> Path of the markdown file to convert
-p, --phantom-path [path] Path to phantom binary
-s, --css-path [path] Path to custom CSS file
-f, --paper-format [format] 'A3', 'A4', 'A5', 'Legal', 'Letter' or 'Tabloid'
-r, --paper-orientation [orientation] 'portrait' or 'landscape'
-b, --paper-border [measurement] Supported dimension units are: 'mm', 'cm', 'in', 'px'
-d, --render-delay [millis] Delay before rendering the PDF (give HTML and CSS a chance to load)
-o, --out [path] Path of where to save the PDF