stratic-filter-drafts
v1.0.1
Published
Filter out Stratic posts that are drafts
Downloads
4
Readme
stratic-filter-drafts
Gulp plugin to filter out Stratic posts that are drafts
Installation
npm install stratic-filter-drafts
Usage
Put this somewhere in a Gulp pipeline of Vinyl file objects to filter out posts that are drafts.
Files are considered drafts if they meet any of these conditions:
file.data.draft
exists and is truthyfile.data.time
doesn't existfile.data.time.epoch
doesn't exist or isn't a numberfile.dta.time.utcoffset
doesn't exist or isn't a string
You probably want to put this as early as possible in the pipeline (ideally right after metadata is extracted) to avoid doing unnecessary work on files that are just going to be dropped later. See below for examples on where to put this.
Example
Minimal example:
var gulp = require('gulp');
var frontMatter = require('gulp-grey-matter');
var straticFilterDrafts = require('stratic-filter-drafts');
var straticDateInPath = require('stratic-date-in-path');
gulp.task('posts', function() {
return gulp.src('*.md')
.pipe(frontMatter())
.pipe(straticFilterDrafts());
});
Full example:
var gulp = require('gulp');
var remark = require('gulp-remark');
var remarkHtml = require('remark-html');
var frontMatter = require('gulp-grey-matter');
var straticFilterDrafts = require('stratic-filter-drafts');
var addsrc = require('gulp-add-src');
var pug = require('gulp-pug');
var straticDateInPath = require('stratic-date-in-path');
gulp.task('posts', function() {
return gulp.src('*.md')
.pipe(frontMatter())
.pipe(straticFilterDrafts())
.pipe(remark().use(remarkHtml))
.pipe(straticDateInPath())
.pipe(addsrc('src/blog/post.pug'))
.pipe(attachToTemplate('post.pug'))
.pipe(pug({basedir: __dirname}))
.pipe(rename({ extname: '.html' }))
.pipe(gulp.dest('dist'));
});
Draft examples
All of these posts will be considered drafts.
---
title: "Example post 1"
time:
epoch: 1494649337
utcoffset: UTC-0
author: "Jane Doe"
categories:
- example
draft: true
---
Example post that's a draft because `file.data.draft` is set to something truthy (`true`).
---
title: "Example post 2"
time:
epoch:
utcoffset:
author: "Jane Doe"
categories:
- example
---
Example post that's a draft both because `file.data.time.epoch` is undefined and because `file.data.time.utcoffset` is undefined.
---
title: "Example post 3"
author: "Jane Doe"
categories:
- example
---
Example post that's a draft because `file.data.time` is missing entirely.
Code of Conduct
Please note that StraticJS is developed under the Contributor Covenant Code of Conduct. Project contributors are expected to respect these terms.
For the full Code of Conduct, see CODE_OF_CONDUCT.md. Violations may be reported to [email protected].
License
LGPL 3.0+
Author
AJ Jordan [email protected]