-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathgulpfile.babel.js
121 lines (99 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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
let browserify = require('browserify'),
gulp = require('gulp'),
source = require('vinyl-source-stream'),
buffer = require('vinyl-buffer'),
del = require('del'),
uglify = require('gulp-uglify'),
babel = require('gulp-babel'),
rename = require('gulp-rename'),
connect = require('gulp-connect'),
open = require('gulp-open'),
Stream = require('merge-stream');
// Define folders
const experiments = [
'experiments/01 - single line/',
'experiments/02 - simple closed shape/',
'experiments/03 - multiple shapes/',
'experiments/04 - SVG as input/',
'experiments/05 - line studies/',
'experiments/06 - shape studies/',
'experiments/07 - bounds/',
'experiments/playground/'
];
// Define globs
const globs = {
js: 'js/**/*.js',
dist: 'dist/**/*',
core: 'core/**/*.js',
allJs: ['core/*.js'],
allHtml: ['index.html']
};
// Build globs for global watch tasks
for(let experiment of experiments) {
globs.allJs.push(experiment + globs.js);
globs.allHtml.push(experiment + 'index.html')
}
//=============
// CLEAN
//=============
// Clean all dist/ folders in all experiments
gulp.task('clean', () => {
for(experiment in experiments) {
del(experiment + globs.dist, {
force: true
});
}
});
//=============
// BUILD
//=============
// Build JS
gulp.task('build:js', () => {
let streams = new Stream();
for(let experiment of experiments) {
let b = browserify({
entries: experiment + 'js/entry.js',
debug: true
});
streams.add(b.bundle()
.pipe(source('app.js'))
.pipe(buffer())
.pipe(babel({
presets: ['@babel/env']
}))
.pipe(uglify())
.pipe(rename('app.min.js'))
.pipe(gulp.dest(experiment + 'dist'))
.pipe(connect.reload()));
}
return streams;
});
// Build all
gulp.task('build', gulp.series(gulp.parallel('clean', 'build:js')));
//=============
// WATCH
//=============
gulp.task('watch', () => {
gulp.watch(globs.allJs, gulp.parallel('build'));
gulp.watch(globs.allHtml, gulp.parallel('build'));
});
//=============
// SERVE
//=============
gulp.task('serve', () => {
connect.server({
root: './',
port: '8080',
livereload: true
});
});
gulp.task('open', () => {
return gulp.src('index.html')
.pipe(open({
uri: 'http://localhost:8080'
}));
});
//=============
// DEFAULT
//=============
gulp.task('default', gulp.series(gulp.parallel('build', 'serve', 'open', 'watch')));