-
Notifications
You must be signed in to change notification settings - Fork 0
/
gulpfile.js
76 lines (61 loc) · 1.96 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
let gulp = require('gulp');
let watch = require('gulp-watch');
let sequence = require('gulp-watch-sequence');
let browserSync = require('browser-sync').create();
let gulpSequence = require('gulp-sequence');
let nodemon = require('nodemon');
let inject = require('gulp-inject-string');
//let run = require('gulp-run-command').default;
let shell = require('gulp-shell')
//--------------------------------------
gulp.task('start-server', (cb) => {
let started = false;
return nodemon({
script: 'server.js'
}).on('start', () => {
if (!started) {
cb();
started = true;
}
});
});
//--------------------------------------
//--------------------------------------
gulp.task('rebuild-webpack', shell.task([
'npm run build'
]))
//--------------------------------------
//--------------------------------------
gulp.task('trigger-sync', () => {
gulp.src('./bsync.js')
.pipe(inject.append('//reload'))
.pipe(gulp.dest('./'));
});
//--------------------------------------
//--------------------------------------
gulp.task('browser-sync', ['start-server'], () => {
// AFTER STARTER HAS BEEN STARTED, START BROWSERSYNC
browserSync.init(null,
{proxy: 'http://localhost:3000',
files: ['server.js', 'bsync.js'],
port: 3030,
reloadDelay: 2000}
)
// IF ANY OF THESE FILES HAVE BEEN CHANGED, COMPILE THEN START TRIGGER-SYNC, WHICH KICKS OFF BROWSERSYNC
let queue = sequence(100);// SMALL DELAY SO CLEARHTML DOESN'T BREAK
/* CSS */
watch('src/**/*.*', {
emitOnGlob: false
}, queue.getHandler('rebuild-webpack'));
/* CSS */
watch('dist/server.js', {
emitOnGlob: false
}, queue.getHandler('trigger-sync'));
})
//--------------------------------------
//--------------------------------------
gulp.task('build', ['rebuild-webpack'], () => {});
//--------------------------------------
//--------------------------------------
gulp.task('default', ['browser-sync'], () => {});
//--------------------------------------