-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrollup.config.js
53 lines (46 loc) · 1.26 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
import babelPlugin from '@rollup/plugin-babel'
import resolve from '@rollup/plugin-node-resolve'
import commonjs from '@rollup/plugin-commonjs'
import dts from 'rollup-plugin-dts'
import peerDepsExternal from 'rollup-plugin-peer-deps-external'
import ts from 'rollup-plugin-typescript2'
import postcss from 'rollup-plugin-postcss'
import svg from 'rollup-plugin-svg'
import visualizer from 'rollup-plugin-visualizer'
import { terser } from 'rollup-plugin-terser'
import { createModule, getBabelOptions } from './scripts/rollup.cfg'
const extensions = ['.js', '.ts', '.tsx']
const plugs = [
peerDepsExternal(),
postcss({
extract: 'dd360.css',
extensions: ['.css']
}),
resolve({ extensions }),
commonjs(),
ts({
tsconfig: './scripts/tsconfig.build.json',
declaration: true,
declarationDir: 'dist'
}),
svg(),
terser(),
visualizer({
filename: 'bundle-analysis.html'
})
]
const esmModule = createModule({ plugins: plugs, format: 'esm' })
const cjsModule = createModule({
plugins: [...plugs, babelPlugin(getBabelOptions({ ie: 11 }))],
format: 'cjs'
})
export default [
esmModule,
cjsModule,
{
input: 'dist/esm/index.d.ts',
output: [{ file: 'dist/index.d.ts', format: 'esm' }],
plugins: [dts()],
external: [/\.css$/]
}
]