123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- 'use strict';
- const path = require('path');
- const validateBoolOption = (name, value, defaultValue) => {
- if (typeof value === 'undefined') {
- value = defaultValue;
- }
- if (typeof value !== 'boolean') {
- throw new Error(`Preset react-app: '${name}' option must be a boolean.`);
- }
- return value;
- };
- module.exports = function (api, opts, env) {
- if (!opts) {
- opts = {};
- }
- var isEnvDevelopment = env === 'development';
- var isEnvProduction = env === 'production';
- var isEnvTest = env === 'test';
- var useESModules = validateBoolOption(
- 'useESModules',
- opts.useESModules,
- isEnvDevelopment || isEnvProduction
- );
- var isFlowEnabled = validateBoolOption('flow', opts.flow, true);
- var isTypeScriptEnabled = validateBoolOption(
- 'typescript',
- opts.typescript,
- true
- );
- var areHelpersEnabled = validateBoolOption('helpers', opts.helpers, true);
- var useAbsoluteRuntime = validateBoolOption(
- 'absoluteRuntime',
- opts.absoluteRuntime,
- true
- );
- var absoluteRuntimePath = undefined;
- if (useAbsoluteRuntime) {
- absoluteRuntimePath = path.dirname(
- require.resolve('@babel/runtime/package.json')
- );
- }
- if (!isEnvDevelopment && !isEnvProduction && !isEnvTest) {
- throw new Error(
- 'Using `babel-preset-react-app` requires that you specify `NODE_ENV` or ' +
- '`BABEL_ENV` environment variables. Valid values are "development", ' +
- '"test", and "production". Instead, received: ' +
- JSON.stringify(env) +
- '.'
- );
- }
- return {
- presets: [
- isEnvTest && [
-
- require('@babel/preset-env').default,
- {
- targets: {
- node: 'current',
- },
- },
- ],
- (isEnvProduction || isEnvDevelopment) && [
-
- require('@babel/preset-env').default,
- {
-
- useBuiltIns: 'entry',
-
- corejs: 3,
-
- exclude: ['transform-typeof-symbol'],
- },
- ],
- [
- require('@babel/preset-react').default,
- {
-
-
- development: isEnvDevelopment || isEnvTest,
-
-
- ...(opts.runtime !== 'automatic' ? { useBuiltIns: true } : {}),
- runtime: opts.runtime || 'classic',
- },
- ],
- isTypeScriptEnabled && [require('@babel/preset-typescript').default],
- ].filter(Boolean),
- plugins: [
-
-
-
-
-
-
- isFlowEnabled && [
- require('@babel/plugin-transform-flow-strip-types').default,
- false,
- ],
-
-
- require('babel-plugin-macros'),
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- isTypeScriptEnabled && [
- require('@babel/plugin-proposal-decorators').default,
- false,
- ],
-
-
-
- [
- require('@babel/plugin-proposal-class-properties').default,
- {
- loose: true,
- },
- ],
-
- require('@babel/plugin-proposal-numeric-separator').default,
-
-
- [
- require('@babel/plugin-transform-runtime').default,
- {
- corejs: false,
- helpers: areHelpersEnabled,
-
-
-
- version: require('@babel/runtime/package.json').version,
- regenerator: true,
-
-
-
- useESModules,
-
-
-
- absoluteRuntime: absoluteRuntimePath,
- },
- ],
- isEnvProduction && [
-
- require('babel-plugin-transform-react-remove-prop-types').default,
- {
- removeImport: true,
- },
- ],
-
-
-
-
- require('@babel/plugin-proposal-optional-chaining').default,
- require('@babel/plugin-proposal-nullish-coalescing-operator').default,
- ].filter(Boolean),
- overrides: [
- isFlowEnabled && {
- exclude: /\.tsx?$/,
- plugins: [require('@babel/plugin-transform-flow-strip-types').default],
- },
- isTypeScriptEnabled && {
- test: /\.tsx?$/,
- plugins: [
- [
- require('@babel/plugin-proposal-decorators').default,
- { legacy: true },
- ],
- ],
- },
- ].filter(Boolean),
- };
- };
|