forked from vuejs/rollup-plugin-vue
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.js
68 lines (62 loc) · 1.56 KB
/
build.js
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
const rollup = require('rollup').rollup
const vue = require('../dist/rollup-plugin-vue.common.js')
const buble = require('rollup-plugin-buble')
const uglify = require('uglify-js')
const CleanCSS = require('clean-css')
const fs = require('fs')
const stylus = require('stylus')
rollup({
entry: 'index.js',
plugins: [
vue({
compileTemplate: true,
css (styles, stylesNodes) {
write('dist/papervue.styl', styles)
stylus.render(styles, function (err, css) {
if (err) throw err
write('dist/papervue.css', css)
write('dist/papervue.min.css', new CleanCSS().minify(css).styles)
})
}
}),
buble()
]
})
.then(function (bundle) {
var code = bundle.generate({
format: 'umd',
moduleName: 'helloRollupVue',
useStrict: false
}).code
return write('dist/papervue.js', code).then(function () {
return code
})
})
.then(function (code) {
var minified = uglify.minify(code, {
fromString: true,
output: {
ascii_only: true
}
}).code
return write('dist/papervue.min.js', minified)
})
.catch(logError)
function write (dest, code) {
return new Promise(function (resolve, reject) {
fs.writeFile(dest, code, function (err) {
if (err) return reject(err)
console.log(blue(dest) + ' ' + getSize(code))
resolve()
})
})
}
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'
}