-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnext.config.js
66 lines (56 loc) · 1.58 KB
/
next.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
const path = require('path');
const withPlugins = require('next-compose-plugins');
const sass = require('@zeit/next-sass');
const css = require('@zeit/next-css');
const withTM = require('next-transpile-modules')(['react-map-gl', 'rbx', 'react-datepicker', 'dayjs']);
const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');
const Dotenv = require('dotenv-webpack');
module.exports = withPlugins([
[withTM, {
transpileModules: ['react-map-gl', 'rbx', 'react-datepicker', 'dayjs']
}],
[sass, {
sassLoaderOptions: {
includePaths: [path.resolve('node_modules')]
}
}],
[css]
], {
experimental: {
modern: true
},
generateBuildId: async () => {
// Get Git commit hash
const hash = require('child_process')
.execSync('git rev-parse HEAD')
.toString().trim().slice(0, 7);
return hash;
},
webpack: config => {
config.plugins = config.plugins || [];
config.plugins = [
...config.plugins,
// Read the .env file
new Dotenv({
path: path.join(__dirname, '.env')
})
];
const isProduction = config.mode === 'production';
if (!isProduction) {
return config;
}
config.optimization.minimizer.push(
new OptimizeCSSAssetsPlugin({})
);
// Unshift polyfills in main entrypoint.
const originalEntry = config.entry;
config.entry = async () => {
const entries = await originalEntry();
if (entries['main.js']) {
entries['main.js'].unshift('./components/lib/polyfills.js');
}
return entries;
};
return config;
}
});