-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
43 lines (33 loc) · 1.19 KB
/
gulpfile.js
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
/* global require, exports */
const { src, dest, parallel, watch, series } = require('gulp');
const del = require('del');
const sass = require('gulp-sass');
const autoprefixer = require('gulp-autoprefixer');
const cssnano = require('gulp-cssnano');
const babel = require('gulp-babel');
const uglify = require('gulp-uglify');
sass.compiler = require('node-sass');
const cleanCSS = () => del('./build/css/**/*.css');
const cleanJS = () => del('./build/js/**/*.js');
const browsersList = ['> 1%', 'last 2 versions', 'ie >= 11'];
const compileSCSS = () =>
src('./src/scss/**/*.scss')
.pipe(sass())
.pipe(autoprefixer({ overrideBrowserslist: browsersList }))
.pipe(cssnano())
.pipe(dest('./build/css'));
const transpileJS = () =>
src('./src/js/**/*.js')
.pipe(babel())
.pipe(uglify())
.pipe(dest('./build/js'));
const buildCSS = series(cleanCSS, compileSCSS);
const buildJS = series(cleanJS, transpileJS);
const watchCSS = () => {
watch('./src/scss/**/*.scss', buildCSS);
};
const watchJS = () => {
watch('./src/js/**/*.js', buildJS);
};
exports.build = parallel(buildCSS, buildJS);
exports.watch = exports.default = parallel(watchCSS, watchJS);