-
Notifications
You must be signed in to change notification settings - Fork 2
/
rollup.config.js
78 lines (72 loc) · 2.21 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
import typescript from 'rollup-plugin-typescript2';
import commonjs from '@rollup/plugin-commonjs';
import resolve from '@rollup/plugin-node-resolve';
import copy from 'rollup-plugin-copy';
import scss from 'rollup-plugin-scss';
import externals from 'rollup-plugin-node-externals';
import banner from 'rollup-plugin-banner';
import { terser } from 'rollup-plugin-terser';
import replace from '@rollup/plugin-replace';
import image from '@rollup/plugin-image';
import pkg from './package.json';
import '@jswork/next-rollup-banner';
export default [
{
input: 'src/main.ts',
output: {
file: pkg.main,
format: 'umd',
exports: 'named',
sourcemap: false,
name: 'ReactModalManagerComponent',
globals: {
'@jswork/noop': 'noop',
'prop-types': 'PropTypes',
'classnames': 'classNames',
'react': 'React',
'react-dom': 'ReactDOM'
}
},
plugins: [
// external(),
externals({
// The path(s) to your package.json. Optional.
// Can be a string or an array of strings for monorepos -- see below
packagePath: './package.json',
// Make node builtins external. Optional. Default: true
builtins: true,
// Make pkg.dependencies external. Optional. Default: false
deps: true,
// Make pkg.peerDependencies external. Optional. Default: true
peerDeps: true
}),
resolve(),
replace({ __VERSION__: pkg.version, preventAssignment: true }),
terser({ output: { comments: false } }),
banner(nx.rollupBanner()),
image(),
typescript({
tsconfig: 'tsconfig.build.json',
clean: true
}),
commonjs({
include: ['node_modules/**'],
namedExports: {
'node_modules/react-is/index.js': Object.keys(require('react-is')),
'node_modules/react/react.js': ['Children', 'Component', 'PropTypes', 'createElement'],
'node_modules/react-dom/index.js': ['render']
}
})
]
},
{
input: 'src/components/style.scss',
output: null,
plugins: [
scss({ output: 'dist/style.css' }),
copy({
targets: [{ src: 'src/components/*.scss', dest: 'dist' }]
})
]
}
];