UNPKG

vue-custom-element

Version:
134 lines (119 loc) 2.97 kB
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' }