diff --git a/gulpfile.babel.js b/gulpfile.babel.js index 62e65d01f..b3c942cbb 100644 --- a/gulpfile.babel.js +++ b/gulpfile.babel.js @@ -10,20 +10,13 @@ import webpackConfig from "./webpack.conf"; const browserSync = BrowserSync.create(); const hugoBin = "hugo"; +const defaultArgs = ["-d", "../dist", "-s", "site", "-v"]; -gulp.task("hugo", (cb) => { - const args = ["-d", "../dist", "-s", "site", "-v"]; - return cp.spawn(hugoBin, args, {stdio: "inherit"}).on("close", (code) => { - if (code === 0) { - browserSync.reload(); - } else { - browserSync.notify("Hugo build failed :("); - } - cb(); - }); -}); +gulp.task("hugo", (cb) => buildSite(cb)); +gulp.task("hugo-preview", (cb) => buildSite(cb, ["--buildDrafts", "--buildFuture"])); gulp.task("build", ["css", "js", "hugo"]); +gulp.task("build-preview", ["css", "js", "hugo-preview"]); gulp.task("css", () => ( gulp.src("./src/css/*.css") @@ -56,3 +49,12 @@ gulp.task("server", ["hugo", "css", "js"], () => { gulp.watch("./src/css/**/*.css", ["css"]); gulp.watch("./site/**/*", ["hugo"]); }); + +function buildSite(cb, options) { + const args = options ? defaultArgs.concat(options) : defaultArgs; + + return cp.spawn(hugoBin, args, {stdio: "inherit"}).on("close", () => { + browserSync.reload(); + cb(); + }); +} diff --git a/netlify.toml b/netlify.toml index efcfd06c3..dd1ef8ee4 100644 --- a/netlify.toml +++ b/netlify.toml @@ -1,3 +1,6 @@ [build] -command = "npm run build" -publish = "dist" + command = "npm run build" + publish = "dist" + +[context.deploy-preview] + command = "npm run build-preview" diff --git a/package.json b/package.json index 67a3ab00d..f82f02b07 100644 --- a/package.json +++ b/package.json @@ -7,6 +7,7 @@ "hugo": "gulp hugo", "webpack": "gulp webpack", "build": "gulp build", + "build-preview": "gulp build-preview", "start": "gulp server", "lint": "eslint src" },