Guest User

Untitled

a guest
Oct 28th, 2016
60
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 2.27 KB | None | 0 0
  1. /*!
  2. * gulp
  3. * $ npm install gulp-ruby-sass gulp-autoprefixer gulp-cssnano gulp-jshint gulp-concat gulp-uglify gulp-imagemin gulp-notify gulp-rename gulp-livereload gulp-cache del --save-dev
  4. */
  5.  
  6. // Load plugins
  7. var gulp = require('gulp'),
  8. sass = require('gulp-ruby-sass'),
  9. autoprefixer = require('gulp-autoprefixer'),
  10. cssnano = require('gulp-cssnano'),
  11. jshint = require('gulp-jshint'),
  12. uglify = require('gulp-uglify'),
  13. imagemin = require('gulp-imagemin'),
  14. rename = require('gulp-rename'),
  15. concat = require('gulp-concat'),
  16. notify = require('gulp-notify'),
  17. cache = require('gulp-cache'),
  18. livereload = require('gulp-livereload'),
  19. del = require('del');
  20.  
  21. // Styles
  22. gulp.task('styles', function() {
  23. return sass('src/styles/main.scss', { style: 'expanded' })
  24. .pipe(autoprefixer('last 2 version'))
  25. .pipe(gulp.dest('dist/styles'))
  26. .pipe(rename({ suffix: '.min' }))
  27. .pipe(cssnano())
  28. .pipe(gulp.dest('dist/styles'))
  29. .pipe(notify({ message: 'Styles task complete' }));
  30. });
  31.  
  32. // Scripts
  33. gulp.task('scripts', function() {
  34. return gulp.src('src/scripts/**/*.js')
  35. .pipe(jshint('.jshintrc'))
  36. .pipe(jshint.reporter('default'))
  37. .pipe(concat('main.js'))
  38. .pipe(gulp.dest('dist/scripts'))
  39. .pipe(rename({ suffix: '.min' }))
  40. .pipe(uglify())
  41. .pipe(gulp.dest('dist/scripts'))
  42. .pipe(notify({ message: 'Scripts task complete' }));
  43. });
  44.  
  45. // Images
  46. gulp.task('images', function() {
  47. return gulp.src('src/images/**/*')
  48. .pipe(cache(imagemin({ optimizationLevel: 3, progressive: true, interlaced: true })))
  49. .pipe(gulp.dest('dist/images'))
  50. .pipe(notify({ message: 'Images task complete' }));
  51. });
  52.  
  53. // Clean
  54. gulp.task('clean', function() {
  55. return del(['dist/styles', 'dist/scripts', 'dist/images']);
  56. });
  57.  
  58. // Default task
  59. gulp.task('default', ['clean'], function() {
  60. gulp.start('styles', 'scripts', 'images');
  61. });
  62.  
  63. // Watch
  64. gulp.task('watch', function() {
  65.  
  66. // Watch .scss files
  67. gulp.watch('src/styles/**/*.scss', ['styles']);
  68.  
  69. // Watch .js files
  70. gulp.watch('src/scripts/**/*.js', ['scripts']);
  71.  
  72. // Watch image files
  73. gulp.watch('src/images/**/*', ['images']);
  74.  
  75. // Create LiveReload server
  76. livereload.listen();
  77.  
  78. // Watch any files in dist/, reload on change
  79. gulp.watch(['dist/**']).on('change', livereload.changed);
  80.  
  81. });
Add Comment
Please, Sign In to add comment