-
Notifications
You must be signed in to change notification settings - Fork 0
/
rollup.config.js
69 lines (60 loc) · 1.48 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
import babel from "@rollup/plugin-babel"
import resolve from "@rollup/plugin-node-resolve"
import commonjs from "@rollup/plugin-commonjs"
import postcss from "rollup-plugin-postcss"
import filesize from "rollup-plugin-filesize"
import autoprefixer from "autoprefixer"
import pkg from "./package.json"
const INPUT_FILE_PATH = "src/index.js"
const OUTPUT_NAME = "Example"
const GLOBALS = {
react: "React",
"react-dom": "ReactDOM",
"prop-types": "PropTypes",
}
const PLUGINS = [
postcss({
extract: true,
plugins: [autoprefixer],
}),
babel({
babelHelpers: "runtime",
exclude: "node_modules/**",
}),
resolve({
browser: true,
resolveOnly: [/^(?!react$)/, /^(?!react-dom$)/, /^(?!prop-types)/],
}),
commonjs(),
filesize(),
]
const EXTERNAL = ["react", "react-dom", "prop-types"]
// https://github.com/rollup/plugins/tree/master/packages/babel#babelhelpers
// @ts-ignore
const CJS_AND_ES_EXTERNALS = EXTERNAL.concat(/@babel\/runtime/)
const OUTPUT_DATA = [
{
file: pkg.browser,
format: "umd",
},
{
file: pkg.main,
format: "cjs",
},
{
file: pkg.module,
format: "es",
},
]
const config = OUTPUT_DATA.map(({ file, format }) => ({
input: INPUT_FILE_PATH,
output: {
file,
format,
name: OUTPUT_NAME,
globals: GLOBALS,
},
external: ["cjs", "es"].includes(format) ? CJS_AND_ES_EXTERNALS : EXTERNAL,
plugins: PLUGINS,
}))
export default config