-
-
Notifications
You must be signed in to change notification settings - Fork 62
/
Copy pathgulpfile.js
93 lines (82 loc) · 2.65 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
const gulp = require('gulp');
const terser = require('gulp-terser');
const concat = require('gulp-concat');
const cleanCSS = require('gulp-clean-css');
const htmlmin = require('gulp-html-minifier-terser');
const rename = require('gulp-rename');
const htmlreplace = require('gulp-html-replace');
gulp.task('pack-css', function () {
// Start the stream from the source files
let stream = gulp.src([
'./assets/styles/spectre.css/spectre-modified.css',
'./assets/styles/style.css'
])
.pipe(concat('style.main.css'))
.pipe(cleanCSS({
level: 2
}))
.pipe(gulp.dest('./assets/bundles/'));
if (process.env.NODE_ENV === 'production') {
stream = stream.pipe(gulp.dest('./build/assets/'));
}
return stream;
});
gulp.task('pack-js', function () {
let stream = gulp.src([
'./assets/js/iconfont.js',
'./node_modules/jquery/dist/jquery.js',
'./assets/js/jquery-qrcode.js',
'./assets/js/function.js'
])
.pipe(concat('function.main.js'))
.pipe(terser())
.pipe(gulp.dest('./assets/bundles/'));
if (process.env.NODE_ENV === 'production') {
stream = stream.pipe(gulp.dest('./build/assets/'));
}
return stream;
});
gulp.task('minify-html', async function () {
return gulp.src(['./build/index.html'], { base: "./" })
.pipe(htmlmin({
collapseWhitespace: true,
conservativeCollapse: true,
collapseInlineTagWhitespace: true,
collapseBooleanAttributes: true,
removeComments: true,
minifyCSS: true,
minifyJS: true,
removeRedundantAttributes: true,
removeScriptTypeAttributes: true,
removeStyleLinkTypeAttributes: true,
useShortDoctype: true,
sortAttributes: true,
sortClassName: true,
includeAutoGeneratedTags: false,
}))
.pipe(gulp.dest('./'));
});
// gulp.task('temp-copy', function() {
// return gulp.src('assets/bundles/function.main.js')
// .pipe(rename('function_main.js'))
// .pipe(gulp.dest('assets/bundles'))
// .pipe(gulp.src('assets/bundles/style.main.css'))
// .pipe(rename('style_main.css'))
// .pipe(gulp.dest('assets/bundles'));
// });
gulp.task('replace-js-css', function (done) {
return gulp.src('./merger.html')
.pipe(htmlreplace({
'css': 'assets/style.main.css',
'js': 'assets/function.main.js'
}))
.pipe(rename('index.html'))
.pipe(gulp.dest('build/'))
.on('end', done);
});
gulp.task('build-html', async function () {
gulp.start('replace-js-css');
gulp.start('minify-html');
})
gulp.task('compile', gulp.series(gulp.parallel('pack-css', 'pack-js')));
gulp.task('default', gulp.series(gulp.parallel('replace-js-css', 'pack-js', 'pack-css' ), 'minify-html'));