-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
67 lines (57 loc) · 1.79 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
const gulp = require('gulp');
const concat = require('gulp-concat');
const less = require('gulp-less');
const inject = require('gulp-inject');
const rollup = require('rollup');
const image = require('gulp-image');
const assetsPath = 'src/assets/*.{png, jpeg, psd, bmp, gif, tiff, icon, ico}';
const stylesPath = './src/styles/app.scss';
var imageDirectory = 'src/assets/';
const jsPath = 'src/scripts/*.js';
const htmlPath = './src/*.html';
const distPath = './dist/';
const rollupConfig = {
input: 'src/scripts/app.js',
plugins: []
}
const imageOptimizingSettings = {
pngquant: true,
optipng: true,
zopflipng: true,
mozjpeg: true,
gifsicle: true,
svgo: true,
concurrent: 10,
};
gulp.task('rollup', async (done) => {
const bundle = await rollup.rollup(rollupConfig);
bundle.write({
format: 'esm',
file: 'dist/app.js'
});
done();
});
gulp.task('css', () => {
return gulp.src(stylesPath)
.pipe(less())
.pipe(concat('styles/style.css'))
.pipe(gulp.dest(distPath));
});
gulp.task('watch', function (done) {
gulp.watch(stylesPath, gulp.series('css'));
gulp.watch(jsPath, gulp.series('rollup'));
done();
});
gulp.task('assets', function () {
return gulp.src(assetsPath)
.pipe(image(imageOptimizingSettings))
.pipe(gulp.dest(`${distPath}/assets/`));
});
gulp.task('html', function () {
const target = gulp.src(htmlPath);
const sources = gulp.src(['./dist/**/*.js', './dist/**/*.css'], { read: false });
return target.pipe(inject(sources, { ignorePath: '../dist', relative: true, addPrefix: '.' }))
.pipe(gulp.dest(distPath));
});
gulp.task('default', gulp.series('rollup', 'css', 'assets', 'html', 'watch'));
gulp.task('build', gulp.series('rollup', 'css', 'assets', 'html'));