/
rollup.config.mjs
87 lines (76 loc) · 1.66 KB
/
rollup.config.mjs
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
import buble from '@rollup/plugin-buble'
import del from 'rollup-plugin-delete'
import vue from 'rollup-plugin-vue'
import { nodeResolve } from '@rollup/plugin-node-resolve'
import terser from '@rollup/plugin-terser'
const createSources = () => [
'./src/index.js',
'./src/Dataset.vue',
'./src/DatasetInfo.vue',
'./src/DatasetItem.vue',
'./src/DatasetPager.vue',
'./src/DatasetSearch.vue',
'./src/DatasetShow.vue'
]
const createPlugins = () => [
nodeResolve(),
vue({
css: false
}),
buble({
exclude: 'node_modules/**'
})
]
const umdBuild = (minify) =>
createSources().map((source) => {
const name = source === './src/index.js' ? 'VueDataset' : source.split('/').pop().replace('.vue', '')
const minifiedSuffix = minify ? '.min' : ''
const plugins = createPlugins()
if (minify) {
plugins.push(terser())
}
return {
input: source,
output: [
{
file: `./dist/umd/${name}${minifiedSuffix}.js`,
format: 'umd',
name,
sourcemap: true,
sourcemapExcludeSources: false,
globals: {
vue: 'Vue'
}
}
],
external: ['vue'],
plugins
}
})
const esBuild = () => {
const plugins = createPlugins()
plugins.unshift(del({ targets: 'dist/*' }))
return [
{
input: createSources(),
output: [
{
dir: 'dist/es',
format: 'es',
sourcemap: true,
sourcemapExcludeSources: false
}
],
external: ['vue'],
plugins
}
]
}
export default [
// ES
...esBuild(),
// UMD
...umdBuild(),
// UMD Minified
...umdBuild(true)
]