-
Notifications
You must be signed in to change notification settings - Fork 63
Expand file tree
/
Copy pathcraco.config.js
More file actions
62 lines (56 loc) · 2.13 KB
/
craco.config.js
File metadata and controls
62 lines (56 loc) · 2.13 KB
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
// craco.config.js
const webpack = require('webpack'); // Need webpack for ProvidePlugin if used later
module.exports = {
webpack: {
configure: (config) => {
// Ensure resolve and fallback exist
config.resolve = config.resolve || {};
config.resolve.fallback = config.resolve.fallback || {};
// Add fallbacks
config.resolve.fallback = {
...config.resolve.fallback,
fs: false, // Disable fs as it's not needed in the browser
path: require.resolve('path-browserify'),
crypto: require.resolve('crypto-browserify'), // Add crypto fallback
stream: require.resolve('stream-browserify'), // Add stream fallback (often needed with crypto)
vm: require.resolve('vm-browserify') // Add vm fallback (might be needed by dependencies)
};
// Add ProvidePlugin for Buffer if needed (sql.js might require it indirectly)
config.plugins = (config.plugins || []).concat([
new webpack.ProvidePlugin({
Buffer: ['buffer', 'Buffer'],
}),
]);
// Ignore specific warnings from source-map-loader if they clutter the output
config.ignoreWarnings = [
...(config.ignoreWarnings || []),
/Failed to parse source map/, // Example: Ignore source map warnings
];
// Ensure CSS files are processed correctly
const cssRule = config.module.rules.find(rule => rule.test && rule.test.toString().includes('.css'));
if (cssRule) {
// Force CSS modules to be disabled for global CSS files
cssRule.use = cssRule.use.map(loader => {
if (loader.loader && loader.loader.includes('css-loader')) {
return {
...loader,
options: {
...loader.options,
modules: false,
sourceMap: true
}
};
}
return loader;
});
}
return config;
},
},
// Disable cache to ensure fresh builds
babel: {
loaderOptions: {
cacheDirectory: false,
},
},
};