-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathgulpfile.js
114 lines (99 loc) · 2.63 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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
const gulp = require('gulp');
const { series, parallel } = require('gulp');
const babel = require('gulp-babel');
const browserSync = require('browser-sync').create();
const cache = require('gulp-cached');
const del = require('del');
const eslint = require('gulp-eslint');
const gulpif = require('gulp-if');
const uglify = require('gulp-uglify-es').default;
const prettier = require('gulp-prettier');
const sourcemaps = require('gulp-sourcemaps');
const SRC = './src';
const DIST = './dist';
const BUILD = './build';
function isDevEnv() {
return process.env.NODE_ENV !== 'production';
}
function getBuildTarget() {
return isDevEnv() ? DIST : BUILD;
}
function reload(done) {
browserSync.reload();
done();
}
function clean() {
return del([BUILD + '/**']);
};
function cleanDist() {
return del([DIST + '/**']);
}
function assets() {
return gulp.src([SRC + '/**/*',
'!' + SRC + '/**/*.js',
SRC + '/**/*.min.js',
])
.pipe(cache('assets'))
.pipe(gulp.dest(getBuildTarget()));
};
function scripts() {
const dev = isDevEnv();
return gulp.src([SRC + '/**/*.js',
'!' + SRC + '/**/*.min.js'])
.pipe(cache('scripts'))
.pipe(gulpif(!!dev, sourcemaps.init()))
.pipe(babel({
presets: [
['@babel/preset-env',
{
'targets': {
'esmodules' : true
},
'modules' : false
}]]
}))
.pipe(gulpif(!dev, uglify()))
.pipe(gulpif(!!dev, sourcemaps.write('.')))
.pipe(gulp.dest(getBuildTarget()));
};
function prettify() {
return gulp.src([SRC + '/**/*.js',
'!' + SRC + '/**/*.min.js'])
.pipe(prettier({ singleQuote: true }))
.pipe(gulp.dest(SRC));
}
function lint() {
return gulp.src('./src/**/*.js')
.pipe(eslint({
fix: true
}))
.pipe(eslint.format());
}
function serve(done) {
browserSync.init({
server: {
baseDir: getBuildTarget(),
directory: true,
serveStaticOptions: {
extensions: ['html']
}
},
ghostmode: {
clicks: true,
forms: true,
scroll: true
},
open: false
});
gulp.watch(SRC + '/**/*.html', series(assets, reload));
gulp.watch(SRC + '/**/*.css', series(assets, reload));
gulp.watch(SRC + '/**/*.js', series(scripts, reload));
};
gulp.task('prettier', prettify);
gulp.task('lint', lint);
gulp.task('scripts', scripts);
gulp.task('clean', clean);
gulp.task('assets', assets);
gulp.task('cleanDist', cleanDist);
gulp.task('build', series(clean, assets, scripts));
gulp.task('default', series(clean, assets, scripts, serve));