-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathcraco.config.ts
57 lines (55 loc) · 1.73 KB
/
craco.config.ts
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
const CracoAntDesignPlugin = require('craco-antd');
const path = require('path');
const webpack = require('webpack');
const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');
const WebpackBar = require('webpackbar');
process.env.BROWSER = 'none';
// eslint-disable-next-line import/no-anonymous-default-export
export default {
plugins: [
{
plugin: CracoAntDesignPlugin,
options: {
customizeThemeLessPath: path.join(__dirname, 'src/assets/styles/antd.customize.less'),
javascriptEnabled: true,
},
},
],
webpack: {
configure: (webpackConfig: any, { env, paths }: any): any => {
webpackConfig.module.rules = webpackConfig.module.rules.map((rule: any) => {
if (rule.oneOf instanceof Array) {
return {
...rule,
oneOf: [{ test: /\.wasm$/, type: 'webassembly/async' }, ...rule.oneOf],
};
}
return rule;
});
//
const fallback = webpackConfig.resolve.fallback || {};
Object.assign(fallback, {
os: require.resolve('os-browserify/browser'),
buffer: require.resolve('buffer'),
// Required for liquidjs-lib
stream: require.resolve('stream-browserify'),
});
webpackConfig.resolve.fallback = fallback;
//
webpackConfig.plugins = (webpackConfig.plugins || []).concat([
new webpack.ProvidePlugin({
Buffer: ['buffer', 'Buffer'],
}),
]);
//
webpackConfig.experiments = {
asyncWebAssembly: true,
};
return webpackConfig;
},
plugins: [
new WebpackBar({ profile: true }),
...(process.env.NODE_ENV === 'development' ? [new BundleAnalyzerPlugin({ openAnalyzer: false })] : []),
],
},
};