2015-11-14 00:57:36 +01:00
|
|
|
var gulp = require('gulp')
|
|
|
|
var source = require('vinyl-source-stream')
|
|
|
|
var buffer = require('vinyl-buffer')
|
|
|
|
var minifyCss = require('gulp-minify-css')
|
|
|
|
var browserify = require('browserify')
|
|
|
|
var uglify = require('gulp-uglify')
|
|
|
|
var clean = require('gulp-clean')
|
2015-11-14 01:34:03 +01:00
|
|
|
var connect = require('gulp-connect')
|
2015-11-14 00:57:36 +01:00
|
|
|
|
|
|
|
var config = {
|
|
|
|
files: {
|
2015-11-14 01:34:03 +01:00
|
|
|
mainJs: 'webapp/app.jsx',
|
2015-11-14 00:57:36 +01:00
|
|
|
css: 'webapp/*.css',
|
2015-11-14 01:34:03 +01:00
|
|
|
js: ['webapp/*.js','webapp/*.jsx'],
|
|
|
|
html: 'webapp/*.html'
|
2015-11-14 00:57:36 +01:00
|
|
|
},
|
|
|
|
dest: 'webapp/dist/'
|
|
|
|
}
|
|
|
|
|
|
|
|
gulp.task('css',function(){
|
|
|
|
gulp.src(config.files.css)
|
|
|
|
.pipe(minifyCss())
|
|
|
|
.pipe(gulp.dest(config.dest))
|
2015-11-14 01:34:03 +01:00
|
|
|
.pipe(connect.reload())
|
2015-11-14 00:57:36 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
gulp.task('html',function(){
|
|
|
|
gulp.src(config.files.html)
|
|
|
|
.pipe(gulp.dest(config.dest))
|
2015-11-14 01:34:03 +01:00
|
|
|
.pipe(connect.reload())
|
2015-11-14 00:57:36 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
gulp.task('js',function(){
|
2015-11-14 01:07:52 +01:00
|
|
|
browserify(config.files.mainJs)
|
|
|
|
.transform('babelify', { presets: [ 'es2015', 'react' ]})
|
2015-11-14 10:46:42 +01:00
|
|
|
.transform('eslintify')
|
2015-11-14 01:07:52 +01:00
|
|
|
.bundle()
|
2015-11-14 00:57:36 +01:00
|
|
|
.on('error', console.error.bind(console))
|
|
|
|
.pipe(source('app.js')) // do this or browserify won't work
|
|
|
|
.pipe(buffer()) // do this or uglify won't work
|
2015-11-14 12:06:37 +01:00
|
|
|
//.pipe(uglify())
|
2015-11-14 00:57:36 +01:00
|
|
|
.pipe(gulp.dest(config.dest))
|
2015-11-14 01:34:03 +01:00
|
|
|
.pipe(connect.reload())
|
2015-11-14 00:57:36 +01:00
|
|
|
})
|
|
|
|
|
2015-11-14 10:46:42 +01:00
|
|
|
|
|
|
|
|
2015-11-14 00:57:36 +01:00
|
|
|
gulp.task('clean',function(){
|
|
|
|
gulp.src(config.dest, { read: false })
|
|
|
|
.pipe(clean())
|
|
|
|
})
|
|
|
|
|
2015-11-14 10:46:42 +01:00
|
|
|
gulp.task('server',function(){
|
2015-11-14 01:34:03 +01:00
|
|
|
connect.server({
|
|
|
|
root: config.dest,
|
|
|
|
port: 9090,
|
|
|
|
livereload: true
|
2015-11-14 10:46:42 +01:00
|
|
|
})
|
2015-11-14 01:34:03 +01:00
|
|
|
})
|
|
|
|
|
2015-11-14 00:57:36 +01:00
|
|
|
gulp.task('watch',function(){
|
|
|
|
gulp.watch(config.files.js,['js'])
|
|
|
|
gulp.watch(config.files.html,['html'])
|
|
|
|
gulp.watch(config.files.css,['css'])
|
|
|
|
})
|
|
|
|
|
2015-11-14 10:46:42 +01:00
|
|
|
gulp.task('serve', [ 'html', 'css', 'js', 'watch', 'server' ])
|
|
|
|
|
|
|
|
gulp.task('default', [ 'html', 'css', 'js' ])
|