2016-11-21 12:24:50 +00:00
|
|
|
'use strict';
|
|
|
|
|
2016-12-08 11:43:13 +00:00
|
|
|
const babelify = require("babelify")
|
|
|
|
const browserify = require('browserify')
|
|
|
|
const gulp = require('gulp')
|
|
|
|
const source = require('vinyl-source-stream')
|
|
|
|
const buffer = require('vinyl-buffer')
|
|
|
|
const rename = require('gulp-rename')
|
|
|
|
const gutil = require('gulp-util')
|
|
|
|
const sass = require('gulp-sass')
|
|
|
|
const uglify = require('gulp-uglify')
|
|
|
|
const pump = require('pump')
|
2018-05-06 09:53:19 +00:00
|
|
|
const es = require('event-stream');
|
2016-12-10 14:58:54 +00:00
|
|
|
const debug = process.env.NODE_ENV !== 'production';
|
2016-11-21 12:24:50 +00:00
|
|
|
|
2018-05-06 09:53:19 +00:00
|
|
|
let defaultTasks = [ 'browserify', 'sass', 'html', 'img' ] ;
|
2016-12-10 14:58:54 +00:00
|
|
|
if( ! debug ) {
|
|
|
|
defaultTasks.push( 'minify' );
|
|
|
|
}
|
|
|
|
|
|
|
|
gulp.task('default', defaultTasks);
|
2016-11-21 12:24:50 +00:00
|
|
|
|
|
|
|
gulp.task('browserify', function () {
|
2018-05-06 09:53:19 +00:00
|
|
|
let files = [
|
|
|
|
'./assets/js/script.js',
|
|
|
|
'./assets/js/tracker.js',
|
|
|
|
];
|
|
|
|
|
|
|
|
var tasks = files.map(function(entry) {
|
|
|
|
return browserify({
|
|
|
|
entries: entry,
|
|
|
|
debug: debug
|
|
|
|
})
|
|
|
|
.transform("babelify", {
|
|
|
|
presets: ["es2015"],
|
|
|
|
plugins: [
|
|
|
|
"transform-decorators-legacy",
|
|
|
|
["transform-react-jsx", { "pragma":"h" } ]
|
|
|
|
]
|
|
|
|
})
|
|
|
|
.bundle()
|
|
|
|
.pipe(source(entry.split('/').pop()))
|
|
|
|
.pipe(gulp.dest('./build/js/'))
|
|
|
|
});
|
|
|
|
// create a merged stream
|
|
|
|
return es.merge.apply(null, tasks);
|
2016-11-21 12:24:50 +00:00
|
|
|
});
|
|
|
|
|
2016-12-08 11:43:13 +00:00
|
|
|
gulp.task('minify', function(cb) {
|
|
|
|
pump([
|
2018-04-25 08:15:24 +00:00
|
|
|
gulp.src('./build/js/*.js'),
|
2016-12-08 11:43:13 +00:00
|
|
|
uglify().on('error', gutil.log),
|
2018-04-25 08:15:24 +00:00
|
|
|
gulp.dest('./build/js/')
|
2016-12-08 11:43:13 +00:00
|
|
|
], cb)
|
|
|
|
});
|
|
|
|
|
2016-11-26 15:17:52 +00:00
|
|
|
gulp.task('img', function() {
|
2018-04-25 08:15:24 +00:00
|
|
|
return gulp.src('./assets/img/**/*')
|
|
|
|
.pipe(gulp.dest('./build/img'))
|
2016-11-26 15:17:52 +00:00
|
|
|
});
|
|
|
|
|
2018-04-20 11:12:23 +00:00
|
|
|
gulp.task('html', function() {
|
2018-04-25 08:15:24 +00:00
|
|
|
return gulp.src('./assets/**/*.html')
|
|
|
|
.pipe(gulp.dest('./build'))
|
2018-04-20 11:12:23 +00:00
|
|
|
});
|
2016-11-26 15:17:52 +00:00
|
|
|
|
2016-11-21 12:24:50 +00:00
|
|
|
gulp.task('sass', function () {
|
2018-04-25 08:15:24 +00:00
|
|
|
var files = './assets/sass/[^_]*.scss';
|
2016-11-21 12:24:50 +00:00
|
|
|
return gulp.src(files)
|
|
|
|
.pipe(sass())
|
2016-11-23 14:51:19 +00:00
|
|
|
.on('error', gutil.log)
|
2016-11-21 12:24:50 +00:00
|
|
|
.pipe(rename({ extname: '.css' }))
|
2018-04-25 08:15:24 +00:00
|
|
|
.pipe(gulp.dest('./build/css'))
|
2016-11-21 12:24:50 +00:00
|
|
|
});
|
2016-11-21 15:01:14 +00:00
|
|
|
|
|
|
|
gulp.task('watch', ['default'], function() {
|
2018-05-06 09:53:19 +00:00
|
|
|
gulp.watch(['./assets/js/**/*.js'], ['browserify'] );
|
2018-04-25 08:15:24 +00:00
|
|
|
gulp.watch(['./assets/sass/**/**/*.scss'], ['sass'] );
|
|
|
|
gulp.watch(['./assets/**/*.html'], ['html'] );
|
2018-05-02 12:52:52 +00:00
|
|
|
gulp.watch(['./assets/img/**/*'], ['img'] );
|
2016-11-21 15:01:14 +00:00
|
|
|
});
|