forked from chartjs/Chart.js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
rollup.config.js
119 lines (114 loc) · 2.32 KB
/
rollup.config.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
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/* eslint-disable import/no-commonjs */
/* eslint-env es6 */
const babel = require('rollup-plugin-babel');
const cleanup = require('rollup-plugin-cleanup');
const dts = require('rollup-plugin-dts').default;
const glob = require('glob');
const inject = require('@rollup/plugin-inject');
const json = require('@rollup/plugin-json');
const resolve = require('@rollup/plugin-node-resolve').default;
const terser = require('rollup-plugin-terser').terser;
const pkg = require('./package.json');
const input = 'src/index.js';
const inputESM = {
'dist/chart.esm': 'src/index.esm.js',
};
const inputESMTypings = {};
glob('src/helpers/helpers.*.js', (_er, files) => {
files.forEach(file => {
inputESM[file.replace(/src\/|helpers\.|\.js/g, '')] = file;
});
Object.keys(inputESM).forEach((key) => {
inputESMTypings[key.replace('src', 'types')] = inputESM[key].replace('src', 'types').replace(/\.js$/, '.d.ts');
});
});
const banner = `/*!
* Chart.js v${pkg.version}
* ${pkg.homepage}
* (c) ${(new Date(process.env.SOURCE_DATE_EPOCH ? (process.env.SOURCE_DATE_EPOCH * 1000) : new Date().getTime())).getFullYear()} Chart.js Contributors
* Released under the MIT License
*/`;
module.exports = [
// UMD builds
// dist/chart.min.js
// dist/chart.js
{
input,
plugins: [
inject({
ResizeObserver: 'resize-observer-polyfill'
}),
json(),
resolve(),
babel(),
cleanup({
sourcemap: true
})
],
output: {
name: 'Chart',
file: 'dist/chart.js',
banner,
format: 'umd',
indent: false,
},
},
{
input,
plugins: [
inject({
ResizeObserver: 'resize-observer-polyfill'
}),
json(),
resolve(),
babel(),
terser({
output: {
preamble: banner
}
})
],
output: {
name: 'Chart',
file: 'dist/chart.min.js',
format: 'umd',
indent: false,
},
},
// ES6 builds
// dist/chart.esm.js
// helpers/*.js
{
input: inputESM,
plugins: [
json(),
resolve(),
cleanup({
sourcemap: true
})
],
output: {
dir: './',
chunkFileNames: 'helpers/chunks/[name].js',
banner,
format: 'esm',
indent: false,
},
},
// ES6 Typings builds
// dist/chart.esm.d.ts
// helpers/*.d.ts
{
input: inputESMTypings,
plugins: [
dts()
],
output: {
dir: './',
chunkFileNames: 'helpers/chunks/[name].ts',
banner,
format: 'esm',
indent: false,
},
}
];