-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathrollup.config.js
109 lines (100 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
import path from 'path'
import babel from '@rollup/plugin-babel'
import resolve from '@rollup/plugin-node-resolve'
import typescript from '@rollup/plugin-typescript'
import commonjs from '@rollup/plugin-commonjs'
import { uglify } from "rollup-plugin-uglify"
import esbuild from 'rollup-plugin-esbuild'
import { sizeSnapshot } from 'rollup-plugin-size-snapshot'
const createBabelConfig = require('./babel.config')
const extensions = ['.js', '.ts', '.tsx']
const { root } = path.parse(process.cwd())
function external(id) {
return (
id.startsWith('./vanilla') || (!id.startsWith('.') && !id.startsWith(root)) || id.startsWith('tinycolor2') || id.startsWith('lodash')
)
}
function getEsbuild(target) {
return esbuild({
minify: false,
target,
tsconfig: path.resolve('./tsconfig.json'),
})
}
function getBabelOptions(targets) {
const config = createBabelConfig({ env: (env) => env === 'build' }, targets)
if (targets.ie) {
config.plugins = [...config.plugins, '@babel/plugin-transform-regenerator']
config.babelHelpers = 'bundled'
}
return {
...config,
comments: false,
extensions,
}
}
function createDeclarationConfig(input, output) {
return {
input,
output: {
dir: output,
},
external,
plugins: [typescript({ declaration: true, outDir: output })],
}
}
function createESMConfig(input, output) {
return {
input,
output: { file: output, format: 'esm' },
external,
plugins: [resolve({ extensions }), getEsbuild('node12'), sizeSnapshot()],
}
}
function createCommonJSConfig(input, output) {
return {
input,
output: { file: output, format: 'cjs', exports: 'named' },
external,
plugins: [
resolve({ extensions }),
commonjs(),
babel(getBabelOptions({ ie: 11 })),
sizeSnapshot(),
],
}
}
function createMinJSConfig(input, output) {
return {
input,
output: { file: output, format: 'iife' },
plugins: [
resolve({
extensions,
jsnext: true,
main: true,
browser: true,
}),
commonjs(),
babel(getBabelOptions({ ie: 11 })),
uglify(),
],
}
}
export default function (args) {
let c = Object.keys(args).find((key) => key.startsWith('config-'))
if (c) {
c = c.slice('config-'.length)
return [
createCommonJSConfig(`src/${c}.ts`, `dist/${c}.js`),
createMinJSConfig('src/index.ts', 'dist/index.min.js'),
createESMConfig(`src/${c}.ts`, `dist/${c}.module.js`),
]
}
return [
createDeclarationConfig('src/index.ts', 'dist'),
createCommonJSConfig('src/index.ts', 'dist/index.js'),
createMinJSConfig('src/index.ts', 'dist/index.min.js'),
createESMConfig('src/index.ts', 'dist/index.module.js'),
]
}