1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- module.exports = (api) => {
- const env = api.env();
- const reactOptions = {
- development: false,
- runtime: 'automatic',
- };
- const envOptions = {
- useBuiltIns: "usage",
- corejs: { version: "3.30" },
- debug: false,
- include: [
- 'transform-numeric-separator',
- 'transform-optional-chaining',
- 'transform-nullish-coalescing-operator',
- 'transform-class-properties',
- ],
- };
- const plugins = [
- ['formatjs'],
- 'preval',
- ];
- switch (env) {
- case 'production':
- plugins.push(...[
- 'lodash',
- [
- 'transform-react-remove-prop-types',
- {
- mode: 'remove',
- removeImport: true,
- additionalLibraries: [
- 'react-immutable-proptypes',
- ],
- },
- ],
- '@babel/transform-react-inline-elements',
- [
- '@babel/transform-runtime',
- {
- helpers: true,
- regenerator: false,
- useESModules: true,
- },
- ],
- ]);
- break;
- case 'development':
- reactOptions.development = true;
- envOptions.debug = true;
- // We need Babel to not inject polyfills in dev, as this breaks `preval` files
- envOptions.useBuiltIns = false;
- envOptions.corejs = undefined;
- break;
- }
- const config = {
- presets: [
- '@babel/preset-typescript',
- ['@babel/react', reactOptions],
- ['@babel/env', envOptions],
- ],
- plugins,
- overrides: [
- {
- test: /tesseract\.js/,
- presets: [
- ['@babel/env', { ...envOptions, modules: 'commonjs' }],
- ],
- },
- ],
- };
- return config;
- };
|