-
Notifications
You must be signed in to change notification settings - Fork 0
/
build.js
83 lines (73 loc) · 1.57 KB
/
build.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
import * as sass from 'sass';
import * as esbuild from 'esbuild';
import { readFile } from 'node:fs/promises';
/**
* 生成 style 模块
*
* @param {string} css - css 文本
* @returns 模块文本
*/
function styleModule(css) {
return `
const css = \`${css}\`;
const styleElement = document.createElement('style');
styleElement.textContent = css;
document.head.appendChild(styleElement);
`;
}
function svgPlugin() {
/**
* @type {esbuild.Plugin}
*/
const svgPlugin = {
name: 'svg',
setup(build) {
build.onLoad({ filter: /\.svg$/ }, async args => {
const raw_svg = await readFile(args.path, 'utf-8');
const svg = raw_svg.replace(/(\n?\s+)/g, ' ');
return {
contents: svg,
loader: 'text',
};
});
},
};
return svgPlugin;
}
function sassPlugin() {
/**
* @type {esbuild.Plugin}
*/
const sassPlugin = {
name: 'sass',
setup(build) {
build.onLoad({ filter: /\.scss$/ }, async args => {
const { css } = await sass.compileAsync(args.path, {
style: 'compressed',
});
return {
contents: styleModule(css),
};
});
},
};
return sassPlugin;
}
/**
* @type {esbuild.BuildOptions}
*/
const buildOptions = {
bundle: true,
entryPoints: ['src/index.ts'],
plugins: [sassPlugin(), svgPlugin()],
};
await esbuild.build({
...buildOptions,
outfile: 'lib/docsify-chat.js',
});
await esbuild.build({
...buildOptions,
minify: true,
outfile: 'lib/docsify-chat.min.js',
});
console.log('✨🐢🚀✨');