-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
85 lines (72 loc) · 2.19 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
var gulp = require('gulp');
var gutil = require('gulp-util');
var concat = require('gulp-concat');
var connect = require('gulp-connect');
var streamify = require('gulp-streamify');
var source = require('vinyl-source-stream');
var browserify = require('browserify');
var babelify = require('babelify');
var lessify = require('node-lessify');
var less = require('gulp-less');
var concatCss = require('gulp-concat-css');
var uglify = require('gulp-uglify');
var ghPages = require('gulp-gh-pages');
var LessPluginCleanCSS = require('less-plugin-clean-css'),
LessPluginAutoPrefix = require('less-plugin-autoprefix'),
cleancss = new LessPluginCleanCSS({ advanced: true }),
autoprefix= new LessPluginAutoPrefix({ browsers: ["last 2 versions"] });
gulp.task('build', function() {
browserify('./src/app.js')
.transform(babelify, {
presets: ["react", "es2015", "stage-0"]
})
.transform(lessify)
.bundle()
.on('error', function(err) {
gutil.log(err);
})
.pipe(source('./src/app.js'))
.pipe(streamify(concat('bundle.js')))
.pipe(streamify(uglify({
mangle: true,
})))
.pipe(gulp.dest('dist'))
})
gulp.task('less', function() {
gulp.src('./src/components/**/*.less')
.pipe(less({
plugins: [autoprefix, cleancss]
}))
.pipe(concatCss("bundle.css"))
.pipe(gulp.dest('./assets/css'))
})
gulp.task('server', function() {
connect.server({
root: './',
livereload: true
});
})
gulp.task('reload', function() {
gulp.src('dist/bundle.js')
.pipe(connect.reload())
})
gulp.task('watch', function() {
gulp.watch('src/**/*', ['build', 'less', 'reload'])
})
gulp.task('assets', function() {
gulp.src('assets/**/*')
.pipe(gulp.dest('dist/assets'))
})
gulp.task('cname', function() {
gulp.src('CNAME')
.pipe(gulp.dest('dist'))
})
gulp.task('deploy', function () {
return gulp.src("./dist/**/*")
.pipe(ghPages({
branch: 'master'
}))
});
gulp.task('default', ['build', 'less'])
gulp.task('develop', ['server', 'watch'])
gulp.task('prod', ['build', 'less', 'assets', 'cname']);