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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
const fs = require('fs');
const del = require('del');
const Bili = require('bili');
const pkg = require('./package.json');
const options = {
input: './src/index.js',
outDir: 'lib',
name: 'reactjs-popup',
format: ['es', 'cjs', 'umd', 'umd-min'],
banner: true,
target: 'browser',
external: Object.keys(pkg.peerDependencies),
};
// some confuse between babel config for parcel that use v6 and Bili that's use V7
const babelBiliConfig = {
presets: [['@babel/preset-env', {modules: false}], '@babel/preset-react'],
plugins: ['@babel/plugin-proposal-class-properties'],
};
const babelParcelConfig = {
presets: [
[
'@babel/preset-env',
{
targets: {
node: 'current',
},
},
],
'@babel/preset-react',
],
plugins: ['@babel/plugin-proposal-class-properties'],
};
// Copy package.json, LICENSE,README and npmignore files
const writePackageFiles = () => {
delete pkg.devDependencies;
delete pkg.scripts;
fs.writeFileSync(
'./lib/package.json',
JSON.stringify(pkg, null, ' '),
'utf-8',
);
fs.writeFileSync(
'./lib/LICENSE',
fs.readFileSync('LICENSE', 'utf-8'),
'utf-8',
);
fs.writeFileSync(
'./lib/README.md',
fs.readFileSync('README.md', 'utf-8'),
'utf-8',
);
fs.writeFileSync(
'lib/.npmignore',
fs.readFileSync('.npmignore', 'utf-8'),
'utf-8',
);
fs.writeFileSync(
'./lib/index.d.ts',
fs.readFileSync('src/index.d.ts', 'utf-8'),
'utf-8',
);
};
// and use babel config V7
// Clean up the output directory
const Build = () => {
console.log('Delete old build Folder ....');
del(['lib/*']).then(() => {
fs.writeFileSync(
'./.babelrc',
JSON.stringify(babelBiliConfig, null, ' '),
'utf-8',
);
Bili.write(options).then(() => {
fs.writeFileSync(
'./.babelrc',
JSON.stringify(babelParcelConfig, null, ' '),
'utf-8',
);
});
writePackageFiles();
});
};
let promise = Promise.resolve();
promise = promise.then(Build);
// catch errors
promise.catch(err => console.error(err.stack));
|