-
Notifications
You must be signed in to change notification settings - Fork 0
/
gulp-dev.js
126 lines (114 loc) · 3.75 KB
/
gulp-dev.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
const del = require('del');
const { src, dest, series, parallel, watch } = require('gulp');
const browserSync = require('browser-sync').create();
const htmllint = require('gulp-htmllint');
const fancyLog = require('fancy-log');
const colors = require('ansi-colors');
const htmlmin = require('gulp-htmlmin');
const imagemin = require('gulp-imagemin');
const cssmin = require('gulp-cssmin');
const jsmin = require('gulp-jsmin');
const eslint = require('gulp-eslint');
const sass = require('gulp-sass')(require('sass'));
const gulpStylelint = require('gulp-stylelint');
const publicFolder = 'public';
const privateFolder = 'private';
const any = '/**';
const index = '/index.html';
const mediaFolder = 'media';
const scriptFolder = 'script';
const styleFolder = 'style';
function clean(cb) {
del([
`${publicFolder}${any}`,
`!${publicFolder}/.gitignore`,
`!${publicFolder}/.git`,
`!${publicFolder}/.vscode`], { force: true });
cb();
}
function html() {
return src(`${privateFolder}${index}`)
.pipe(htmllint({
'rules': {
'line-end-style': false,
'id-class-style': 'dash',
},
}, htmllintReporter))
.pipe(htmlmin({
'collapseWhitespace': true,
}))
.pipe(dest(publicFolder));
}
function htmllintReporter(filepath, issues) {
if (issues.length > 0) {
issues.forEach(function (issue) {
fancyLog(colors.cyan('[gulp-htmllint] ') + colors.white(filepath + ' [' + issue.line + ',' + issue.column + ']: ') + colors.red('(' + issue.code + ') ' + issue.msg));
});
process.exitCode = 1;
}
};
function media() {
return src(`${privateFolder}/${mediaFolder}${any}`)
.pipe(imagemin({
'silent': true,
}))
.pipe(dest(`${publicFolder}/${mediaFolder}`));
}
function jslint() {
return src(`${privateFolder}/${scriptFolder}${any}`)
// TODO gulp-eslint needs updating to support the newer version of eslint
.pipe(eslint({ fix: true }))
.pipe(eslint.format())
.pipe(eslint.failAfterError())
.pipe(dest(`${privateFolder}/${scriptFolder}`));
}
function javascript() {
return src(`${privateFolder}/${scriptFolder}${any}`)
.pipe(jsmin())
.pipe(dest(`${publicFolder}/${scriptFolder}`));
}
function css() {
return src(`${privateFolder}/${styleFolder}${any}`)
.pipe(gulpStylelint({
reporters: [
{ formatter: 'string', console: true },
],
}))
.pipe(sass().on('error', sass.logError))
.pipe(cssmin())
.pipe(dest(`${publicFolder}/${styleFolder}`));
}
function server(cb) {
browserSync.init({
server: {
baseDir: `${publicFolder}/`,
notify: false,
open: false,
},
});
cb();
};
function reload(cb) {
if (browserSync.active) {
browserSync.reload();
};
cb();
};
function watcher(cb) {
watch(`${privateFolder}${index}`).on('change', series(exports.html, reload));
watch(`${privateFolder}/${mediaFolder}${any}`).on('change', series(exports.media, reload));
watch(`${privateFolder}/${scriptFolder}${any}`).on('change', series(exports.javascript, reload));
watch(`${privateFolder}/${styleFolder}${any}`).on('change', series(exports.css, reload));
cb();
};
exports.clean = clean;
exports.html = html;
exports.media = media;
exports.javascript = series(jslint, javascript);
exports.css = css;
exports.server = server;
exports.watcher = watcher;
exports.build = series(exports.clean, parallel(exports.html, exports.media, exports.javascript, exports.css));
exports.auto = series(exports.build, exports.watcher);
exports.autoload = series(exports.auto, server);
exports.default = exports.autoload;