Skip to content

Instantly share code, notes, and snippets.

@mattmcgiv
Created January 4, 2016 19:20
Show Gist options
  • Select an option

  • Save mattmcgiv/2e2cc89cd47112696cf9 to your computer and use it in GitHub Desktop.

Select an option

Save mattmcgiv/2e2cc89cd47112696cf9 to your computer and use it in GitHub Desktop.
Sample gulpfile to get started
// Include gulp
var gulp = require('gulp');
// Include Our Plugins
var jshint = require('gulp-jshint');
var sass = require('gulp-sass');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var rename = require('gulp-rename');
var browserSync = require('browser-sync').create();
var autoprefixer = require('gulp-autoprefixer');
// Lint Task
gulp.task('lint', function() {
return gulp.src('assets/scripts/*.js')
.pipe(jshint())
.pipe(jshint.reporter('default'));
});
// Compile Our Sass
gulp.task('sass', function() {
return gulp.src('assets/styles/*.scss')
.pipe(sass())
.pipe(gulp.dest('dist/styles'))
// .pipe(autoprefixer, {
// browsers: [
// 'last 2 versions',
// 'ie 8',
// 'ie 9',
// 'android 2.3',
// 'android 4',
// 'opera 12'
// ]
// })
.pipe(gulp.dest('dist/styles'))
.pipe(browserSync.stream());
});
// Concatenate & Minify JS
gulp.task('scripts', function() {
return gulp.src('assets/scripts/*.js')
.pipe(concat('all.js'))
.pipe(gulp.dest('dist/scripts'))
.pipe(rename('all.min.js'))
.pipe(uglify())
.pipe(gulp.dest('dist/scripts'));
});
// Static Server + watching scss/html files
gulp.task('serve', ['sass'], function() {
browserSync.init({
files: ['{lib,templates,includes}/**/*.php', '*.php'],
proxy: 'windycitycurling.dev',
snippetOptions: {
whitelist: ['/wp-admin/admin-ajax.php'],
blacklist: ['/wp-admin/**']
}
});
gulp.watch(['assets/styles/**/*'], ['sass']);
gulp.watch(['assets/scripts/**/*'], ['jshint', 'scripts']);
// gulp.watch([path.source + 'fonts/**/*'], ['fonts']);
// gulp.watch([path.source + 'images/**/*'], ['images']);
// gulp.watch(['bower.json', 'assets/manifest.json'], ['build']);
});
// Watch Files For Changes
gulp.task('watch', function() {
gulp.watch('assets/scripts/*.js', ['lint', 'scripts']);
});
// Default Task
gulp.task('default',
['lint',
'sass',
'scripts',
'serve',
// 'browser-sync',
'watch']
);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment