-
Notifications
You must be signed in to change notification settings - Fork 73
/
rollup.config.mjs
125 lines (117 loc) · 2.78 KB
/
rollup.config.mjs
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
120
121
122
123
124
125
import { createRequire } from 'node:module';
import { fileURLToPath } from 'node:url';
import autoprefixer from 'autoprefixer';
import merge from 'lodash.merge';
import babel from '@rollup/plugin-babel';
import commonjs from '@rollup/plugin-commonjs';
import eslint from '@rollup/plugin-eslint';
import json from '@rollup/plugin-json';
import resolve from '@rollup/plugin-node-resolve';
import terser from '@rollup/plugin-terser';
import postcss from 'rollup-plugin-postcss';
const require = createRequire(import.meta.url);
const pkg = require('./package.json');
const entryFile = fileURLToPath(new URL('src/index.js', import.meta.url));
const outputFile = fileURLToPath(
new URL(`dist/${pkg.name}.js`, import.meta.url)
);
const currentYear = new Date().getFullYear();
const releaseYear = 2017;
const bannerData = [
`${pkg.name}`,
`v${pkg.version}`,
`${pkg.homepage}`,
`(c) ${releaseYear}${currentYear === releaseYear ? '' : '-' + currentYear} ${
pkg.author
}`,
`${pkg.license} license`,
];
// Plugins
const pluginSettings = {
eslint: {
exclude: ['node_modules/**', './package.json', '**.css'],
throwOnWarning: false,
throwOnError: true,
},
babel: {
babelHelpers: 'bundled',
exclude: ['node_modules/**'],
presets: [
[
'@babel/env',
{
modules: false,
targets: 'last 2 versions, ie > 10',
},
],
],
},
commonjs: {
exclude: ['**.css'],
},
json: {},
postcss: {
inject: true,
minimize: true,
plugins: [autoprefixer()],
},
resolve: {
moduleDirectories: ['node_modules'],
},
terser: {
beautify: {
compress: false,
mangle: false,
output: {
beautify: true,
comments: 'some',
},
},
minify: {
compress: true,
mangle: true,
output: {
comments: new RegExp(pkg.name),
},
},
},
};
/**
* @type {import('rollup').RollupOptions}
*/
const config = {
strictDeprecations: true,
input: entryFile,
output: {
file: outputFile,
banner: `/*!\n * ${bannerData.join('\n * ')}\n */`,
sourcemap: true,
},
plugins: [
postcss(pluginSettings.postcss),
resolve(pluginSettings.resolve),
commonjs(pluginSettings.commonjs),
json(pluginSettings.json),
eslint(pluginSettings.eslint),
babel(pluginSettings.babel),
],
watch: {
clearScreen: false,
},
};
// IIFE
const iife = merge({}, config, {
output: {
format: 'iife',
},
plugins: config.plugins.concat([terser(pluginSettings.terser.beautify)]),
});
// IIFE (Minified)
const iifeMinified = merge({}, config, {
output: {
file: iife.output.file.replace(/\.js$/, '.min.js'),
format: iife.output.format,
},
plugins: config.plugins.concat([terser(pluginSettings.terser.minify)]),
});
export default [iife, iifeMinified];