-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathbuild.js
67 lines (61 loc) · 1.54 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
var fs = require('fs');
var rollup = require('rollup');
var uglify = require('uglify-js');
var buble = require('rollup-plugin-buble');
var package = require('./package.json');
var banner =
"/*!\n" +
" * vue-masonry-css v" + package.version + "\n" +
" * https://github.com/paulcollett/vue-masonry-css\n" +
" * Released under the MIT License.\n" +
" */\n";
rollup.rollup({
input: 'src/index.js',
plugins: [buble()]
})
.then(bundle =>
bundle.generate({
format: 'umd',
banner: banner,
name: 'VueMasonry'
}).then(({code}) => write('dist/vue-masonry.js', code, bundle))
)
.then(bundle =>
write('dist/vue-masonry.min.js', banner + '\n' +
uglify.minify(read('dist/vue-masonry.js')).code,
bundle)
)
.then(bundle =>
bundle.generate({
format: 'es',
banner: banner
}).then(({code}) => write('dist/vue-masonry.es2015.js', code, bundle))
)
.then(bundle =>
bundle.generate({
format: 'cjs',
banner: banner
}).then(({code}) => write('dist/vue-masonry.common.js', code, bundle))
)
.catch(logError);
function read(path) {
return fs.readFileSync(path, 'utf8');
}
function write(dest, code, bundle) {
return new Promise(function (resolve, reject) {
fs.writeFile(dest, code, function (err) {
if (err) return reject(err);
console.log(blue(dest) + ' ' + getSize(code));
resolve(bundle);
});
});
}
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';
}