-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgulpfile.babel.js
94 lines (84 loc) · 2.41 KB
/
gulpfile.babel.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
import gulp from 'gulp';
import del from 'del';
import runSequence from 'run-sequence';
import childProcess from 'child_process';
import eslint from 'gulp-eslint';
import tslint from 'gulp-tslint';
import stylelint from 'gulp-stylelint';
const exec = childProcess.exec;
const spawn = childProcess.spawn;
const isProduction = process.env.NODE_ENV === 'production';
// Run eslint
gulp.task('eslint', () =>
gulp.src(['**/*.js', '**/*.jsx', '!node_modules/**'])
.pipe(eslint())
.pipe(eslint.format('codeframe'))
.pipe(eslint.failAfterError()),
);
// Run tslint
gulp.task('tslint', () =>
gulp.src(['**/*.ts', '**/*.tsx', '!node_modules/**'])
.pipe(tslint({
formatter: 'codeFrame',
}))
.pipe(tslint.report()),
);
// Run stylelint
gulp.task('stylelint', () =>
gulp.src(['**/*.scss', '**/*.css', '!node_modules/**', '!**/materialize/**'])
.pipe(stylelint({
reporters: [
{ formatter: 'string', console: true },
],
})),
);
// Clean webpack generated files
gulp.task('webpack:clean', () => del(['frontend/dist', 'webpack-stats.*.json']));
// Build dll reference files
gulp.task('webpack:build-dll', ['webpack:clean'], (callback) => {
exec('yarn run build-dll', (err, stdout, stderr) => {
console.log(stdout);
console.log(stderr);
callback(err);
});
});
// Generate webpack asset bundles for production
gulp.task('webpack:build-prod', (callback) => {
exec('yarn run build-prod', (err, stdout, stderr) => {
console.log(stdout);
console.log(stderr);
callback(err);
});
});
// Generate webpack asset bundles for development
gulp.task('webpack:build-dev', (callback) => {
const buildDev = spawn('yarn', ['run', 'build-dev']);
buildDev.stdout.on('data', (data) => {
console.log(`${data}`);
});
buildDev.stderr.on('data', (data) => {
console.log(`${data}`);
});
buildDev.on('close', (code) => {
console.log(`child process exited with code ${code}`);
});
buildDev.on('error', (err) => {
callback(err);
});
});
// Generate asset bundles
gulp.task('webpack:build', ['webpack:build-dll'], (callback) => {
if (isProduction) {
runSequence('webpack:build-prod', callback);
} else {
runSequence('webpack:build-dev', callback);
}
});
// Default task
// 1. eslint
// 2. tslint
// 3. stylelint
// 4. generate asset bundles
gulp.task('default', (callback) => {
runSequence('eslint', 'tslint', 'stylelint', 'webpack:build', callback);
});