-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbabel.config.js
106 lines (96 loc) · 3.28 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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
'use strict';
// * Every now and then, we adopt best practices from CRA
// * https://tinyurl.com/yakv4ggx
// TODO: replace with 'package'
const pkgName = require('./package.json').name;
const debug = require('debug')(`${pkgName}:babel-config`);
debug('NODE_ENV: %O', process.env.NODE_ENV);
// ! This is pretty aggressive. It targets modern browsers only.
// ? For some projects, less aggressive targets will make much more
// ? sense!
const browserTargets =
'Chrome >= 60, Safari >= 10.1, iOS >= 10.3, Firefox >= 54, Edge >= 15';
// ? Something like the following might be more appropriate:
//const targets = '>1% in US and not ie 11';
// ? Next.js-specific Babel settings
const nextBabelPresetAndConfig = [
'next/babel',
{
'preset-env': {
targets: browserTargets,
// ? If users import all core-js they're probably not concerned with
// ? bundle size. We shouldn't rely on magic to try and shrink it.
useBuiltIns: false,
// ? Do not transform modules to CJS
// ! MUST BE FALSE (see: https://nextjs.org/docs/#customizing-babel-config)
modules: false,
// ? Exclude transforms that make all code slower
exclude: ['transform-typeof-symbol']
},
'preset-typescript': {
allowDeclareFields: true
}
}
];
/**
* @type {import('@babel/core').TransformOptions}
*/
module.exports = {
comments: false,
parserOpts: { strictMode: true },
plugins: [
'@babel/plugin-proposal-export-default-from',
'@babel/plugin-syntax-import-assertions'
// ? Interoperable named CJS imports for free
// [
// 'transform-default-named-imports',
// {
// exclude: [/^next([/?#].+)?/, /^mongodb([/?#].+)?/]
// }
// ]
],
// ? Sub-keys under the "env" config key will augment the above
// ? configuration depending on the value of NODE_ENV and friends. Default
// ? is: development
env: {
// * Used by Jest and `npm test`
test: {
comments: true,
sourceMaps: 'both',
presets: [
['@babel/preset-env', { targets: { node: true } }],
'@babel/preset-react',
['@babel/preset-typescript', { allowDeclareFields: true }]
// ? We don't care about minification
],
plugins: [
// ? Only active when testing, the plugin solves the following problem:
// ? https://stackoverflow.com/q/40771520/1367414
'explicit-exports-references'
]
},
// * Used by Vercel, `npm start`, and `npm run build`
production: {
// ? Source maps are handled by Next.js and Webpack
presets: [nextBabelPresetAndConfig]
// ? Minification is handled by Webpack
},
// * Used by `npm run dev`; is also the default environment
development: {
// ? Source maps are handled by Next.js and Webpack
presets: [nextBabelPresetAndConfig],
// ? https://reactjs.org/docs/error-boundaries.html#how-about-event-handlers
plugins: ['@babel/plugin-transform-react-jsx-source']
// ? We don't care about minification
},
// * Used by `npm run build-externals`
external: {
presets: [
['@babel/preset-env', { targets: { node: true } }],
['@babel/preset-typescript', { allowDeclareFields: true }]
// ? Minification is handled by Webpack
]
}
}
};
debug('exports: %O', module.exports);