-
Notifications
You must be signed in to change notification settings - Fork 15
/
rollup.config.js
124 lines (114 loc) · 2.55 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
120
121
122
123
124
const path = require('path');
import autoprefixer from 'autoprefixer';
import babel from '@rollup/plugin-babel';
import commonjs from '@rollup/plugin-commonjs';
import json from '@rollup/plugin-json';
import merge from 'lodash.merge';
import pkg from './package.json';
import postcss from 'rollup-plugin-postcss'
import resolve from '@rollup/plugin-node-resolve';
import url from '@rollup/plugin-url';
import { terser } from 'rollup-plugin-terser';
import { eslint } from 'rollup-plugin-eslint';
const entryFile = path.resolve(__dirname, 'src', 'index.js');
const outputFile = path.resolve(__dirname, 'dist', `${pkg.name}.js`);
// Banner
const bannerData = [
`${pkg.name}`,
`v${pkg.version}`,
`${pkg.homepage}`,
`(c) ${(new Date()).getFullYear()} ${pkg.author}`,
`${pkg.license} license`
];
// Plugins
const pluginSettings = {
eslint: {
exclude: ['node_modules/**', './package.json', '**/*.scss'],
throwOnWarning: false,
throwOnError: true
},
babel: {
exclude: ['node_modules/**'],
babelHelpers: 'bundled',
presets: [
['@babel/preset-env', {
modules: false,
targets: {
browsers: ['ie >= 9']
}
}]
]
},
postcss: {
minimize: true,
plugins: [
autoprefixer()
]
},
url: {
limit: 10 * 1024, // inline files < 10k, copy files > 10k
include: ["**/*.svg"], // defaults to .svg, .png, .jpg and .gif files
emitFiles: true // defaults to true
},
terser: {
beautify: {
compress: false,
mangle: false,
output: {
beautify: true,
comments: /(?:^!|@(?:license|preserve))/
}
},
minify: {
compress: true,
mangle: true,
output: {
comments: new RegExp(pkg.name)
}
}
}
};
// Config Base
const config = {
input: entryFile,
output: {
file: outputFile,
banner: `/*!\n * ${bannerData.join('\n * ')}\n */`,
sourcemap: true
},
plugins: [
url(pluginSettings.url),
postcss(pluginSettings.postcss),
resolve(),
commonjs(),
json(),
eslint(pluginSettings.eslint),
babel(pluginSettings.babel)
],
watch: {
clearScreen: false
}
};
// Format: IIFE
const iife = merge({}, config, {
output: {
format: 'iife'
},
plugins: [
terser(pluginSettings.terser.beautify)
]
});
// Format: IIFE (Minified)
const iifeMinified = merge({}, config, {
output: {
file: iife.output.file.replace(/\.js$/, '.min.js'),
format: iife.output.format
},
plugins: [
terser(pluginSettings.terser.minify)
]
});
export default [
iife,
iifeMinified
];