-
Notifications
You must be signed in to change notification settings - Fork 8
/
rollup.config.ts
73 lines (71 loc) · 1.45 KB
/
rollup.config.ts
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
import { resolve } from 'path'
import { nodeResolve } from '@rollup/plugin-node-resolve'
import commonjs from '@rollup/plugin-commonjs'
import babel from '@rollup/plugin-babel'
import json from '@rollup/plugin-json'
import dts from 'vite-plugin-dts'
import vue from 'rollup-plugin-vue'
import postcss from 'rollup-plugin-postcss'
import cssnano from 'cssnano'
import { terser } from 'rollup-plugin-terser'
import filesize from 'rollup-plugin-filesize'
const inputPath = resolve(__dirname, './src/index.ts')
const outputPath = (t) => resolve(__dirname, `./dist/index.${t}.js`)
const extensions = [
'.js',
'.jsx',
'.ts',
'.tsx',
'vue'
]
const exclude = [
'**/node_modules/**',
'**/dist/**'
]
const globals = {
vue: 'Vue',
'@popperjs/core': 'Popperjs'
}
module.exports = {
input: inputPath,
output: [{
file: outputPath('umd'),
format: 'umd',
name: 'index',
exports: 'named',
globals
}, {
file: outputPath('esm'),
format: 'es',
name: 'index.module',
exports: 'named',
globals
}],
plugins: [
vue({
preprocessStyles: true,
postcssPlugins: [cssnano()]
}),
nodeResolve({
extensions
}),
commonjs(),
postcss(),
json(),
babel({
exclude,
babelHelpers: 'runtime',
extensions
}),
dts({
rollupTypes: true
}),
terser({
compress: {
// drop_console: true
}
}),
filesize()
],
external: ['vue', '@popperjs/core']
}