-
Notifications
You must be signed in to change notification settings - Fork 38
/
craco.config.js
74 lines (71 loc) · 2.47 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
const webpack = require('webpack');
const path = require('path');
module.exports = {
babel: {
presets: ["@babel/preset-react", "@babel/preset-env", "@babel/typescript"],
plugins: [
"@babel/plugin-proposal-numeric-separator",
"@babel/proposal-class-properties",
"@babel/proposal-object-rest-spread",
"@babel/plugin-proposal-optional-chaining"
],
},
plugins: [
{
plugin: {
overrideCracoConfig: ({ cracoConfig }) => {
if (typeof cracoConfig.eslint.enable !== 'undefined') {
cracoConfig.disableEslint = !cracoConfig.eslint.enable;
}
delete cracoConfig.eslint;
return cracoConfig;
},
overrideWebpackConfig: ({ webpackConfig, pluginOptions }) => {
const dfxJson = require(`${__dirname}/dfx.json`);
if (typeof pluginOptions.disableEslint !== 'undefined' &&
pluginOptions.disableEslint === true ) {
webpackConfig.plugins = webpackConfig.plugins.filter(
(instance) => instance.constructor.name !== 'ESLintWebpackPlugin');
}
const networkName = process.env["DFX_NETWORK"] || "local";
const aliases = Object.entries(dfxJson.canisters).reduce((acc, [name, value]) => {
const outputRoot = path.join(
__dirname,
".dfx",
networkName,
`${dfxJson.defaults.build.output}`,
name,
);
return {
...acc,
["dfx-generated/" + name]: path.join(outputRoot, name + ".js"),
};
}, {});
return {
...webpackConfig,
devtool: "source-map",
mode: process.env.NODE_ENV === 'development' ? 'development' :'production',
plugins: [
...webpackConfig.plugins,
new webpack.ProvidePlugin({
Buffer: [require.resolve("buffer/"), "Buffer"],
}),
],
resolve: {
...webpackConfig.resolve,
alias: { ...webpackConfig.resolve.alias, ...aliases },
extensions: [...webpackConfig.resolve.extensions, '.tsx', '.ts', '.js'],
plugins: [
...webpackConfig.resolve.plugins.filter((t) => {
// Removes ModuleScopePlugin
return !Object.keys(t).includes('appSrcs');
}),
],
},
};
},
},
options: {},
},
],
};