-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
108 lines (95 loc) · 2.99 KB
/
gulpfile.js
File metadata and controls
108 lines (95 loc) · 2.99 KB
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
const gulp = require("gulp");
const browserSync = require("browser-sync").create();
const less = require("gulp-less");
const browserify = require("browserify");
const gulpIf = require("gulp-if");
const babelify = require("babelify");
const buffer = require("vinyl-buffer");
const source = require("vinyl-source-stream");
const LessAutoprefix = require("less-plugin-autoprefix");
const yargs = require("yargs");
const watchify = require("watchify");
const gutil = require("gulp-util");
const envify = require("envify/custom");
const sourcemaps = require('gulp-sourcemaps');
const reload = browserSync.reload;
const del = require('del')
let isDebug = Boolean(yargs.debug);
// less autoprefix
let autoprefix = new LessAutoprefix({ browsers: ['> 5%', 'Firefox >= 20'] });
let customOpts = {
entries: ['./demo/index.js'],
debug: isDebug
}
let opts = Object.assign({}, watchify.args, customOpts);
let babelOpts = {
presets: ["es2015", "stage-0", "react"],
plugins: ["transform-remove-strict-mode", "transform-object-assign"]
}
let watchifyTask = watchify(browserify(opts)
.transform("babelify", babelOpts)
.transform(envify({
NODE_ENV: "development"
}))
);
watchifyTask.on('update', bundle);
watchifyTask.on('log', gutil.log)
function bundle() {
return watchifyTask.bundle()
// log errors if they happen
.on('error', gutil.log.bind(gutil, 'Browserify Error'))
.pipe(source('all.js'))
// optional, remove if you don't need to buffer file contents
.pipe(buffer())
// optional, remove if you dont want sourcemaps
//loads map from browserify file
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(sourcemaps.write('./')) // writes .map file
.pipe(gulp.dest('./demo/dist'))
}
gulp.task('develop', bundle);
gulp.task('clean', (cb) => {
return del(['./*.map'], cb);
});
gulp.task('build', ['clean'], () => {
return browserify(customOpts)
.transform("babelify", babelOpts)
.transform(envify({
NODE_ENV: "production"
}))
.bundle()
.pipe(source('all.js'))
.pipe(buffer())
.pipe(gulpIf(isDebug, uglify({
mangling: false,
output: {
ascii_only: true
}
})))
.on('error', gutil.log)
.pipe(gulp.dest('./demo/dist'));
});
gulp.task('server', () => {
return browserSync.init({
server: {
baseDir: './demo/dist'
},
port: 3000
})
})
gulp.task('css', () => {
return gulp.src(['demo/less/*.less'])
.pipe(less({
plugins: [autoprefix]
}))
.pipe(gulp.dest('./demo/dist/css'));
})
gulp.task('watch', () => {
gulp.watch(['./demo/less/*.less'], ['css']).on('change', () => {
reload();
});
gulp.watch(['./demo/dist/*.js', './demo/dist/*.html']).on('change', reload);
})
gulp.task('default', ['server', 'watch', 'develop'], () => {
console.log(`default task is runing! \n current debug is ${isDebug}`);
})