-
-
Notifications
You must be signed in to change notification settings - Fork 155
/
rollup.config.js
115 lines (111 loc) · 3.4 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
import babel from '@rollup/plugin-babel'
import external from 'rollup-plugin-peer-deps-external'
import postcss from 'rollup-plugin-postcss-modules'
import del from 'rollup-plugin-delete'
import pkg from './package.json'
import typescript from 'rollup-plugin-typescript2'
// so JS can be rolled with TS
// remove when JS files have been removed
import nodeResolve from '@rollup/plugin-node-resolve'
import commonjs from '@rollup/plugin-commonjs'
import icons from './internals/icons'
console.log('Expected Externals', [
...Object.keys(pkg.dependencies || {}),
...Object.keys(pkg.peerDependencies || {}),
'./src',
])
const extensions = ['.js', '.jsx', '.ts', '.tsx']
export default {
input: {
index: 'src/index.tsx',
// avatar: 'src/components/Avatar/index.tsx',
button: 'src/components/Button/index.tsx',
typography: 'src/components/Typography/index.tsx',
icon: 'src/components/Icon/index.tsx',
image: 'src/components/Image/index.tsx',
card: 'src/components/Card/index.tsx',
badge: 'src/components/Badge/index.tsx',
alert: 'src/components/Alert/index.tsx',
accordion: 'src/components/Accordion/index.tsx',
tabs: 'src/components/Tabs/index.tsx',
menu: 'src/components/Menu/index.tsx',
modal: 'src/components/Modal/index.tsx',
modal: 'src/components/Popover/index.tsx',
sidepanel: 'src/components/SidePanel/index.tsx',
dropdown: 'src/components/Dropdown/index.tsx',
contextmenu: 'src/components/ContextMenu/index.tsx',
space: 'src/components/Space/index.tsx',
loading: 'src/components/Loading/index.tsx',
divider: 'src/components/Divider/index.tsx',
select: 'src/components/Select/index.tsx',
listbox: 'src/components/Listbox/index.tsx',
checkbox: 'src/components/Checkbox/index.tsx',
input: 'src/components/Input/index.tsx',
radio: 'src/components/Radio/index.tsx',
toggle: 'src/components/Toggle/index.tsx',
upload: 'src/components/Upload/index.tsx',
auth: 'src/components/Auth/index.tsx',
...icons,
},
external: [
...Object.keys(pkg.dependencies || {}),
...Object.keys(pkg.peerDependencies || {}),
'./src',
],
output: [
{
dir: 'dist/cjs',
format: 'cjs',
preserveModules: true,
preserveModulesRoot: 'src',
exports: 'named',
},
{
dir: 'dist/esm',
format: 'es',
preserveModules: true,
preserveModulesRoot: 'src',
exports: 'named',
},
],
plugins: [
external(),
typescript(),
// so JS can be rolled with TS
// remove when JS files have been removed
nodeResolve({
ignoreGlobal: false,
include: ['node_modules/**'],
extensions,
// skip: keys(EXTERNALS), // <<-- skip: ['react', 'react-dom']
}),
commonjs({
ignoreGlobal: false,
include: 'node_modules/**',
}),
postcss({
// plugins: require('./postcss.config').plugins,
plugins: [
require('postcss-import'),
require('tailwindcss'),
require('autoprefixer'),
],
// modules: true,
minimize: true,
sourceMap: false,
// extract: false,
minimize: true,
modules: {
// see generateScopedName options here
// https://github.com/css-modules/postcss-modules
generateScopedName: '[local]',
},
}),
babel({
babelHelpers: 'runtime',
exclude: 'node_modules/**',
extensions,
}),
del({ targets: ['dist/*'] }),
],
}