2
0
mirror of https://github.com/tenrok/vue-meta.git synced 2026-05-17 08:09:38 +03:00
Files
vue-meta/scripts/rollup.config.js
2019-06-10 12:43:02 +02:00

125 lines
2.5 KiB
JavaScript

import commonjs from 'rollup-plugin-commonjs'
import nodeResolve from 'rollup-plugin-node-resolve'
import json from 'rollup-plugin-json'
import buble from 'rollup-plugin-buble'
import replace from 'rollup-plugin-replace'
import { terser } from 'rollup-plugin-terser'
import defaultsDeep from 'lodash/defaultsDeep'
const pkg = require('../package.json')
const banner = `/**
* vue-meta v${pkg.version}
* (c) ${new Date().getFullYear()}
* - Declan de Wet
* - Sébastien Chopin (@Atinux)
* - All the amazing contributors
* @license MIT
*/
`
function rollupConfig({
plugins = [],
...config
}) {
const replaceConfig = {
exclude: 'node_modules/**',
delimiters: ['', ''],
values: {
// replaceConfig needs to have some values
'const polyfill = process.env.NODE_ENV === \'test\'': 'const polyfill = false',
}
}
// keep simple polyfills when buble plugin is used for build
if (plugins && plugins.some(p => p.name === 'buble')) {
replaceConfig.values = {
'const polyfill = process.env.NODE_ENV === \'test\'': 'const polyfill = true',
}
}
return defaultsDeep({}, config, {
input: 'src/browser.js',
output: {
name: 'VueMeta',
format: 'umd',
sourcemap: false,
banner
},
plugins: [
json(),
nodeResolve(),
commonjs(),
replace(replaceConfig)
].concat(plugins),
})
}
export default [
// umd web build
{
output: {
file: pkg.web,
},
plugins: [
buble()
]
},
// minimized umd web build
{
output: {
file: pkg.web.replace('.js', '.min.js'),
},
plugins: [
buble(),
terser()
]
},
// common js build
{
input: 'src/index.js',
output: {
file: pkg.main,
format: 'cjs'
},
plugins: [
buble()
],
external: Object.keys(pkg.dependencies)
},
// esm build
{
input: 'src/index.js',
output: {
file: pkg.web.replace('.js', '.esm.js'),
format: 'es'
},
plugins: [
buble()
],
external: Object.keys(pkg.dependencies)
},
// browser esm build
{
input: 'src/browser.js',
output: {
file: pkg.web.replace('.js', '.esm.browser.js'),
format: 'es'
},
external: Object.keys(pkg.dependencies)
},
// minimized browser esm build
{
input: 'src/browser.js',
output: {
file: pkg.web.replace('.js', '.esm.browser.min.js'),
format: 'es'
},
plugins: [
terser()
],
external: Object.keys(pkg.dependencies)
}
].map(rollupConfig)