-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
127 lines (103 loc) · 3.18 KB
/
gulpfile.js
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
let gulp = require('gulp'),
browserSync = require('browser-sync').create(),
sass = require('gulp-sass'),
autoprefixer = require('gulp-autoprefixer'),
concat = require('gulp-concat'),
cleanCSS = require('gulp-clean-css'),
pump = require('pump'),
uglify = require('gulp-uglify'),
imagemin = require('gulp-imagemin'),
clean = require('gulp-clean');
gulp.task('copy-html', () => {
return gulp.src('./src/**/*.html')
.pipe(gulp.dest('./dist/'));
});
gulp.task('copy-plugins',()=>{
return gulp.src('./src/plugins/**/*')
.pipe(gulp.dest('./dist/plugins/'));
});
gulp.task('clean-dist', () => {
return gulp.src('./dist/', {read: false})
.pipe(clean());
});
// tasks for CSS files
gulp.task('clean-css', ()=> {
return gulp.src('./src/css/', {read: false})
.pipe(clean());
});
gulp.task('sass',['clean-css'], ()=> {
return gulp.src('./src/scss/**/*.scss')
.pipe(sass())
.pipe(gulp.dest('./src/css/'));
});
gulp.task('autoprefix', ['sass'], ()=> {
return gulp.src('./src/css/**/*.css')
.pipe(autoprefixer({
browsers: ['last 2 versions'],
cascade: false
}))
.pipe(gulp.dest('./src/css/'))
});
gulp.task('concat-css', ['autoprefix'], ()=>{
return gulp.src('./src/css/**/*.css')
.pipe(concat('style.css'))
.pipe(gulp.dest('./src/css/'));
});
gulp.task('minify-css', ['concat-css'], ()=>{
return gulp.src('./src/css/style.css')
.pipe(cleanCSS({compatibility: 'ie8'}))
.pipe(gulp.dest('./src/css/'));
});
gulp.task('copy-css', ['minify-css'], () => {
return gulp.src('./src/css/style.css')
.pipe(gulp.dest('./dist/css/'))
});
// tasks for JS files
gulp.task('clean-js', ()=> {
return gulp.src('./dist/js/script.js', {read: false})
.pipe(clean());
});
gulp.task('concat-js',['clean-js'],()=>{
return gulp.src('./src/js/**/*.js')
.pipe(concat('script.js'))
.pipe(gulp.dest('./src/js/'));
});
gulp.task('minify-js', ['concat-js'], (cb) => {
pump([
gulp.src('./src/js/script.js'),
uglify(),
gulp.dest('./src/js/')
],
cb
);
});
gulp.task('copy-js',['minify-js'], () => {
return gulp.src('./src/js/script.js')
.pipe(gulp.dest('./dist/js/'))
});
// tasks for images
gulp.task('minify-img',()=>{
return gulp.src('./src/img/**/*')
.pipe(imagemin())
.pipe(gulp.dest('./dist/img/'))
})
gulp.task('serve', ['copy-html','copy-css','copy-js','minify-img', 'copy-plugins'], () => {
browserSync.init({
server: {
baseDir: "./dist"
}
});
gulp.watch('./src/**/*.html', ['copy-html']).on('change', browserSync.reload);
gulp.watch('./src/scss/**/*.scss', ['copy-css']).on('change', browserSync.reload);
gulp.watch('./src/js/**/*.js', ['copy-js']).on('change', browserSync.reload);
gulp.watch('./src/img/**/*', ['minify-img']).on('change', browserSync.reload);
});
gulp.task('dev',['clean-dist'],()=>{
gulp.start('serve');
});
gulp.task('build', ['clean-dist'],()=>{
gulp.start('copy-html');
gulp.start('copy-css');
gulp.start('copy-js');
gulp.start('minify-img');
});