1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-05 11:25:09 +01:00
onion/gulpfile.js

123 lines
3.3 KiB
JavaScript
Raw Normal View History

'use strict';
var gulp = require('gulp');
var gulpif = require('gulp-if');
var sourcemaps = require('gulp-sourcemaps');
var util = require('gulp-util');
var source = require('vinyl-source-stream');
var buffer = require('vinyl-buffer');
var watchify = require('watchify');
var browserify = require('browserify');
var browserSync = require('browser-sync');
var babelify = require('babelify');
var notify = require('gulp-notify');
var sass = require('gulp-sass');
var concat = require('gulp-concat');
var _ = require('lodash');
2015-06-05 09:17:41 +02:00
var eslint = require('gulp-eslint');
2015-05-29 13:38:59 +02:00
var config = {
bootstrapDir: './node_modules/bootstrap-sass'
2015-05-29 13:38:59 +02:00
};
gulp.task('build', function() {
bundle(false);
});
gulp.task('serve', ['browser-sync', 'lint:watch', 'sass', 'sass:watch', 'copy'], function() {
bundle(true);
});
gulp.task('browser-sync', function() {
browserSync({
server: {
baseDir: "."
},
port: process.env.PORT || 3000
});
});
gulp.task('sass', function () {
gulp.src('./sass/**/main.scss')
.pipe(sourcemaps.init())
2015-05-29 13:38:59 +02:00
.pipe(sass({
includePaths: [
config.bootstrapDir + '/assets/stylesheets'
]
}).on('error', sass.logError))
.pipe(sourcemaps.write('./maps'))
.pipe(gulp.dest('./build/css'))
2015-05-29 12:08:26 +02:00
.pipe(browserSync.stream());;
});
gulp.task('sass:watch', function () {
2015-05-29 13:38:59 +02:00
gulp.watch('./sass/**/*.scss', ['sass']);
});
2015-05-29 11:57:24 +02:00
gulp.task('copy', function () {
var files = [
2015-05-29 11:57:24 +02:00
'./fonts/**/*',
2015-05-29 13:38:59 +02:00
'./img/**/*'
2015-05-29 11:57:24 +02:00
];
gulp.src(files, {base: './'})
.pipe(gulp.dest('build'));
2015-05-29 13:38:59 +02:00
gulp.src(config.bootstrapDir + '/assets/fonts/**/*')
.pipe(gulp.dest('./build/fonts'));
2015-05-29 11:57:24 +02:00
});
2015-06-05 09:17:41 +02:00
gulp.task('lint', function () {
return gulp.src(['js/**/*.js'])
// eslint() attaches the lint output to the eslint property
// of the file object so it can be used by other modules.
.pipe(eslint())
// eslint.format() outputs the lint results to the console.
// Alternatively use eslint.formatEach() (see Docs).
.pipe(eslint.format())
// To have the process exit with an error code (1) on
// lint error, return the stream and pipe to failOnError last.
.pipe(eslint.failOnError());
});
gulp.task('lint:watch', function () {
gulp.watch('js/**/*.js', ['lint']);
});
function bundle(watch) {
var bro;
if (watch) {
bro = watchify(browserify('./js/app.js',
// Assigning debug to have sourcemaps
_.assign(watchify.args, {
debug: true
})));
bro.on('update', function() {
rebundle(bro, true);
});
} else {
bro = browserify('./js/app.js', {
debug: true
});
}
bro.transform(babelify.configure({
compact: false
}));
function rebundle(bundler, watch) {
return bundler.bundle()
.on('error', notify.onError('Error: <%= error.message %>'))
.pipe(source('app.js'))
.pipe(buffer())
.pipe(sourcemaps.init({
loadMaps: true
})) // loads map from browserify file
.pipe(sourcemaps.write()) // writes .map file
.pipe(gulp.dest('./build'))
.pipe(browserSync.stream());
}
return rebundle(bro);
}