2016-09-06 18:46:28 +02:00
|
|
|
var argv = require('minimist')(process.argv.slice(2));
|
|
|
|
var autoprefixer = require('gulp-autoprefixer');
|
|
|
|
var chmod = require('gulp-chmod');
|
|
|
|
var concat = require('gulp-concat');
|
2017-09-28 15:35:15 +02:00
|
|
|
var git = require('gulp-git');
|
2016-09-06 18:46:28 +02:00
|
|
|
var gulp = require('gulp');
|
|
|
|
var gulpif = require('gulp-if');
|
2018-02-01 17:01:03 +01:00
|
|
|
var pug = require('gulp-pug');
|
2016-09-06 18:46:28 +02:00
|
|
|
var livereload = require('gulp-livereload');
|
|
|
|
var plumber = require('gulp-plumber');
|
|
|
|
var rename = require('gulp-rename');
|
|
|
|
var sass = require('gulp-sass');
|
|
|
|
var sourcemaps = require('gulp-sourcemaps');
|
|
|
|
var uglify = require('gulp-uglify');
|
2016-09-20 15:13:25 +02:00
|
|
|
var cache = require('gulp-cached');
|
2016-09-06 18:46:28 +02:00
|
|
|
|
|
|
|
var enabled = {
|
|
|
|
uglify: argv.production,
|
|
|
|
maps: argv.production,
|
|
|
|
failCheck: argv.production,
|
|
|
|
prettyPug: !argv.production,
|
2017-09-28 15:35:15 +02:00
|
|
|
liveReload: !argv.production,
|
|
|
|
cleanup: argv.production,
|
2016-09-06 18:46:28 +02:00
|
|
|
};
|
|
|
|
|
2017-09-28 15:34:28 +02:00
|
|
|
var destination = {
|
|
|
|
css: 'attract/static/assets/css',
|
|
|
|
pug: 'attract/templates',
|
|
|
|
js: 'attract/static/assets/js/generated',
|
|
|
|
}
|
|
|
|
|
2016-09-20 15:13:25 +02:00
|
|
|
|
2016-09-06 18:46:28 +02:00
|
|
|
/* CSS */
|
|
|
|
gulp.task('styles', function() {
|
|
|
|
gulp.src('src/styles/**/*.sass')
|
|
|
|
.pipe(gulpif(enabled.failCheck, plumber()))
|
|
|
|
.pipe(gulpif(enabled.maps, sourcemaps.init()))
|
|
|
|
.pipe(sass({
|
|
|
|
outputStyle: 'compressed'}
|
|
|
|
))
|
|
|
|
.pipe(autoprefixer("last 3 versions"))
|
|
|
|
.pipe(gulpif(enabled.maps, sourcemaps.write(".")))
|
2017-09-28 15:34:28 +02:00
|
|
|
.pipe(gulp.dest(destination.css))
|
2016-09-06 18:46:28 +02:00
|
|
|
.pipe(gulpif(enabled.liveReload, livereload()));
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2018-02-01 17:01:03 +01:00
|
|
|
/* Templates - Pug */
|
2016-09-06 18:46:28 +02:00
|
|
|
gulp.task('templates', function() {
|
2018-02-01 17:01:03 +01:00
|
|
|
gulp.src('src/templates/**/*.pug')
|
2016-09-06 18:46:28 +02:00
|
|
|
.pipe(gulpif(enabled.failCheck, plumber()))
|
2016-09-20 15:13:25 +02:00
|
|
|
.pipe(cache('templating'))
|
2018-02-01 17:01:03 +01:00
|
|
|
.pipe(pug({
|
2016-09-06 18:46:28 +02:00
|
|
|
pretty: enabled.prettyPug
|
|
|
|
}))
|
2017-09-28 15:34:28 +02:00
|
|
|
.pipe(gulp.dest(destination.pug))
|
2016-09-06 18:46:28 +02:00
|
|
|
.pipe(gulpif(enabled.liveReload, livereload()));
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
/* Individual Uglified Scripts */
|
|
|
|
gulp.task('scripts', function() {
|
|
|
|
gulp.src('src/scripts/*.js')
|
|
|
|
.pipe(gulpif(enabled.failCheck, plumber()))
|
2016-09-20 15:13:25 +02:00
|
|
|
.pipe(cache('scripting'))
|
2016-09-06 18:46:28 +02:00
|
|
|
.pipe(gulpif(enabled.maps, sourcemaps.init()))
|
|
|
|
.pipe(gulpif(enabled.uglify, uglify()))
|
|
|
|
.pipe(rename({suffix: '.min'}))
|
|
|
|
.pipe(gulpif(enabled.maps, sourcemaps.write(".")))
|
|
|
|
.pipe(chmod(644))
|
2017-09-28 15:34:28 +02:00
|
|
|
.pipe(gulp.dest(destination.js))
|
2016-09-06 18:46:28 +02:00
|
|
|
.pipe(gulpif(enabled.liveReload, livereload()));
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2016-09-29 12:22:53 +02:00
|
|
|
/* Collection of scripts in src/scripts/tutti/ to merge into tutti.min.js */
|
|
|
|
/* Since it's always loaded, it's only for functions that we want site-wide */
|
|
|
|
gulp.task('scripts_tutti', function() {
|
|
|
|
gulp.src('src/scripts/tutti/**/*.js')
|
|
|
|
.pipe(gulpif(enabled.failCheck, plumber()))
|
|
|
|
.pipe(gulpif(enabled.maps, sourcemaps.init()))
|
|
|
|
.pipe(concat("tutti.min.js"))
|
|
|
|
.pipe(gulpif(enabled.uglify, uglify()))
|
|
|
|
.pipe(gulpif(enabled.maps, sourcemaps.write(".")))
|
|
|
|
.pipe(chmod(644))
|
2017-09-28 15:34:28 +02:00
|
|
|
.pipe(gulp.dest(destination.js))
|
2016-09-29 12:22:53 +02:00
|
|
|
.pipe(gulpif(enabled.liveReload, livereload()));
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2016-09-06 18:46:28 +02:00
|
|
|
// While developing, run 'gulp watch'
|
|
|
|
gulp.task('watch',function() {
|
2016-09-22 18:09:29 +02:00
|
|
|
// Only listen for live reloads if ran with --livereload
|
|
|
|
if (argv.livereload){
|
|
|
|
livereload.listen();
|
|
|
|
}
|
2016-09-06 18:46:28 +02:00
|
|
|
|
|
|
|
gulp.watch('src/styles/**/*.sass',['styles']);
|
2018-02-01 17:01:03 +01:00
|
|
|
gulp.watch('src/templates/**/*.pug',['templates']);
|
2016-09-06 18:46:28 +02:00
|
|
|
gulp.watch('src/scripts/*.js',['scripts']);
|
2016-09-29 12:22:53 +02:00
|
|
|
gulp.watch('src/scripts/tutti/*.js',['scripts_tutti']);
|
2016-09-06 18:46:28 +02:00
|
|
|
});
|
|
|
|
|
2017-09-28 15:35:15 +02:00
|
|
|
// Erases all generated files in output directories.
|
|
|
|
gulp.task('cleanup', function() {
|
|
|
|
var paths = [];
|
|
|
|
for (attr in destination) {
|
|
|
|
paths.push(destination[attr]);
|
|
|
|
}
|
|
|
|
|
|
|
|
git.clean({ args: '-f -X ' + paths.join(' ') }, function (err) {
|
|
|
|
if(err) throw err;
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2016-09-06 18:46:28 +02:00
|
|
|
|
|
|
|
// Run 'gulp' to build everything at once
|
2017-09-28 15:35:15 +02:00
|
|
|
var tasks = [];
|
|
|
|
if (enabled.cleanup) tasks.push('cleanup');
|
|
|
|
gulp.task('default', tasks.concat(['styles', 'templates', 'scripts', 'scripts_tutti']));
|