forked from xivanalysis/xivanalysis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
babel.config.js
57 lines (54 loc) · 1.58 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
const getPlugins = ({
isDevelopment = false,
isTypescript = false,
isTSX = false,
} = {}) => [
'./config/babel-plugin-xiva-dependency',
isTypescript && ['@babel/plugin-transform-typescript', {
isTSX,
allowDeclareFields: true,
}],
['@babel/plugin-proposal-decorators', {legacy: true}],
['@babel/plugin-proposal-class-properties', {loose: true}],
['@babel/plugin-proposal-private-methods', {loose: true}],
'babel-plugin-macros',
'babel-plugin-lodash',
!isDevelopment && ['babel-plugin-transform-react-remove-prop-types', {
removeImport: true,
}],
'./locale/babel-plugin-transform-react.js',
['@babel/plugin-transform-runtime', {
corejs: {version: 3},
useESModules: true,
version: '^7.12.5',
}],
].filter(item => !!item)
const needsNodeTarget = caller => false
|| caller?.name === '@babel/register'
|| caller?.name === '@babel/node'
|| caller?.name === 'babel-jest'
module.exports = api => ({
presets: [
['@babel/preset-env', {
// If running under register, we need to swap down to node target, otherwise
// permit fallback to browserslist config handling.
targets: api.caller(needsNodeTarget)
? {node: true}
: undefined,
}],
['@babel/preset-react', {
development: api.env('development'),
runtime: 'automatic',
}],
],
overrides: [{
test: /\.jsx?$/,
plugins: getPlugins({isDevelopment: api.env('development')}),
}, {
test: /\.ts$/,
plugins: getPlugins({isDevelopment: api.env('development'), isTypescript: true}),
}, {
test: /\.tsx$/,
plugins: getPlugins({isDevelopment: api.env('development'), isTypescript: true, isTSX: true}),
}],
})