fathom/gulpfile.js

56 lines
1.4 KiB
JavaScript

'use strict';
// TODO: Minify JS
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');
gulp.task('default', [ 'browserify', 'sass', 'tracker' ] );
gulp.task('browserify', function () {
return browserify({
entries: './assets/js/script.js',
debug: true
})
.transform("babelify", {presets: ["es2015"]})
.bundle()
.on('error', function(err){
console.log(err.message);
this.emit('end');
})
.pipe(source('script.js'))
.pipe(buffer())
.pipe(gulp.dest('./static/js/'))
});
gulp.task('img', function() {
return gulp.src('./assets/img/**/*')
.pipe(gulp.dest('./static/img'))
});
gulp.task('tracker', function() {
return gulp.src('./assets/js/tracker.js')
.pipe(gulp.dest('./static/js'))
});
gulp.task('sass', function () {
var files = './assets/sass/[^_]*.scss';
return gulp.src(files)
.pipe(sass())
.on('error', gutil.log)
.pipe(rename({ extname: '.css' }))
.pipe(gulp.dest('./static/css'))
});
gulp.task('watch', ['default'], function() {
gulp.watch(['./assets/js/**/*.js'], ['browserify', 'tracker'] );
gulp.watch(['./assets/sass/**/*.scss'], ['sass'] );
});