-
Notifications
You must be signed in to change notification settings - Fork 53
/
Copy pathrollup.config.js
96 lines (90 loc) · 2.39 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
import babel from 'rollup-plugin-babel';
import {terser} from 'rollup-plugin-terser';
import resolve from '@rollup/plugin-node-resolve';
import commonjs from '@rollup/plugin-commonjs';
import replace from '@rollup/plugin-replace';
import pkg from './package.json';
// Common.
const input = './src/index.ts';
const extensions = ['.js', '.jsx', '.ts', '.tsx'];
const banner = `/**
* Muuri-react v${pkg.version}
* ${pkg.homepage}
* Copyright (c) 2020-present, Paol-imi
* Released under the MIT license
* https://github.com/Paol-imi/muuri-react/blob/master/LICENSE
* @license MIT
*/
`;
// Babel options.
const getBabelOptions = ({useESModules}) => ({
exclude: 'node_modules/**',
extensions,
runtimeHelpers: true,
plugins: [['@babel/transform-runtime', {useESModules}]],
});
export default [
// Universal module definition (UMD) build
{
input,
output: {
file: 'dist/muuri-react.js',
format: 'umd',
name: 'MuuriReact',
globals: {react: 'React', muuri: 'Muuri'},
banner,
},
external: ['react', 'muuri'],
plugins: [
babel(getBabelOptions({useESModules: true})),
resolve({extensions}),
commonjs({
include: 'node_modules/**',
}),
replace({'process.env.NODE_ENV': JSON.stringify('development')}),
],
},
// Minified UMD build
{
input,
output: {
file: 'dist/muuri-react.min.js',
format: 'umd',
name: 'MuuriReact',
globals: {react: 'React', muuri: 'Muuri'},
banner,
},
external: ['react', 'muuri'],
plugins: [
babel(getBabelOptions({useESModules: true})),
resolve({extensions}),
commonjs({
include: 'node_modules/**',
}),
replace({'process.env.NODE_ENV': JSON.stringify('production')}),
terser(),
],
},
// CommonJS (cjs) build
// - All external packages are not bundled
{
input,
output: {file: pkg.main, format: 'cjs', banner},
external: (id) => !id.startsWith('.') && !id.startsWith('/'),
plugins: [
resolve({extensions}),
babel(getBabelOptions({useESModules: false})),
],
},
// EcmaScript Module (esm) build
// - All external packages are not bundled
{
input,
output: {file: pkg.module, format: 'esm', banner},
external: (id) => !id.startsWith('.') && !id.startsWith('/'),
plugins: [
resolve({extensions}),
babel(getBabelOptions({useESModules: true})),
],
},
];