-
Notifications
You must be signed in to change notification settings - Fork 2
/
rollup.config.mjs
73 lines (68 loc) · 1.74 KB
/
rollup.config.mjs
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
import { nodeResolve } from "@rollup/plugin-node-resolve";
import commonjs from "@rollup/plugin-commonjs";
import typescript from "@rollup/plugin-typescript";
import dts from "rollup-plugin-dts";
import postcss from "rollup-plugin-postcss";
import image from '@rollup/plugin-image';
import json from '@rollup/plugin-json';
import terser from "@rollup/plugin-terser";
import peerDepsExternal from 'rollup-plugin-peer-deps-external';
import analyze from 'rollup-plugin-analyzer';
const limitBytes = 6.1e6;
const onAnalysis = ({ bundleSize }) => {
if (bundleSize < limitBytes) return;
console.log(`Bundle size exceeds ${limitBytes / 1024} kb: ${bundleSize / 1024} kb`);
process.exit(1);
};
const manualChunks = {
prettier: ['prettier/standalone', 'prettier/plugins/babel', 'prettier/plugins/estree']
};
const getPlugins = ({ browser = false, minify = false } = {}) => [
peerDepsExternal(),
nodeResolve({ browser }),
commonjs(),
typescript({ tsconfig: "./tsconfig.json" }),
postcss(),
image(),
json(),
...(minify ? [terser()] : []),
...(minify ? [analyze({ onAnalysis, summaryOnly: true })] : [])
];
export default [
{
input: "src/index.ts",
output: {
dir: "dist/cjs",
format: "cjs",
sourcemap: true,
manualChunks
},
plugins: getPlugins()
},
{
input: "src/index.ts",
output: {
dir: "dist/esm",
format: "esm",
sourcemap: true,
manualChunks
},
plugins: getPlugins()
},
{
input: "src/index.ts",
output: {
dir: "dist/browser",
format: "esm",
sourcemap: true,
manualChunks
},
plugins: getPlugins({ browser: true, minify: true })
},
{
input: "src/index.ts",
output: [{ file: "dist/index.d.ts", format: "esm" }],
plugins: [dts()],
external: [/\.css$/, /\.stories.tsx$/, /\.previewData.ts$/]
}
];