forked from Tencent/tdesign-icons
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.config.js
126 lines (114 loc) · 2.61 KB
/
rollup.config.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
import babel from '@rollup/plugin-babel';
import commonjs from '@rollup/plugin-commonjs';
import nodeResolve from '@rollup/plugin-node-resolve';
import multiInput from 'rollup-plugin-multi-input';
import postcss from 'rollup-plugin-postcss';
import vuePlugin from 'rollup-plugin-vue';
import esbuild from 'rollup-plugin-esbuild';
import ignoreImport from 'rollup-plugin-ignore-import';
import replace from '@rollup/plugin-replace';
import { terser } from 'rollup-plugin-terser';
const extensions = ['.ts', '.tsx'];
const external = ['vue', '@babel/runtime', 'classnames'];
const input = 'src/index.ts';
const inputList = ['src/**/*.ts', 'src/**/*.tsx'];
const getPlugins = ({ isProd = false, isUmd = false, isEsm = false } = {}) => {
const plugins = [
nodeResolve({ extensions }),
commonjs(),
vuePlugin(),
esbuild({
target: 'esnext',
minify: false,
jsx: 'preserve',
}),
babel({ babelHelpers: 'runtime', extensions }),
];
if (isProd) {
plugins.push(
terser({
output: {
ascii_only: true,
},
}),
);
}
if (isUmd) {
plugins.push(
postcss({
extract: isProd ? 'index.min.css' : 'index.css',
minimize: isProd,
sourceMap: true,
}),
);
} else {
plugins.push(
postcss({
extract: 'style/index.css',
}),
ignoreImport({
extensions: ['.css'],
}),
);
}
if (isEsm) {
plugins.push(replace({
'var undefined$1 = undefined': 'import "./index.css"',
}));
}
return plugins;
};
const esmConfig = {
input: inputList,
treeshake: false,
external,
plugins: [multiInput()].concat(getPlugins({ isEsm: true })),
output: {
dir: 'esm/',
format: 'esm',
sourcemap: true,
chunkFileNames: '_chunks/dep-[hash].js',
},
};
const cjsConfig = {
input: inputList,
external,
plugins: [multiInput()].concat(getPlugins()),
output: {
dir: 'lib/',
format: 'cjs',
sourcemap: true,
exports: 'named',
chunkFileNames: '_chunks/dep-[hash].js',
},
};
const umdConfig = {
input,
external,
plugins: getPlugins({ isUmd: true }),
output: {
name: 'TDesignIconVue',
format: 'umd',
exports: 'named',
globals: { vue: 'Vue' },
sourcemap: true,
file: 'dist/index.js',
},
};
const umdMinConfig = {
input,
external,
plugins: getPlugins({
isProd: true,
isUmd: true,
}),
output: {
name: 'TDesignIconVue',
format: 'umd',
exports: 'named',
globals: { vue: 'Vue' },
sourcemap: true,
file: 'dist/index.min.js',
},
};
export default [esmConfig, cjsConfig, umdConfig, umdMinConfig];