Gulp plugin for removing files flagged as drafts. Can also be used as an assemble or verb plugin.
The filtering part of the plugin was inspired by gulp-filter.
Install with npm
npm i gulp-drafts --save
All of the following examples should work in any combination with one another.
var gulp = require('gulp');
var drafts = require('gulp-drafts');
gulp.task('blog', function () {
gulp.src('posts/**/*.md')
// remove files from the pipeline if they match the given
// filepath or glob patterns:
.pipe(drafts('**/drafts/*.md'))
.pipe(gulp.dest('dist'));
});
The plugin automatically filters out files with the draft
or data.draft
property set to true
. Files won't have these properties unless you're setting them on the file object earlier in the pipeline. (Or, if you're using this plugin with [assemble] or [verb] you can define the draft
property in front-matter.)
var gulp = require('gulp');
var drafts = require('gulp-drafts');
gulp.task('blog', function () {
gulp.src('posts/**/*.md')
// files with {draft: true} or {data: {draft: true}}
// will be removed
.pipe(drafts())
.pipe(gulp.dest('dist'));
});
var gulp = require('gulp');
var drafts = require('gulp-drafts');
gulp.task('blog', function () {
gulp.src('posts/**/*.md')
// ignore files with the `{foo: ...}` or `{bar: {baz: ...}}`
// properties
.pipe(drafts({props: ['foo', 'bar.baz']}))
.pipe(gulp.dest('dist'));
});
Everything works the same with [verb] and [assemble].
var verb = require('verb');
var drafts = require('verb-drafts');
verb.task('blog', function () {
verb.src('posts/**/*.md')
// ignore files with the `{foo: ...}` or `{bar: {baz: ...}}`
// properties
.pipe(drafts({props: ['foo', 'bar.baz']}))
.pipe(verb.dest('dist'));
});
Install dev dependencies:
node i -d && mocha
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue
Jon Schlinkert
Copyright (c) 2015 Jon Schlinkert
Released under the MIT license
This file was generated by verb-cli on March 22, 2015.