lila/ui/gulp/jsProject.js
Thibault Duplessis 1032095fda UI v2 WIP
2019-02-08 18:13:50 +07:00

52 lines
1.4 KiB
JavaScript

const gulp = require('gulp');
const source = require('vinyl-source-stream');
const buffer = require('vinyl-buffer');
const colors = require('ansi-colors');
const logger = require('fancy-log');
const watchify = require('watchify');
const browserify = require('browserify');
const uglify = require('gulp-uglify');
const size = require('gulp-size');
module.exports = (standalone, fileBaseName, dir) => {
const browserifyOpts = (debug) => ({
entries: [`${dir}/src/main.js`],
standalone: standalone,
debug: debug
});
const destination = () => gulp.dest('../../public/compiled/');
const prod = () => browserify(browserifyOpts(false))
.bundle()
.pipe(source(`${fileBaseName}.min.js`))
.pipe(buffer())
.pipe(uglify())
.pipe(size())
.pipe(destination());
const dev = () => browserify(browserifyOpts(true))
.bundle()
.pipe(source(`${fileBaseName}.js`))
.pipe(destination());
const watch = () => {
const bundle = () => bundler
.bundle()
.on('error', error => logger.error(colors.red(error.message)))
.pipe(source(`${fileBaseName}.js`))
.pipe(destination());
const bundler = watchify(
browserify(Object.assign({}, watchify.args, browserifyOpts(true)))
).on('update', bundle).on('log', logger.info);
return bundle();
};
gulp.task('prod', prod);
gulp.task('dev', dev);
gulp.task('default', watch);
};