-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
86 lines (75 loc) · 2.56 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
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 typescript = require("@rollup/plugin-typescript");
const assetsPath = 'src/assets/*';
const stylesPath = './src/styles/**/*.css';
const tsPath = 'src/scripts/*.ts';
const htmlPath = './src/index.html';
const distPath = './dist/';
const rollupConfig = {
input: 'src/scripts/app.ts',
plugins: [
typescript()
]
}
const imageOptimizingSettings = {
pngquant: true,
optipng: true,
zopflipng: true,
mozjpeg: true,
gifsicle: true,
svgo: true,
concurrent: 10,
};
/**
* Описание задачи на сборку javascript, с помощью rollup
*/
gulp.task('rollup', async (done) => {
const bundle = await rollup.rollup(rollupConfig);
bundle.write({
format: 'esm',
file: 'dist/app.js'
});
done();
});
/**
* Простая задача на компиляцию scss файлов в файл style.css, ее отличие от rollup плагина rollup-plugin-scss
* в том, что файлы подключаются по маске, а в rollup они подключаются явно через import
**/
gulp.task('css', () => {
return gulp.src(stylesPath)
.pipe(less())
.pipe(concat('style.css'))
.pipe(gulp.dest(distPath));
});
/**
* Вотчинг всех файлов которые мы
**/
gulp.task('watch', function (done) {
gulp.watch(stylesPath, gulp.series('css'));
gulp.watch(tsPath, gulp.series('rollup'));
done();
});
/**
* Копирование картинок и прочего из папки assets, картинки обжимаются с помощью наастроек imageOptimizingSettings
*/
gulp.task('assets', function () {
return gulp.src(assetsPath)
.pipe(image(imageOptimizingSettings))
.pipe(gulp.dest(`${distPath}/assets/`));
});
/**
* Описание задачи на вставку js & css файлов в наш шаблон index.html
*/
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'));