-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathrollup.config.mjs
115 lines (105 loc) · 2.6 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
/* eslint-disable import/no-extraneous-dependencies */
import { babel } from '@rollup/plugin-babel';
import replace from '@rollup/plugin-replace';
import terser from '@rollup/plugin-terser';
import { nodeResolve } from '@rollup/plugin-node-resolve';
import commonjs from '@rollup/plugin-commonjs';
import copy from 'rollup-plugin-copy';
import serve from 'rollup-plugin-serve';
import data from './package.json' assert { type: 'json' };
const year = new Date().getFullYear();
function getHeader() {
return `/*!
* ${data.title} v${data.version} (${data.homepage})
* Copyright ${year} ${data.author}
* Licensed under MIT (https://github.com/nk-o/flickr-justified-gallery/blob/master/LICENSE)
*/`;
}
const pathCore = './src/fjGallery.esm.js';
const pathCoreUmd = './src/fjGallery.umd.js';
const bundles = [
// Core.
{
input: pathCore,
output: {
banner: getHeader(),
file: './dist/fjGallery.esm.js',
format: 'esm',
},
},
{
input: pathCore,
output: {
banner: getHeader(),
file: './dist/fjGallery.esm.min.js',
format: 'esm',
},
},
{
input: pathCoreUmd,
output: {
banner: getHeader(),
name: 'fjGallery',
file: './dist/fjGallery.js',
format: 'umd',
},
},
{
input: pathCoreUmd,
output: {
banner: getHeader(),
name: 'fjGallery',
file: './dist/fjGallery.min.js',
format: 'umd',
},
},
{
input: pathCore,
output: {
banner: getHeader(),
file: './dist/fjGallery.cjs',
format: 'cjs',
},
},
];
const isDev = () => process.env.NODE_ENV === 'dev';
const isUMD = (file) => file.includes('fjGallery.js');
const isMinEnv = (file) => file.includes('.min.');
const isSpecificEnv = (file) => isMinEnv(file);
const isDebugAlways = (file) => (isDev() || isUMD(file) ? 'true' : 'false');
const configs = bundles.map(({ input: inputPath, output }) => ({
input: inputPath,
output,
plugins: [
nodeResolve(),
commonjs(),
babel({
babelHelpers: 'bundled',
plugins: ['annotate-pure-calls'],
}),
replace({
__DEV__: isSpecificEnv(output.file)
? isDebugAlways(output.file)
: 'process.env.NODE_ENV !== "production"',
preventAssignment: true,
}),
output.file.includes('.min.') && terser(),
],
}));
// Copy CSS file to dist.
configs[0].plugins.unshift(
copy({
targets: [{ src: 'src/fjGallery.css', dest: 'dist' }],
})
);
// Dev server.
if (isDev()) {
configs[configs.length - 1].plugins.push(
serve({
open: true,
contentBase: ['demo', './'],
port: 3002,
})
);
}
export default configs;