-
Notifications
You must be signed in to change notification settings - Fork 2
/
rollup.config.js
109 lines (105 loc) · 1.93 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
import babel from '@rollup/plugin-babel';
import commonjs from '@rollup/plugin-commonjs';
import nodeResolve from '@rollup/plugin-node-resolve';
import replace from '@rollup/plugin-replace';
import copy from 'rollup-plugin-copy';
import esbuild from 'rollup-plugin-esbuild';
import scss from 'rollup-plugin-scss';
import watchGlobs from 'rollup-plugin-watch-globs';
import * as sass from 'sass';
const serverBundle = {
input: 'src/server/app.js',
output: {
file: 'built/main.js',
sourcemap: 'inline'
},
external: [
'@reduxjs/toolkit',
'classnames',
'express',
'express-handlebars',
'express-session',
'morgan',
'node:http',
'node:path',
'node:url',
'prop-types',
'react',
'react/jsx-runtime',
'react-bootstrap-typeahead',
'react-dom/server',
'react-helmet',
'react-redux',
'react-router-dom',
'react-router-dom/server.js',
'serve-favicon'
],
watch: {
clearScreen: false
},
plugins: [
esbuild({
jsx: 'automatic'
}),
copy({
targets: [
{ src: './src/client/assets/favicon.ico', dest: 'built/assets' }
]
})
]
};
const clientScriptsBundle = {
input: 'src/react/client-mount.jsx',
output: {
file: 'public/main.js',
format: 'iife'
},
watch: {
clearScreen: false
},
plugins: [
nodeResolve({
browser: true,
extensions: ['.js', '.jsx']
}),
babel({
babelHelpers: 'bundled',
presets: [
[
'@babel/preset-react',
{ runtime: 'automatic' }
]
],
extensions: ['.js', '.jsx']
}),
commonjs(),
replace({
preventAssignment: false,
'process.env.NODE_ENV': JSON.stringify('development')
})
]
};
const clientStylesBundle = {
input: 'src/client/stylesheets/index.scss',
output: {
dir: 'public'
},
watch: {
clearScreen: false
},
plugins: [
watchGlobs([
'src/client/stylesheets/**/*.scss'
]),
scss({
fileName: 'main.css',
failOnError: true,
sass
})
]
};
export default [
serverBundle,
clientScriptsBundle,
clientStylesBundle
];