vac.dev-experimental-old/gulpfile.babel.js

102 lines
2.4 KiB
JavaScript
Raw Normal View History

import autoprefixer from "autoprefixer";
import browserSync from "browser-sync";
2018-12-16 15:27:09 -06:00
import { spawn } from "child_process";
import cssnano from "cssnano";
2018-12-16 15:27:09 -06:00
import { dest, series, src, task, watch } from "gulp";
import gulpif from "gulp-if";
2018-08-09 22:54:58 -05:00
import postcss from "gulp-postcss";
import purgecss from "gulp-purgecss";
2018-12-16 15:27:09 -06:00
import sourcemaps from "gulp-sourcemaps";
import atimport from "postcss-import";
2018-08-09 22:54:58 -05:00
import tailwindcss from "tailwindcss";
2018-12-16 15:27:09 -06:00
const rawStylesheet = "src/style.css";
2018-03-10 23:37:24 -06:00
const siteRoot = "_site";
2018-12-16 15:27:09 -06:00
const cssRoot = `${siteRoot}/assets/css/`;
const tailwindConfig = "tailwind.config.js";
2017-11-20 19:37:43 -06:00
2018-12-16 15:27:09 -06:00
const devBuild =
(process.env.NODE_ENV || "development").trim().toLowerCase() ===
"development";
2018-08-09 22:54:58 -05:00
// Fix for Windows compatibility
const jekyll = process.platform === "win32" ? "jekyll.bat" : "jekyll";
2017-11-08 20:34:49 -06:00
// Custom PurgeCSS Extractor
// https://github.com/FullHuman/purgecss
2018-02-08 23:15:15 -06:00
class TailwindExtractor {
static extract(content) {
return content.match(/[A-z0-9-:\/]+/g) || [];
2018-02-08 23:15:15 -06:00
}
}
2018-12-16 15:27:09 -06:00
task("buildJekyll", () => {
browserSync.notify("Building Jekyll site...");
2018-12-16 15:27:09 -06:00
const args = ["exec", jekyll, "build"];
2018-12-16 15:27:09 -06:00
if (devBuild) {
args.push("--incremental");
}
return spawn("bundle", args, { stdio: "inherit" });
});
2018-12-16 15:27:09 -06:00
task("processStyles", done => {
browserSync.notify("Compiling styles...");
2018-12-16 15:27:09 -06:00
return src(rawStylesheet)
2018-02-08 23:15:15 -06:00
.pipe(postcss([atimport(), tailwindcss(tailwindConfig)]))
.pipe(gulpif(devBuild, sourcemaps.init()))
2018-12-16 15:27:09 -06:00
.pipe(
gulpif(
!devBuild,
new purgecss({
content: ["_site/**/*.html"],
extractors: [
{
extractor: TailwindExtractor,
extensions: ["html", "js"]
}
]
})
)
)
.pipe(gulpif(!devBuild, postcss([autoprefixer(), cssnano()])))
2018-12-16 15:27:09 -06:00
.pipe(gulpif(devBuild, sourcemaps.write("")))
.pipe(dest(cssRoot));
});
2018-12-16 15:27:09 -06:00
task("startServer", () => {
2017-11-08 20:34:49 -06:00
browserSync.init({
2018-02-08 23:15:15 -06:00
files: [siteRoot + "/**"],
open: "local",
2018-02-08 23:15:15 -06:00
port: 4000,
2017-11-08 20:34:49 -06:00
server: {
baseDir: siteRoot,
serveStaticOptions: {
extensions: ["html"]
}
2017-11-08 20:34:49 -06:00
}
});
watch(
[
2019-07-16 22:48:16 -05:00
"**/*.css",
"**/*.html",
"**/*.js",
"**/*.md",
"**/*.markdown",
2019-07-16 22:45:00 -05:00
"!_site/**/*",
2019-07-16 22:48:16 -05:00
"!node_modules/**/*"
2018-12-16 15:27:09 -06:00
],
{ interval: 500 },
2018-08-09 22:54:58 -05:00
buildSite
2018-02-08 23:15:15 -06:00
);
});
2018-12-16 15:27:09 -06:00
const buildSite = series("buildJekyll", "processStyles");
2017-11-08 20:34:49 -06:00
2018-12-16 15:27:09 -06:00
exports.serve = series(buildSite, "startServer");
exports.default = series(buildSite);