-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbabel.config.js
84 lines (73 loc) · 3.14 KB
/
babel.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
const developmentEnvironments = ["development", "test"];
const developmentPlugins = [require("@babel/plugin-transform-runtime")];
const productionPlugins = [
require("babel-plugin-dev-expression"),
// babel-preset-react-optimize
require("@babel/plugin-transform-react-constant-elements"),
require("@babel/plugin-transform-react-inline-elements"),
require("babel-plugin-transform-react-remove-prop-types"),
];
module.exports = (api) => {
// See docs about api at https://babeljs.io/docs/en/config-files#apicache
const development = api.env(developmentEnvironments);
return {
presets: [
// @babel/preset-env will automatically target our browserslist targets
require("@babel/preset-env"),
require("@babel/preset-typescript"),
[require("@babel/preset-react"), { development }],
],
plugins: [
// Stage 0
require("@babel/plugin-proposal-function-bind"),
// Stage 1
require("@babel/plugin-proposal-export-default-from"),
require("@babel/plugin-proposal-logical-assignment-operators"),
[require("@babel/plugin-proposal-optional-chaining"), { loose: false }],
[require("@babel/plugin-proposal-pipeline-operator"), { proposal: "minimal" }],
[require("@babel/plugin-proposal-nullish-coalescing-operator"), { loose: false }],
require("@babel/plugin-proposal-do-expressions"),
// Stage 2
[require("@babel/plugin-proposal-decorators"), { legacy: true }],
require("@babel/plugin-proposal-function-sent"),
require("@babel/plugin-proposal-export-namespace-from"),
require("@babel/plugin-proposal-numeric-separator"),
require("@babel/plugin-proposal-throw-expressions"),
// Stage 3
require("@babel/plugin-syntax-dynamic-import"),
require("@babel/plugin-syntax-import-meta"),
[require("@babel/plugin-proposal-class-properties"), { loose: true }],
require("@babel/plugin-proposal-json-strings"),
...(development ? developmentPlugins : productionPlugins),
// Material UI tree shaking
[
"babel-plugin-import",
{
libraryName: "@material-ui/core",
// Use "'libraryDirectory': ''," if your bundler does not support ES modules
libraryDirectory: "esm",
camel2DashComponentName: false,
},
"core",
],
[
"babel-plugin-import",
{
libraryName: "@material-ui/icons",
// Use "'libraryDirectory': ''," if your bundler does not support ES modules
libraryDirectory: "esm",
camel2DashComponentName: false,
},
"icons",
],
[
"module-resolver",
{
alias: {
"-": "./src",
},
},
],
],
};
};