-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathgulpfile.js
112 lines (95 loc) · 3.12 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
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
var gulp = require('gulp');
var concat = require('gulp-concat');
var imagemin = require('gulp-imagemin');
var sass = require('gulp-sass');
var watch = require('gulp-watch');
var gprint = require('gulp-print');
var clean = require('gulp-clean');
var gprint = require('gulp-print');
var connect = require('gulp-connect');
var wait = require('gulp-wait');
var gutil = require('gulp-util');
var sourcemaps = require('gulp-sourcemaps');
var source = require('vinyl-source-stream');
var buffer = require('vinyl-buffer');
var watchify = require('watchify');
var browserify = require('browserify');
var reactify = require('reactify');
var ROOT = __dirname + '/build';
var reactifyES6 = function(file) {
return reactify(file, {es6: true, target: 'es5'});
};
// https://github.com/gulpjs/gulp/blob/master/docs/recipes/fast-browserify-builds-with-watchify.md
// http://christianalfoni.github.io/javascript/2014/08/15/react-js-workflow.html
gulp.task('browserify', function() {
var watcher = watchify(browserify({
entries: ['./client/js/main.js'],
debug: true,
extension: ['.jsx'],
transform: [reactifyES6],
cache: {},
packageCache: {},
fullPaths: true,
}));
watcher.on('log', gutil.log);
return watcher.on('update', function() {
var updateStart = Date.now();
watcher.bundle()
.pipe(source('main.js'))
.pipe(gulp.dest('./build/js/'))
.pipe(gprint())
.pipe(connect.reload());
})
.bundle()
.pipe(source('main.js'))
.pipe(gulp.dest('./build/js/'))
.pipe(gprint());
});
gulp.task('clean', function () {
return gulp.src('build/', {read: false})
.pipe(clean());
});
gulp.task('styles', function () {
var postcss = require('gulp-postcss');
var sourcemaps = require('gulp-sourcemaps');
var autoprefixer = require('autoprefixer-core');
var autoprefix = autoprefixer({browsers: ['last 2 version']});
gulp.src('client/scss/main.scss')
.pipe(sass())
.pipe(postcss([autoprefix]))
.pipe(gulp.dest('build/css/'))
.pipe(gprint())
.pipe(connect.reload());
});
gulp.task('copy-html', function(){
gulp.src('client/*.html')
.pipe(gulp.dest('build/'))
.pipe(gprint());
});
gulp.task('copy-gtfs', function(){
gulp.src('gtfs/**/*')
.pipe(gulp.dest('build/gtfs'))
.pipe(gprint());
});
gulp.task('watch', function() {
gulp.watch('client/scss/**/*.scss', [ 'styles' ]);
gulp.watch('client/*.html', [ 'copy-html' ]);
});
gulp.task('webserver', function() {
connect.server({
livereload: true,
root: 'build',
host: '0.0.0.0',
port: 1234,
});
});
gulp.task('deploy-gh-pages', function() {
var ghpages = require('gulp-gh-pages');
return gulp.src('./build/**/*')
.pipe(ghpages({
cacheDir: '/tmp/instabus-react',
message: 'Deploy to gh-pages :poop:' + new Date(),
}));
});
gulp.task('build', ['clean', 'styles', 'browserify', 'copy-html', 'copy-gtfs']);
gulp.task('default', ['build', 'webserver', 'watch']);