monkeytype/frontend/gulpfile.js
Bruce Berrios 032fe57f2a
Consolidate webpack configurations (#2716) bruception
* Consolidate webpack configurations

* Add lint step back into dev compilation
2022-03-16 20:57:30 +01:00

129 lines
3.3 KiB
JavaScript

const del = require("del");
const concat = require("gulp-concat");
const { webpack } = require("webpack");
const eslint = require("gulp-eslint-new");
const vinylPaths = require("vinyl-paths");
const sass = require("gulp-sass")(require("dart-sass"));
const { task, src, dest, series, watch } = require("gulp");
const webpackDevConfig = require("./webpack/config.dev.js");
const webpackProdConfig = require("./webpack/config.prod.js");
const JSONValidation = require("./json-validation");
const eslintConfig = "../.eslintrc.json";
task("clean", function () {
return src(["./public/"], { allowEmpty: true }).pipe(vinylPaths(del));
});
task("lint", function () {
return src(["./src/scripts/**/*.js", "./src/scripts/**/*.ts"])
.pipe(eslint(eslintConfig))
.pipe(eslint.format())
.pipe(eslint.failAfterError());
});
task("lint-json", function () {
return src("./static/**/*.json")
.pipe(eslint(eslintConfig))
.pipe(eslint.format())
.pipe(eslint.failAfterError());
});
task("validate-json-schema", function () {
return JSONValidation.validateAll();
});
task("webpack", async function () {
return new Promise((resolve, reject) => {
webpack(webpackDevConfig, (err, stats) => {
if (err) {
return reject(err);
}
if (stats.hasErrors()) {
return reject(new Error(stats.compilation.errors.join("\n")));
}
resolve();
});
});
});
task("webpack-production", async function () {
return new Promise((resolve, reject) => {
webpack(webpackProdConfig, (err, stats) => {
if (err) {
return reject(err);
}
if (stats.hasErrors()) {
return reject(new Error(stats.compilation.errors.join("\n")));
}
resolve();
});
});
});
task("static", function () {
return src("./static/**/*", { dot: true }).pipe(dest("./public/"));
});
task("sass", function () {
return src("./src/styles/*.scss")
.pipe(concat("style.scss"))
.pipe(sass({ outputStyle: "compressed" }).on("error", sass.logError))
.pipe(dest("public/css"));
});
task("compile", series("lint", "lint-json", "webpack", "static", "sass"));
task(
"compile-production",
series(
"lint",
"lint-json",
"validate-json-schema",
"webpack-production",
"static",
"sass"
)
);
task("watch", function () {
watch("./src/styles/*.scss", series("sass"));
watch(
[
"./src/scripts/**/*.js",
"./src/scripts/**/*.ts",
"./src/scripts/*.js",
"./src/scripts/*.ts",
],
series("lint", "webpack")
);
watch(["./static/**/*.*", "./static/*.*"], series("lint-json", "static"));
});
task("build", series("clean", "compile"));
task("build-production", series("clean", "compile-production"));
//PR CHECK
task("validate-quote-json-schema", function () {
return JSONValidation.validateQuotes();
});
task("validate-language-json-schema", function () {
return JSONValidation.validateLanguages();
});
task("validate-other-json-schema", function () {
return JSONValidation.validateOthers();
});
task("pr-check-lint-json", series("lint-json"));
task("pr-check-quote-json", series("validate-quote-json-schema"));
task("pr-check-language-json", series("validate-language-json-schema"));
task("pr-check-other-json", series("validate-other-json-schema"));
task("pr-check-lint", series("lint"));
task("pr-check-scss", series("sass"));
task("pr-check-ts", series("webpack-production"));