-
Notifications
You must be signed in to change notification settings - Fork 0
/
rollup.config.js
75 lines (74 loc) · 1.86 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
import autoprefixer from "autoprefixer";
import babel from "@rollup/plugin-babel";
import postcss from "rollup-plugin-postcss";
import resolve from "@rollup/plugin-node-resolve";
import scssVariable from 'rollup-plugin-sass-variables';
import commonjs from "@rollup/plugin-commonjs";
import copy from "rollup-plugin-copy";
import visualizer from "rollup-plugin-visualizer";
import image from '@rollup/plugin-image';
export default [
{
input: [
"src/index.js"
// "src/components/DatePicker/DatePicker.jsx",
// "src/components/Form/Form.jsx",
// "src/components/Modal/Modal.jsx",
// "src/components/Tabs/Tabs.jsx",
// "src/components/Table/Table.jsx",
// "src/components/ComboBox/ComboBox.jsx"
],
output: [
{
dir: "lib",
format: "cjs",
sourcemap: true
}
],
external: ["react", "react-dom", "prop-types", "react-select"],
plugins: [
image(),
postcss({
plugins: [autoprefixer]
}),
commonjs({
include: /node_modules/,
// namedExports: {
// '@trendmicro/react-sidenav': ['Nav', 'NavItem', 'NavIcon', 'NavText']
// }
}),
resolve({
extensions: [".js", ".jsx"],
mainFields: ["main"],
preferBuiltins: false
}),
babel({
exclude: "node_modules/**",
babelHelpers: 'inline'
}),
copy({
targets: [{ src: "src/base/assets", dest: "lib"} ]
}),
visualizer({
filename: "./docs/statistics.html",
title: "Compass React Bundle",
sourcemap: true
}),
scssVariable()
]
},
// build base css separately
{
input: "src/base/styles.scss",
output: {
file: "lib/styles.css",
format: "esm"
},
plugins: [
postcss({
extract: true,
plugins: [autoprefixer]
})
]
}
];