Skip to content

Instantly share code, notes, and snippets.

@Chrisedmo
Forked from AugustMiller/Gulpfile.js
Last active January 8, 2019 11:09
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save Chrisedmo/66bb4da597484dd46454c121dbb05bff to your computer and use it in GitHub Desktop.
Save Chrisedmo/66bb4da597484dd46454c121dbb05bff to your computer and use it in GitHub Desktop.
Craft + Gulp Setup
var gulp = require('gulp'),
gutil = require('gulp-util'),
coffee = require('gulp-coffee'),
coffeeify = require('gulp-coffeeify'),
concat = require('gulp-concat'),
uglify = require('gulp-uglify'),
sass = require('gulp-sass'),
test = require('gulp-if'),
del = require('del'),
rename = require('gulp-rename'),
cssBase64 = require('gulp-css-base64'),
autoprefixer = require('gulp-autoprefixer');
var paths = {
scripts: {
main: ['src/coffee/app.coffee'],
listen: ['src/coffee/**/*.coffee'],
out: 'public/assets/js'
},
stylesheets: {
main: ['src/sass/app.sass'],
listen: ['src/sass/**/*.sass'],
out: 'public/assets/css'
}
};
var templates = {
scripts: function (mangle) {
return gulp.src(paths.scripts.main)
.pipe(coffeeify({
options: {
debug: !mangle,
paths: [__dirname + '/node_modules', __dirname + '/src/coffee']
}
}))
.pipe(test(mangle, uglify(), null))
.pipe(gulp.dest(paths.scripts.out));
},
styles: function (compress) {
return gulp.src(paths.stylesheets.main)
.pipe(sass({
outputStyle: (compress ? 'compressed' : 'expanded'),
includePaths: require('node-neat').includePaths.concat(require('node-reset-scss').includePath)
}).on('error', sass.logError))
.pipe(autoprefixer({
browsers: ['last 2 versions'],
cascade: false
}))
.pipe(cssBase64({
extensionsAllowed: ['.svg']
}))
.pipe(gulp.dest(paths.stylesheets.out));
}
};
// Javascript
gulp.task('scripts:compile', ['scripts:clean'], function () {
templates.scripts(false);
});
gulp.task('scripts:build', ['scripts:clean'], function () {
templates.scripts(true);
});
gulp.task('scripts:clean', function () {
del(['assets/js/*.js']);
});
gulp.task('scripts:watch', function () {
gulp.watch(paths.scripts.listen, ['scripts:compile']);
});
// Sass
gulp.task('stylesheets:compile', ['stylesheets:clean'], function () {
templates.styles(false);
});
gulp.task('stylesheets:build', ['stylesheets:clean'], function () {
templates.styles(true);
});
gulp.task('stylesheets:clean', function () {
del(['assets/css/*.css']);
});
gulp.task('stylesheets:watch', function () {
gulp.watch(paths.stylesheets.listen, ['stylesheets:compile']);
});
// Groups
gulp.task('scripts', ['scripts:watch', 'scripts:compile']);
gulp.task('stylesheets', ['stylesheets:watch', 'stylesheets:compile']);
// Commands
gulp.task('default', ['scripts:compile', 'stylesheets:compile']);
gulp.task('watch', ['scripts', 'stylesheets']);
gulp.task('build', ['scripts:build', 'stylesheets:build']);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment