mirror of
https://github.com/vacp2p/waku-site.git
synced 2026-01-08 21:18:15 -05:00
65 lines
1.6 KiB
JavaScript
65 lines
1.6 KiB
JavaScript
const { watch, series, src, dest } = require("gulp");
|
|
var browserSync = require("browser-sync").create();
|
|
var postcss = require("gulp-postcss");
|
|
const imagemin = require("gulp-imagemin");
|
|
const uglify = require('gulp-uglify-es').default;
|
|
|
|
// Task for compiling our CSS files using PostCSS
|
|
function cssTask(cb) {
|
|
return src("./src/*.css") // read .css files from ./src/ folder
|
|
.pipe(postcss()) // compile using postcss
|
|
.pipe(dest("./dist/css")) // paste them in ./dist/css folder
|
|
.pipe(browserSync.stream());
|
|
cb();
|
|
}
|
|
|
|
function scriptsTask(cb) {
|
|
return src('./src/*.js')
|
|
.pipe(uglify())
|
|
.pipe(dest('./dist/js'))
|
|
.pipe(browserSync.stream());
|
|
cb();
|
|
}
|
|
|
|
// Task for minifying images
|
|
function imageminTask(cb) {
|
|
return src('./img/**/*')
|
|
.pipe(imagemin())
|
|
.pipe(dest("./dist/img"));
|
|
cb();
|
|
}
|
|
|
|
function htmlBuild(cb) {
|
|
return src("./*.html") // read .css files from ./src/ folder
|
|
.pipe(dest("./dist")) // paste them in ./dist/css folder
|
|
cb();
|
|
}
|
|
|
|
function browsersyncServe(cb) {
|
|
browserSync.init({
|
|
server: {
|
|
baseDir: "./",
|
|
},
|
|
});
|
|
cb();
|
|
}
|
|
|
|
function browsersyncReload(cb) {
|
|
browserSync.reload();
|
|
cb();
|
|
}
|
|
|
|
// Watch Files & Reload browser after tasks
|
|
function watchTask() {
|
|
watch("./**/*.html", browsersyncReload);
|
|
watch(["./src/*.css"], series(cssTask, browsersyncReload));
|
|
watch(["./src/*.js"], series(scriptsTask, browsersyncReload));
|
|
}
|
|
|
|
// Default Gulp Task
|
|
exports.build = series(cssTask, scriptsTask, imageminTask, htmlBuild);
|
|
exports.default = series(cssTask, scriptsTask, imageminTask, htmlBuild, browsersyncServe, watchTask);
|
|
exports.css = cssTask;
|
|
exports.images = imageminTask;
|
|
|