-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.config.js
93 lines (89 loc) · 2.67 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
import json from '@rollup/plugin-json';
import resolve from '@rollup/plugin-node-resolve';
import babel from 'rollup-plugin-babel';
import commonjs from '@rollup/plugin-commonjs';
// import alias from 'rollup-plugin-alias';
import packageJson from './package.json';
const getPlugins = (platform) => [
json(),
babel({
extensions: ['.ts', '.tsx', '.js', '.jsx', '.es6', '.es', '.mjs'],
exclude: 'node_modules/**',
}),
resolve({
extensions: ['.mjs', `.${platform}.js`, `.${platform}.jsx`, `.${platform}.ts`, `.${platform}.tsx`, '.js', '.ts', '.jsx', '.tsx', '.json'],
}),
commonjs(),
];
const output = {
// file: 'dist/bundle.esm.js',
file: packageJson.module,
format: 'esm',
name: packageJson.name,
globals: {
react: 'React',
'react-dom': 'ReactDOM',
'styled-components': 'styled',
'styled-components/primitives': 'styledP',
'react-primitives': 'reactPrimitives',
'styled-system': 'styledSystem',
'react-primitives-svg': 'reactPrimitivesSvg',
},
// plugins: getPlugins('web'),
};
export default [
// Web export
{
input: 'src/index.ts',
output: [
{
...output,
file: packageJson.main,
format: 'umd',
},
output
],
external: ['react', 'react-native-web', 'react-dom', 'react-is', 'styled-components', 'styled-system', 'react-primitives', 'react-primitives-svg'],
plugins: getPlugins('web')
},
// Sketch export
{
input: 'src/index.ts',
output: [
{
...output,
file: packageJson.sketch,
// plugins: getPlugins('sketch'),
}
],
external: ['react', 'react-native-web', 'react-dom', 'react-is', 'styled-components', 'styled-components/primitives', 'styled-system', 'react-primitives', 'react-primitives-svg'],
plugins: getPlugins('sketch')
},
// React Native export
{
input: 'src/index.ts',
output: [
{
...output,
file: packageJson['react-native'],
// plugins: getPlugins('sketch'),
}
],
external: ['react', 'react-native-web', 'react-native', 'react-dom', 'react-is', 'styled-components', 'styled-components/primitives', 'styled-system', 'react-primitives', 'react-primitives-svg'],
plugins: getPlugins('native')
},
// Figma export
{
input: 'src/index.ts',
output: [
{
...output,
format: 'umd', // Figma doesn't support ES imports
file: packageJson.figma,
// plugins: getPlugins('sketch'),
}
],
external: ['react', 'react-native-web', 'react-dom', 'react-is', 'styled-components', 'styled-components/primitives', 'styled-system', 'react-primitives', 'react-primitives-svg'],
plugins: getPlugins('figma')
},
]