vue-custom-element
Version:
Custom Elements for Vue.js
134 lines (119 loc) • 2.97 kB
JavaScript
const fs = require('fs')
const path = require('path')
const zlib = require('zlib')
const uglify = require('uglify-js')
const rollup = require('rollup')
const babel = require('rollup-plugin-babel')
const cjs = require('rollup-plugin-commonjs')
const node = require('rollup-plugin-node-resolve')
const replace = require('rollup-plugin-replace')
const version = process.env.VERSION || require('../package.json').version
const banner =
`/**
* vue-custom-element v${version}
* (c) ${new Date().getFullYear()} Karol Fabjańczuk
* @license MIT
*/`
if (!fs.existsSync('dist')) {
fs.mkdirSync('dist')
}
const resolve = _path => path.resolve(__dirname, '../', _path)
build([
// browser dev
{
dest: resolve('dist/vue-custom-element.js'),
format: 'umd',
env: 'development'
},
{
dest: resolve('dist/vue-custom-element.min.js'),
format: 'umd',
env: 'production'
},
{
dest: resolve('dist/vue-custom-element.esm.js'),
format: 'es',
env: 'development'
}
].map(genConfig))
function build (builds) {
let built = 0
const total = builds.length
const next = () => {
buildEntry(builds[built]).then(() => {
built++
if (built < total) {
next()
}
}).catch(logError)
}
next()
}
function genConfig (opts) {
const config = {
input: resolve('src/vue-custom-element.js'),
output: {
file: opts.dest,
name: 'VueCustomElement',
format: opts.format,
banner
},
plugins: [
node(),
cjs(),
replace({
__VERSION__: version
}),
babel()
]
}
if (opts.env) {
config.plugins.unshift(replace({
'process.env.NODE_ENV': JSON.stringify(opts.env)
}))
}
return config
}
function buildEntry (config) {
const isProd = /min\.js$/.test(config.output.file)
return rollup.rollup(config).then(bundle => {
bundle.generate(config)
.then(({ code }) => {
if (isProd) {
var minified = (config.output.banner ? config.output.banner + '\n' : '') + uglify.minify(code, {}).code
return write(config.output.file, minified, true)
} else {
return write(config.output.file, code)
}
})
.catch((e) => console.log(e));
})
}
function write (dest, code, zip) {
return new Promise((resolve, reject) => {
function report (extra) {
console.log(blue(path.relative(process.cwd(), dest)) + ' ' + getSize(code) + (extra || ''))
resolve()
}
fs.writeFile(dest, code, err => {
if (err) return reject(err)
if (zip) {
zlib.gzip(code, (err, zipped) => {
if (err) return reject(err)
report(' (gzipped: ' + getSize(zipped) + ')')
})
} else {
report()
}
})
})
}
function getSize (code) {
return (code.length / 1024).toFixed(2) + 'kb'
}
function logError (e) {
console.log(e)
}
function blue (str) {
return '\x1b[1m\x1b[34m' + str + '\x1b[39m\x1b[22m'
}