Skip to content

Instantly share code, notes, and snippets.

@AugustMiller
Created September 27, 2016 22:06
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save AugustMiller/69dd722115d5a26d98125ad76ac28518 to your computer and use it in GitHub Desktop.
Save AugustMiller/69dd722115d5a26d98125ad76ac28518 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']);
@AugustMiller
Copy link
Author

This assumes your project is structured roughly like this:

├── Gulpfile.js
├── craft
├── public
│   └── assets
│       └── css
│           └── app.css
│       └── js
│           └── app.js
└── src
     ├── coffee
     │   └── app.coffee
     └── sass
         └── app.sass

Untracked, compiled files are output into public/assets folder.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment