-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgulpfile.js
75 lines (59 loc) · 1.69 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
var gulp = require('gulp'),
path = require('path'),
watch = require('gulp-watch'),
less = require('gulp-less'),
minifyCSS = require('gulp-minify-css'),
inlineSource = require('gulp-inline-source'),
minifyHTML = require('gulp-minify-html'),
src = {
html: ['index.html'],
images: ['images/*'],
css: ['stylesheets/less/style.less'],
fonts: ['fonts/**/*'],
js: ['js/script.js']
},
dest = {
html: 'build/',
images: 'build/images/',
css: 'build/stylesheets/css/',
fonts: 'build/fonts/',
js: 'build/js/'
};
gulp.task('html', function () {
gulp.src(src.html)
.pipe(inlineSource({
rootpath: 'build'
}))
.pipe(minifyHTML())
.pipe(gulp.dest(dest.html));
});
gulp.task('images', function () {
gulp.src(src.images)
.pipe(gulp.dest(dest.images));
});
gulp.task('css', function () {
gulp.src(src.css)
.pipe(less())
.pipe(minifyCSS())
.pipe(gulp.dest(dest.css));
});
gulp.task('fonts', function () {
gulp.src(src.fonts)
.pipe(gulp.dest(dest.fonts));
});
gulp.task('js', function () {
gulp.src(src.js)
.pipe(gulp.dest(dest.js));
});
gulp.task('watch', function() {
gulp.watch(src.images, ['images']);
gulp.watch(src.css, ['css']);
gulp.watch(src.fonts, ['fonts']);
gulp.watch(src.js, ['js']);
gulp.watch(src.html, ['html']);
});
// Order is important:
// CSS might refer to images & fonts, so minify them before CSS
// Keep HTML at last, as it could have reference to any other resource
gulp.task('default', ['images', 'fonts', 'css', 'js', 'html', 'watch'], function () {
});