-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack-config.js
50 lines (43 loc) · 1.33 KB
/
webpack-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
const webpack = require('webpack');
const path = require('path');
module.exports = { webpackOverride };
function webpackOverride(config) {
// disable whatever is already set to load SVGs
config.module.rules
.filter(rule => rule.test && rule.test.test?.('.svg'))
.forEach(rule => (rule.exclude = /\.svg$/i));
config.module.rules.push({
test: /\.svg$/,
use: [
{
loader: '@svgr/webpack',
options: {
icon: true,
},
},
],
});
config.resolve.fallback = {
fs: false,
path: require.resolve('path-browserify'),
constants: false,
crypto: require.resolve('crypto-browserify'),
assert: require.resolve('assert'),
http: require.resolve('stream-http'),
https: require.resolve('https-browserify'),
os: require.resolve('os-browserify'),
url: require.resolve('url'),
stream: require.resolve('stream-browserify'),
buffer: require.resolve('buffer'),
};
config.plugins.push(
new webpack.ProvidePlugin({
Buffer: ['buffer', 'Buffer'],
})
);
config.resolve.alias = {
...config.resolve.alias,
'.storybook': path.resolve(__dirname, './.storybook/'),
};
return config;
}