forked from mdbassit/Coloris
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.babel.js
More file actions
61 lines (52 loc) · 1.48 KB
/
gulpfile.babel.js
File metadata and controls
61 lines (52 loc) · 1.48 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
"use strict";
import gulp from "gulp";
import uglify from "gulp-uglify";
import babel from "gulp-babel";
import replace from 'gulp-replace';
import gulpSass from "gulp-sass";
import nodeSass from "node-sass";
import concat from 'gulp-concat';
import rename from 'gulp-rename';
import cleanCSS from 'gulp-clean-css';
const transpileSass = gulpSass(nodeSass);
const dirs = {
src: "src/*.js",
dest: "./dist",
scss: "src/*.scss"
}
gulp.task("scripts", function() {
return gulp.src(dirs.src)
.pipe(babel({ presets: ['@babel/preset-env'] }))
.pipe(replace('"use strict";', ''))
// transpile to ES5 and create JS file in destination
.pipe(gulp.dest(dirs.dest))
// Minify and rename to *.min.js
.pipe(uglify({
output: {
comments: /^!/
}
}))
.pipe(rename(function (path) {
path.basename += '.min';
}))
.pipe(gulp.dest(dirs.dest));
});
gulp.task("styles", function() {
return gulp.src(dirs.scss)
.pipe(transpileSass().on('error', transpileSass.logError))
// transpile to CSS and create file in destination
.pipe(gulp.dest(dirs.dest))
// Minify and rename to *.min.css
.pipe(cleanCSS())
.pipe(rename(function (path) {
path.basename += '.min';
}))
.pipe(gulp.dest(dirs.dest));
});
gulp.task("watch", () => {
gulp.watch(dirs.src, ["build"]);
gulp.watch(dirs.scss, ["transpileSCSS"]);
})
gulp.task("build",
gulp.series(gulp.parallel('styles', 'scripts'))
);