-
Notifications
You must be signed in to change notification settings - Fork 0
/
next.config.js
58 lines (49 loc) · 1.56 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
/** @type {import('next').NextConfig} */
const regexEqual = (x, y) => {
return (
x instanceof RegExp &&
y instanceof RegExp &&
x.source === y.source &&
x.global === y.global &&
x.ignoreCase === y.ignoreCase &&
x.multiline === y.multiline
)
}
module.exports = {
reactStrictMode: true,
webpack: (config, { isServer }) => {
const oneOf = config.module.rules.find(
(rule) => typeof rule.oneOf === 'object'
)
if (oneOf) {
const moduleCssRule = oneOf.oneOf.find(
(rule) => regexEqual(rule.test, /\.module\.css$/)
)
if (moduleCssRule) {
const cssLoader = moduleCssRule.use.find(({ loader }) =>
loader.includes('css-loader')
)
if (cssLoader) {
cssLoader.options.modules.mode = 'local'
}
}
const fixUse = (use) => {
if (use.loader.indexOf('css-loader') >= 0 && use.options.modules) {
use.options.modules.mode = 'local'
}
}
oneOf.oneOf.forEach((rule) => {
if (Array.isArray(rule.use)) {
rule.use.map(fixUse)
} else if (rule.use && rule.use.loader) {
fixUse(rule.use)
}
})
}
if (!isServer) {
config.resolve.fallback.fs = false
}
config.plugins = config.plugins || []
return config
},
}