-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgulpfile.js
More file actions
83 lines (71 loc) · 1.98 KB
/
gulpfile.js
File metadata and controls
83 lines (71 loc) · 1.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
var gulp = require('gulp'),
plumber = require('gulp-plumber'),
gutil = require('gulp-util'),
sass = require('gulp-sass'),
minifycss = require('gulp-minify-css'),
autoprefixer = require('gulp-autoprefixer'),
uglify = require('gulp-uglify'),
rev = require('gulp-rev'),
imagemin = require('gulp-imagemin'),
clean = require('gulp-clean'),
concat = require('gulp-concat'),
cache = require('gulp-cache'),
rename = require('gulp-rename'),
browserSync = require('browser-sync'),
reload = browserSync.reload;
var onError = function (err) {
gutil.beep();
console.log(err);
};
//sync
gulp.task('browser-sync', function() {
browserSync({
proxy: "" // Add your site URL here
});
});
//sassiness
gulp.task('sass', function () {
gulp.src('dev/css/*.scss')
.pipe(sass())
.pipe(gulp.dest('dev/css'));
});
//css
gulp.task('styles', function() {
return gulp.src('dev/css/style.css')
.pipe(gulp.dest('css'))
.pipe(autoprefixer({
browsers: ['last 2 versions', 'ie >= 9', 'Android >= 2.3', 'ios >= 7'],
cascade: false
}))
.pipe(rename({suffix: '.min'}))
.pipe(minifycss())
.pipe(gulp.dest('css'));
});
//js
gulp.task('scripts', function() {
return gulp.src('dev/js/*.js')
.pipe(plumber({errorHandler: onError}))
.pipe(concat('main.min.js'))
.pipe(gulp.dest('js'))
.pipe(rename({suffix: '.min'}))
.pipe(uglify())
.pipe(gulp.dest('js'));
});
//image compression
gulp.task('images', function() {
return gulp.src('dev/img/*')
.pipe(imagemin({ optimizationLevel: 3, progressive: true, interlaced: true }))
.pipe(gulp.dest('img'));
});
//cleanup time
gulp.task('clean', function() {
return gulp.src(['css/*', 'js/*', 'img/*'], {read: false})
.pipe(clean());
});
//watch all the things and reload when they change
gulp.task('watch', ['browser-sync'], function(){
gulp.watch('dev/css/*.scss', ['sass', reload]);
gulp.watch('dev/css/*.css', ['styles', reload]);
gulp.watch('dev/js/*.js', ['scripts', reload]);
gulp.watch('dev/img/*', ['images', reload]);
});