-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathcraco.config.js
90 lines (87 loc) · 2.9 KB
/
craco.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
const path = require('path');
const webpack = require('webpack');
module.exports = {
webpack: {
alias: {
react: path.resolve('./node_modules/react'),
'react-dom': path.resolve('./node_modules/react-dom'),
'react-router': path.resolve('./node_modules/react-router'),
'react-router-dom': path.resolve('./node_modules/react-router-dom'),
'@zer0-os/zos-component-library': path.resolve('./node_modules/@zer0-os/zos-component-library'),
},
configure: (webpackConfig) => {
// Remove the ModuleScopePlugin which throws when we try to import something outside the `src` directory
// It's meant to protect you from doing weird things but since we use `alias` to
// force zui to use the version of react in the node_modules, we need to disable it.
const scopePluginIndex = webpackConfig.resolve.plugins.findIndex(
({ constructor }) => constructor && constructor.name === 'ModuleScopePlugin'
);
webpackConfig.resolve.plugins.splice(scopePluginIndex, 1);
// Append our custom webpack config
webpackConfig.resolve = { ...webpackConfig.resolve, ...webpackCustomConfig.resolve };
webpackConfig.ignoreWarnings = webpackCustomConfig.ignoreWarnings;
webpackConfig.watchOptions = webpackCustomConfig.watchOptions;
webpackConfig.module.rules = [...webpackConfig.module.rules, ...webpackCustomConfig.module.rules];
return webpackConfig;
},
plugins: {
add: [
new webpack.ProvidePlugin({
Buffer: ['buffer', 'Buffer'],
}),
],
},
},
devServer: {},
jest: {
configure: (jestConfig) => {
return {
...jestConfig,
transformIgnorePatterns: [
'/node_modules/@cloudinary/url-gen/\\.(js|ts|tsx)$',
],
moduleNameMapper: {
'\\.svg\\?react$': '<rootDir>/src/svgr-mock.ts',
},
};
},
},
};
const webpackCustomConfig = {
resolve: {
// https://webpack.js.org/configuration/resolve/#resolvefallback
// https://web3auth.io/docs/troubleshooting/webpack-issues#react-create-react-app
// https://docs.cloud.coinbase.com/wallet-sdk/docs/web3-react
fallback: {
crypto: false,
fs: false,
buffer: require.resolve('buffer'),
stream: require.resolve('stream-browserify'),
util: require.resolve('util/'),
assert: require.resolve('assert/'),
},
},
// https://github.com/facebook/create-react-app/discussions/11767
ignoreWarnings: [
function ignoreSourcemapsloaderWarnings(warning) {
return (
warning.module &&
warning.module.resource.includes('node_modules') &&
warning.details &&
warning.details.includes('source-map-loader')
);
},
],
module: {
rules: [
{
test: /\.mjs/,
include: /node_modules/,
type: 'javascript/auto',
},
],
},
watchOptions: {
ignored: '**/node_modules/**',
},
};