Created
September 14, 2016 11:36
-
-
Save grigorkh/cef12dfedee07f94976b429d0487cf55 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
//two main tasks are 'gulp watch' and 'gulp build' | |
//dependencies: | |
var gulp = require('gulp'); | |
//to use in conjunction with chrome plugin: | |
livereload = require('gulp-livereload'); | |
//for css: | |
sass = require('gulp-sass'), | |
autoprefixer = require('gulp-autoprefixer'), | |
minifycss = reqwuire('gulp-minify-css'), | |
rename = require('gulp-rename'); | |
//for javascript: | |
jshint = require('gulp-jshint'); | |
uglify = require('gulp-uglify'); | |
concat = require('gulp-concat'); | |
//for cleaning out dist/ directory before build: | |
rimraf = require('gulp-rimraf'); | |
//angular-specific: | |
ngAnnotate = require('gulp-ng-annotate'); | |
htmlify = require('gulp-angular-htmlify'); | |
//for bundling up js bower dependencies into one vendor file on build: | |
mainBowerFiles = require('main-bower-files'); | |
gulpFilter = require('gulp-filter'); | |
useref = require('gulp-useref'); | |
//paths object to save file paths for ease as gulpfile gets larger | |
var paths = { | |
dev: { | |
css: 'app/public/css', | |
html: 'app/public/**/*.html', | |
sass: 'app/public/scss/*.scss', | |
js: 'app/public/js/**/*.js', | |
bower: 'app/bower_components/**' | |
}, | |
build: { | |
main: 'dist/', | |
css: 'dist/public/css', | |
js: 'dist/public/js' | |
} | |
}; | |
//for now, only used in bower-files task | |
var jsFilter = gulpFilter('*.js'); | |
//watch for changes and compile css and run jshint on those changes | |
//also use livereload to automatically reload page | |
gulp.task('watch', function() { | |
livereload.listen(); | |
gulp.watch(paths.dev.html).on('change', livereload.changed); | |
gulp.watch(paths.dev.sass, ['styles']).on('change', livereload.changed); | |
gulp.watch(paths.dev.js, ['lint']).on('change', livereload.changed); | |
}); | |
//watch scss for changes and render into minified css with nice auto-prefixing | |
gulp.task('styles', function() { | |
return gulp.src(paths.dev.sass) | |
.pipe(sass({ style: 'expanded', errLogToConsole: true })) | |
.pipe(autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1')) | |
.pipe(concat('main.css')) | |
.pipe(rename({suffix: '.min'})) | |
.pipe(minifycss()) | |
.pipe(gulp.dest('app/public/css')); | |
}); | |
//stylish output for errors | |
gulp.task('lint', function() { | |
return gulp.src([paths.dev.js, '!./app/public/bower_components/**']) | |
.pipe(jshint()).on('error', errorHandler) | |
.pipe(jshint.reporter('jshint-stylish')) | |
.pipe(jshint.reporter('fail')); | |
}); | |
//build task, with other tasks as dependencies and then javascript handling in anonymous function | |
gulp.task('build', ['bower-files', 'copy-css', 'copy-server', 'copy-html-files'], function() { | |
return gulp.src(['./app/public/js/**/*.js', '!./app/public/bower_components/**']) | |
.pipe(ngAnnotate()) | |
.pipe(uglify()) | |
.pipe(concat('app.min.js')) | |
.pipe(gulp.dest(paths.build.js)) | |
}); | |
//task to clear out dist/ folder befor building out deployment version of app - runs before every other task in 'gulp build' | |
gulp.task('empty-dist', function() { | |
return gulp.src(paths.build.main, { read: false }) | |
.pipe(rimraf()); | |
}); | |
//copy minified CSS over to /dist | |
gulp.task('copy-css', ['empty-dist'], function () { | |
return gulp.src('./app/public/css/*.css') | |
.pipe(gulp.dest('dist/public/css')); | |
}); | |
//copy html files into build directory, apply html5 data prefix to angular | |
gulp.task('copy-html-files', ['empty-dist'], function () { | |
var assets = useref.assets(); | |
return gulp.src('./app/public/**/*.html') | |
.pipe(assets) | |
.pipe(htmlify()) | |
.pipe(assets.restore()) | |
.pipe(useref()) | |
.pipe(gulp.dest('dist/public')); | |
}); | |
//copy over express server into dist/ folder | |
gulp.task('copy-server', ['empty-dist'], function () { | |
return gulp.src('./app/server.js') | |
.pipe(gulp.dest('dist/')); | |
}) | |
//deal with getting bower dependencies into dist/index.html bower and minify and concat bower js into vendor.min.js | |
gulp.task("bower-files", ['empty-dist'], function(){ | |
return gulp.src(mainBowerFiles()) | |
.pipe(jsFilter) | |
.pipe(uglify()) | |
.pipe(concat('vendor.min.js')) | |
.pipe(gulp.dest("dist/public/js")); | |
}); | |
//error handler helper for jshint | |
function errorHandler (error) { | |
this.emit('end'); | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment