12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- /* eslint-env node */
- import {TransformOptions} from '@babel/core';
- const config: TransformOptions = {
- presets: [
- [
- '@babel/preset-react',
- {
- runtime: 'automatic',
- importSource: '@emotion/react',
- },
- ],
- [
- '@babel/preset-env',
- {
- useBuiltIns: 'usage',
- corejs: '3.22',
- },
- ],
- '@babel/preset-typescript',
- ],
- overrides: [
- {
- test: ['./docs-ui'],
- presets: [
- [
- '@babel/preset-react',
- {
- runtime: 'automatic',
- },
- ],
- ],
- },
- ],
- plugins: [
- '@emotion/babel-plugin',
- '@babel/plugin-transform-runtime',
- // NOTE: The order of the decorator and class-property plugins is important
- // here. Decorators must be processed first before class properties, see:
- // https://babeljs.io/docs/en/plugins#plugin-ordering
- ['@babel/plugin-proposal-decorators', {legacy: true}],
- '@babel/plugin-proposal-class-properties',
- ],
- env: {
- production: {
- plugins: [
- [
- 'transform-react-remove-prop-types',
- {
- mode: 'remove', // remove from bundle
- removeImport: true, // removes `prop-types` import statements
- classNameMatchers: [
- 'SelectField',
- 'FormField',
- 'AsyncComponent',
- 'AsyncView',
- ],
- additionalLibraries: [/app\/sentryTypes$/],
- },
- ],
- ['babel-plugin-add-react-displayname'],
- ],
- },
- development: {
- plugins: [
- '@emotion/babel-plugin',
- '@babel/plugin-transform-react-jsx-source',
- ...(process.env.SENTRY_UI_HOT_RELOAD ? ['react-refresh/babel'] : []),
- ],
- },
- test: {
- // Required, see https://github.com/facebook/jest/issues/9430
- plugins: ['dynamic-import-node'],
- },
- },
- };
- export default config;
|