This repository has been archived on 2025-01-25. You can view files and clone it, but cannot push or open issues or pull requests.
scrum-board/gulpfile.js
2020-12-31 18:22:54 +01:00

112 lines
3.3 KiB
JavaScript

/**
* scrum-board
*
* @category scrum-board
* @author Vaibhav Mehta <vaibhav@decodingweb.com>, Mats van Reenen <mail@matsvanreenen.nl>
* @copyright Copyright (c) 2016,2020 Vaibhav Mehta <https://github.com/i-break-codes>
* @license http://www.opensource.org/licenses/mit-license.html MIT License
* @version 1.0 Beta
*/
const BrowserSync = require('browser-sync');
const Gulp = require('gulp');
Gulp.clean = require('gulp-clean');
const sass = require('gulp-sass');
const autoprefixer = require('gulp-autoprefixer');
const cleanCSS = require('gulp-clean-css');
const uglify = require('gulp-uglify');
const renameFiles = require('gulp-rename');
const Url = 'http://localhost:8888/scrum/';
const Browser = 'google chrome';
function browserSync(cb){
BrowserSync.init({
server: {
// baseDir: "app",
proxy: Url,
// files: ['app/views/**/*.*', 'public/**/*.css', 'public/**/*.js'],
browser: Browser,
port: 3005,
// open: false
}
}, function (err, bs){
cb();
});
};
function bsReload(cb){
BrowserSync.reload();
cb();
};
function css(){
return Gulp.src('src/stylesheets/**/*.scss')
.pipe(sass().on('error', sass.logError))
.pipe(autoprefixer('last 3 version'))
.pipe(Gulp.dest('app/assets/stylesheets'))
}
function cssMinify(){
return Gulp.src(['app/assets/stylesheets/**/*.css', '!app/assets/stylesheets/**/*.min.css'])
.pipe(cleanCSS({debug: true}, function(details) {
console.log('Original Size : ' + details.name + ': ' + details.stats.originalSize + ' bytes');
console.log('Minified Size : ' + details.name + ': ' + details.stats.minifiedSize + ' bytes');
}))
.pipe(renameFiles({ suffix: '.min' }))
.pipe(Gulp.dest('app/assets/stylesheets'))
// .pipe(browserSync.reload({ // ??
// stream:true
// }));
};
function jsMinify(){
return Gulp.src('src/scripts/**/*.js')
.pipe(uglify())
.pipe(renameFiles({ suffix: '.min' }))
.pipe(Gulp.dest('app/assets/scripts'))
// .pipe(browserSync.reload({ // ??
// stream: true,
// once: true
// }));
};
function clean(mode = 'all'){
const opts = {read: false, allowEmpty: true}
switch(mode){
case 'cssTmp':
return function cleanTmpCSS(){
return Gulp.src(['app/assets/stylesheets/**/*.css', '!app/assets/stylesheets/**/*.min.css'], opts)
.pipe(Gulp.clean())
}
case 'tmp':
return clean('cssTmp');
case 'css':
return function cleanCSS(){
return Gulp.src(['app/assets/stylesheets'], opts)
.pipe(Gulp.clean())
}
case 'js':
return function cleanJS(){
return Gulp.src(['app/assets/scripts'], opts)
.pipe(Gulp.clean())
}
case 'all':
return Gulp.parallel(clean('css'), clean('js'));
default:
console.log(`WARNING: Clean: invalid mode '${mode}'`)
console.log(`dong 'tmp' instad of '${mode}'`)
return clean('tmp')
}
}
const cssTask = Gulp.series(css, cssMinify, clean('cssTmp'));
const jsTask = jsMinify;
const buildTask = Gulp.parallel(cssTask, jsTask);
exports.clean = clean('all');
exports.server = browserSync;
exports.cssBuild = cssTask;
exports.jsBuild = jsTask;
exports.build = Gulp.series(clean('all'), buildTask);
exports.default = Gulp.series(buildTask, browserSync);