-
Notifications
You must be signed in to change notification settings - Fork 48
/
Copy pathgulpfile.js
113 lines (92 loc) · 3.05 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
'use strict';
var gulp = require('gulp'),
$ = require('gulp-load-plugins')(),
cssnano = require('cssnano'),
yaml = require('js-yaml'),
fs = require('fs'),
cfg = yaml.safeLoad(fs.readFileSync('_config.yml')),
path = require('path');
require('shelljs/global');
var htmlMinifierOptions = {
removeComments: true,
collapseWhitespace: true,
collapseBooleanAttributes: true,
removeScriptTypeAttributes: true,
removeStyleLinkTypeAttributes: true,
removeOptionalTags: true,
minifyJS: true,
minifyCSS: true
};
var dirs = {
public: 'public',
fonts: 'public/fonts',
imgs: 'public/img',
assetsDir:'public/assets'
};
gulp.task('useref', ['hexo'], function(){
return gulp.src('public/**/*.html')
.pipe($.useref({
searchPath:'public',
transformPath: function(filePath) {
filePath = path.normalize(filePath);
return filePath.replace(dirs.public + cfg.root, dirs.public + '/');
}
}))
.pipe($.if('*.css', $.postcss([
cssnano()
])))
.pipe($.if('*.css', $.minifyCss()))
.pipe($.if('*.js', $.uglify()))
.pipe($.if('*.html', $.htmlMinifier(htmlMinifierOptions)))
.pipe(gulp.dest('public'));
});
gulp.task('rev:media', function(){
return gulp.src([dirs.fonts + '/**/*', dirs.imgs + '/**/*'], {base: dirs.public})
.pipe($.rev())
.pipe(gulp.dest(dirs.assetsDir))
.pipe($.rev.manifest('rev-media.json'))
.pipe(gulp.dest(dirs.assetsDir));
});
gulp.task('rev:scripts', ['useref', 'rev:media'], function(){
var manifest = gulp.src(dirs.assetsDir + '/rev-media.json');
return gulp.src([dirs.public + '/css/dist*.css', dirs.public + '/js/dist*.js'], {base: dirs.public})
.pipe($.rev())
.pipe($.revReplace({
manifest: manifest
}))
.pipe(gulp.dest(dirs.assetsDir))
.pipe($.rev.manifest())
.pipe(gulp.dest(dirs.assetsDir));
});
gulp.task('img:min', ['rev:media'], function(){
var pngquant = require('imagemin-pngquant');
return gulp.src(dirs.assetsDir + '/img/**/*', {base: dirs.assetsDir})
.pipe($.imagemin({
progressive: true,
svgoPlugins: [{removeViewBox:false}],
use:[pngquant()]
}))
.pipe(gulp.dest(dirs.assetsDir))
});
gulp.task("rev:replace", ["rev:scripts"], function(){
var manifest = gulp.src([dirs.assetsDir + '/rev-*.json']);
return gulp.src([ dirs.public + "/**/*.html"])
.pipe($.revReplace({
manifest: manifest,
modifyReved:function(fileName){
if(fileName.indexOf('/dist') > -1){
//special files proccessed by gulp-useref
fileName = cfg.root + 'assets/' + fileName;
}else {
fileName = 'assets/' + fileName;
}
return fileName;
}
}))
.pipe(gulp.dest(dirs.public));
});
gulp.task('hexo', function(){
exec('hexo g');
});
gulp.task('img', ['img:min']);
gulp.task('default', ['rev:replace', 'img']);