-
Notifications
You must be signed in to change notification settings - Fork 1
/
rollup.config.js
111 lines (101 loc) · 2.7 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
/* eslint
@typescript-eslint/no-var-requires: 0,
import/no-extraneous-dependencies: 0,
global-require: 0,
*/
const typescript = require('rollup-plugin-typescript2');
const { minify } = require('rollup-plugin-esbuild');
const { dirname, resolve, join } = require('path');
/** @returns {import("rollup").RollupOptions[]} */
module.exports = function config() {
const builder = configBuilder();
const pkg = require('./package.json');
return builder.merge(
// core
builder.buildUMD('./src/index.ts', pkg.name, 'dist'),
builder.buildESM('./src/index.ts', 'dist'),
// react
builder.buildUMD('./src/react/index.ts', 'jotai-form-react', 'dist/react'),
builder.buildESM('./src/react/index.ts', 'dist/react'),
);
};
function configBuilder({ env } = {}) {
/** @type {Partial<import("rollup").RollupOptions>} */
const isDev = env || process.env.NODE_ENV !== 'production';
const getCommonPlugins = (input, output) =>
[
!isDev ? minify() : false,
typescript({
cwd: process.cwd(),
useTsconfigDeclarationDir: true,
tsconfig: './tsconfig.json',
tsconfigOverride: {
compilerOptions: {
module: 'ESNext',
target: 'esnext',
},
},
tsconfigDefaults: {
compilerOptions: {
declarationDir: join(resolve(output), dirname(input)),
declaration: true,
},
files: [input],
},
}),
].filter(Boolean);
return {
merge(...configs) {
return [].concat(configs).flat(1);
},
/** @returns {import("rollup").RollupOptions[]} */
buildESM(input, output) {
const plugins = getCommonPlugins(input, output);
return [
{
input,
output: {
globals: {
react: 'React',
},
dir: output,
format: 'es',
entryFileNames: '[name].modern.js',
},
plugins: [...plugins],
},
{
input,
output: {
globals: {
react: 'React',
},
dir: output,
format: 'es',
entryFileNames: '[name].modern.mjs',
},
plugins: [...plugins],
},
];
},
/** @returns {import("rollup").RollupOptions[]} */
buildUMD(input, name, output) {
const plugins = getCommonPlugins(input, output);
return [
{
input,
output: {
globals: {
react: 'React',
},
format: 'umd',
dir: output,
name,
entryFileNames: '[name].umd.js',
},
plugins: [...plugins],
},
];
},
};
}