forked from nervosnetwork/ckb-explorer-frontend
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathconfig-overrides.js
95 lines (87 loc) · 3.94 KB
/
config-overrides.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
/* config-overrides.js */
const SentryWebpackPlugin = require('@sentry/webpack-plugin')
const AntdDayjsWebpackPlugin = require('antd-dayjs-webpack-plugin')
const getCSSModuleLocalIdent = require('react-dev-utils/getCSSModuleLocalIdent')
const webpack = require('webpack')
module.exports = function override(config) {
if (config.ignoreWarnings == null) {
// eslint-disable-next-line no-param-reassign
config.ignoreWarnings = []
}
// The sourcemap configuration of some of the dependency packages in the project is
// not standard, but it can't be resolved. For now, filter out these warnings directly.
config.ignoreWarnings.push(/Failed to parse source map/)
if (config.plugins == null) {
// eslint-disable-next-line no-param-reassign
config.plugins = []
}
const isProduction = process.env.NODE_ENV === 'production'
if (isProduction && process.env.SENTRY_AUTH_TOKEN) {
const isMainnet = process.env.REACT_APP_CHAIN_TYPE === 'mainnet'
config.plugins.push(
new SentryWebpackPlugin({
include: './build',
// The token must need `project:releases` and `org:read` scopes
authToken: process.env.SENTRY_AUTH_TOKEN,
org: process.env.SENTRY_ORG || 'nervosnet',
project:
process.env.SENTRY_PROJECT || (isMainnet ? 'ckb-explorer-frontend-mainnet' : 'ckb-explorer-frontend-testnet'),
}),
new AntdDayjsWebpackPlugin(),
)
}
// https://dhanrajsp.me/snippets/customize-css-loader-options-in-nextjs
const oneOf = config.module.rules.find(rule => typeof rule.oneOf === 'object')
if (oneOf) {
const moduleSassRule = oneOf.oneOf.find(rule => regexEqual(rule.test, /\.module\.(scss|sass)$/))
if (moduleSassRule) {
// Get the config object for css-loader plugin
const cssLoader = moduleSassRule.use.find(({ loader }) => loader?.includes('css-loader'))
if (cssLoader) {
cssLoader.options = {
...cssLoader.options,
modules: {
...cssLoader.options.modules,
// By default, `CRA` uses `node_modules\react-dev-utils\getCSSModuleLocalIdent` as `getLocalIdent` passed to `css-loader`,
// which generates class names with base64 suffixes.
// However, the `@value` syntax of CSS modules does not execute `escapeLocalIdent` when replacing corresponding class names in actual files.
// Therefore, if a class name's base64 hash contains `+` and is also imported into another file using `@value`,
// the selector after applying the `@value` syntax will be incorrect.
// For example, `.CompA_main__KW\+Cg` will become `.CompA_main__KW+Cg` when imported into another file.
// This may not be a bug but a feature, because `@value` is probably not designed specifically for importing selectors from other files.
// So here, we add a `+` handling based on the logic of escapeLocalIdent.
getLocalIdent: (...args) => getCSSModuleLocalIdent(...args).replaceAll('+', '-'),
},
}
}
}
}
// for lumos at https://lumos-website.vercel.app/recipes/cra-vite-webpack-or-other#create-react-app
config.resolve.fallback = {
...config.resolve.fallback,
crypto: require.resolve('crypto-browserify'),
buffer: require.resolve('buffer'),
path: false,
fs: false,
stream: false,
}
config.plugins = [...config.plugins, new webpack.ProvidePlugin({ Buffer: ['buffer', 'Buffer'] })]
const miniCssExtractPlugin = config.plugins.find(plugin => plugin.constructor.name === 'MiniCssExtractPlugin')
if (miniCssExtractPlugin) {
miniCssExtractPlugin.options.ignoreOrder = true
}
return config
}
/**
* Stolen from https://stackoverflow.com/questions/10776600/testing-for-equality-of-regular-expressions
*/
function 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
)
}