Compile static pug files with brunch.
pug-brunch-static is a processor for html-brunch-static, a brunch plugin designed to handle static html files. pug-brunch-static can convert pug files into static html files with html-brunch-static's support for layouts and partial views.
If you're looking for support for deprecated "jade" files, check out jade-brunch-static.
pug-brunch-static depends on html-brunch-static, which also depends on brunch-static, so, you will need to install all three. The recommended method is via npm:
npm install --save-dev brunch-static html-brunch-static pug-brunch-static
Or manually:
- Add
"brunch-static": "x.y.z"
to package.json - Add
"html-brunch-static": "x.y.z"
to package.json - Add
"pug-brunch-static": "x.y.z"
to package.json - Run
npm install
- Alternatively, you may use the latest git version with:
"brunch-static": "git+ssh://[email protected]:bmatcuk/brunch-static"
"html-brunch-static": "git+ssh://[email protected]:bmatcuk/html-brunch-static"
"pug-brunch-static": "git+ssh://[email protected]:bmatcuk/pug-brunch-static"
Add pug-brunch-static to your list of html-brunch-static processors:
exports.config =
...
plugins: {
static: {
processors: [
require('html-brunch-static')({
processors: [
require('pug-brunch-static')({
fileMatch: 'source/views/home.pug',
fileTransform: (filename) => filename.replace(/static\.pug$/, '.html')
})
]
})
]
}
}
Most options passed to pug-brunch-static are passed, verbatim, to pug, with the exception of:
-
fileMatch (default:
/\.static\.pug$/
)fileMatch is an anymatch that is used to determine which files will be handled by this processor. As an anymatch, it may be a string with globs, a regex, or a function that takes a filename and returns true if it should be handled, or false otherwise. The default will match files that end in
.static.pug
. -
fileTransform (default:
(filename) => filename.replace(/static\.pug$/, '.html')
)fileTransform converts the input filename into an html filename. It takes a filename as input and returns the new filename with the html extension. If you set the fileMatch property above, you'll probably need to set this option as well to ensure that your output files end with the html extension.
The html-brunch-static's context will be exposed in your pug files as local variables allowing you to use them in your template.