-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.babel.js
56 lines (46 loc) · 1.1 KB
/
gulpfile.babel.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
import gulp from 'gulp';
import { sassPlugin } from 'esbuild-sass-plugin';
const { src, dest, watch } = require('gulp');
// esbuild sass plugin
// const sassPlugin = require('esbuild-sass-plugin');
// cache map
const pluginCache = new Map();
// gulp esbuild
const { createGulpEsbuild } = require('gulp-esbuild');
const gulpEsbuild = createGulpEsbuild({
incremental: true,
});
// eslint
const eslint = require('gulp-eslint');
function build() {
return src('src/js/*')
.pipe(eslint())
.pipe(eslint.format())
.pipe(gulpEsbuild())
.pipe(dest('dist'));
}
function buildStyles() {
return src('src/scss/main.scss')
.pipe(
gulpEsbuild({
plugins: [
sassPlugin({
// cache: pluginCache,
file: 'main.scss',
includePaths: ['/src/scss'],
}),
],
loader: {
'.scss': 'css',
},
}),
)
.pipe(dest('dist'));
}
function watchTask() {
watch(['src/js/*'], build);
watch(['src/scss/**/*.scss'], buildStyles);
}
exports.build = build;
exports.watch = watchTask;
exports.buildStyles = buildStyles;