forked from Automattic/wp-calypso
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbabel.config.js
67 lines (63 loc) · 2.04 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
/** @format */
const _ = require( 'lodash' );
const path = require( 'path' );
const isCalypsoClient = process.env.CALYPSO_CLIENT === 'true';
const isCalypsoServer = process.env.CALYPSO_SERVER === 'true';
const isCalypso = isCalypsoClient || isCalypsoServer;
const modules = isCalypsoClient ? false : 'commonjs'; // only calypso should keep es6 modules
const codeSplit = require( './server/config' ).isEnabled( 'code-splitting' );
const config = {
presets: [
[
'@babel/env',
{
modules,
targets: {
browsers: [ 'last 2 versions', 'Safari >= 10', 'iOS >= 10', 'ie >= 11' ],
},
exclude: [ 'transform-classes', 'transform-template-literals' ], // transform-classes is added manually later.
useBuiltIns: 'entry',
shippedProposals: true, // allows es7 features like Promise.prototype.finally
},
],
'@babel/react',
],
plugins: _.compact( [
// the two class transforms are to emulate exactly how babel 6 handled classes.
// it very slightly diverges from spec but also is more concise.
// see: http://new.babeljs.io/docs/en/next/v7-migration.html#babel-plugin-proposal-class-properties
[ '@babel/plugin-proposal-class-properties', { loose: true } ],
[ '@babel/plugin-transform-classes', { loose: false } ],
[ '@babel/plugin-transform-template-literals', { loose: true } ],
isCalypso && [
path.join(
__dirname,
'server',
'bundler',
'babel',
'babel-plugin-transform-wpcalypso-async'
),
{ async: isCalypsoClient && codeSplit },
],
'@babel/plugin-proposal-export-default-from',
'@babel/plugin-proposal-export-namespace-from',
'@babel/plugin-syntax-dynamic-import',
[
'@babel/transform-runtime',
{
corejs: false, // we polyfill so we don't need core-js
helpers: true,
regenerator: false,
useESModules: false,
},
],
isCalypsoClient && './inline-imports.js',
] ),
env: {
test: {
presets: [ [ '@babel/env', { targets: { node: 'current' } } ] ],
plugins: [ 'add-module-exports', './server/bundler/babel/babel-lodash-es' ],
},
},
};
module.exports = config;