gulp-nunjucks-api
v0.9.1
Published
Render Nunjucks templates with data, custom filters, custom context functions and options for other Nunjucks API features.
Downloads
83
Maintainers
Readme
gulp-nunjucks-api
Render Nunjucks templates with data, custom filters, custom context functions and options for other Nunjucks API features.
Install
Install with npm
npm install --save-dev gulp-nunjucks-api
Example
var gulp = require('gulp');
var nunjucksRender = require('gulp-nunjucks-api');
gulp.task('default', function () {
return gulp.src('src/templates/*.html')
.pipe(nunjucksRender({
src: 'src/templates',
data: require('./global-data.json'),
filters: require('./global-filters.js'),
functions: require('./global-functions.js')
}))
.pipe(gulp.dest('dist'));
});
Example with gulp data
var gulp = require('gulp');
var nunjucksRender = require('gulp-nunjucks-api');
var data = require('gulp-data');
function getDataForFile(file){
return {
example: 'data loaded for ' + file.relative
};
}
gulp.task('default', function () {
return gulp.src('src/templates/*.html')
.pipe(data(getDataForFile))
.pipe(nunjucksRender({
src: 'src/templates/'
}))
.pipe(gulp.dest('dist'));
});
API
gulp-nunjucks-api(options)
Renders source templates using the given options to configure the Nunjucks API with custom data, extensions, filters and contextual functions.
Same options as
nunjucks.configure()
:
- watch (default: false) reload templates when they are changed.
- express an express app that nunjucks should install to.
- autoescape (default: false) controls if output with dangerous characters are escaped automatically. See Autoescaping.
- tags (default: see nunjucks syntax) defines the syntax for nunjucks tags. See Customizing Syntax.
With the following additional options:
- extension (default: ".html") String. File extension to output. Pass 'inherit' to use the extension of the input file.
- src (default: undefined) String or Array. Search path(s) for
nunjucks.configure()
. - data (default: {}) Ojbect. Global data merged into the Nunjucks render context.
- errors (default: true) Boolean. Whether to emit errors to gulp or not.
Set to
false
to let the gulp task continue on errors. See also: the verbose option. - extensions (default: {}) Object. Global extensions added to the Nunjucks environment. See Custom Tags.
- filters (default: {}) Object. Global filter functions added to the Nunjucks environment. See Custom Filters.
- functions (default: {}) Object. Global functions merged into the Nunjucks render context.
- globals (default: undefined) Object. A single object which provides
data
,extensions
,filters
andfunctions
objects instead of setting each of these options separately. The separate global options are merged into this base object. - locals (default: undefined) Boolean or String. When
true
, enables loading of local template context data and functions from files that match the following default pattern:"<filename>.+(js|json)"
. When a glob pattern string is given, the directory containing a given template will be searched using the pattern. Data and functions from all matched files are merged into the render context. Note that the token<filename>
will be replaced with a given template's file name including extension. Use the<filename_noext>
token instead in a custom pattern to target the file name without extension. - verbose (default: false) Boolean. When
true
, detailed operational data is logged to the console.
Render with data example
nunjucksRender({
data: {css_path: 'http://company.com/css/'}
});
For the following template
<link rel="stylesheet" href="{{ css_path }}test.css" />
Would render
<link rel="stylesheet" href="http://company.com/css/test.css" />
Watch mode
Nunjucks' watch feature, which is normally enabled by default, is disabled by
default for gulp. Pass watch: true
to enable it:
nunjucksRender({
src: './source',
watch: true
});
License
MIT © Devoptix LLC
Shout-outs
Carlos G. Limardo who wrote gulp-nunjucks-render which I am forking in order to update Nunjucks and do other stuff.
Sindre Sorhus who wrote the original gulp-nunjucks for precompiling Nunjucks templates.