2018-12-02 18:30:00 +01:00
|
|
|
import {PluginItem} from '@babel/core'
|
|
|
|
const env = process.env.NODE_ENV
|
|
|
|
const isProduction = env === 'production'
|
|
|
|
const isDevelopment = env === 'development'
|
|
|
|
const isTest = env === 'test'
|
|
|
|
|
|
|
|
type StyledJsxPlugin = [string, any] | string
|
|
|
|
type StyledJsxBabelOptions = {
|
|
|
|
plugins?: StyledJsxPlugin[]
|
|
|
|
} | undefined
|
|
|
|
|
|
|
|
// Resolve styled-jsx plugins
|
|
|
|
function styledJsxOptions (options: StyledJsxBabelOptions) {
|
|
|
|
if (!options) {
|
|
|
|
return {}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!Array.isArray(options.plugins)) {
|
|
|
|
return options
|
|
|
|
}
|
|
|
|
|
|
|
|
options.plugins = options.plugins.map((plugin: StyledJsxPlugin): StyledJsxPlugin => {
|
|
|
|
if (Array.isArray(plugin)) {
|
|
|
|
const [name, options] = plugin
|
|
|
|
return [
|
|
|
|
require.resolve(name),
|
|
|
|
options
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
return require.resolve(plugin)
|
|
|
|
})
|
|
|
|
|
|
|
|
return options
|
|
|
|
}
|
|
|
|
|
|
|
|
type NextBabelPresetOptions = {
|
|
|
|
'preset-env'?: any,
|
|
|
|
'preset-react'?: any,
|
|
|
|
'class-properties'?: any,
|
|
|
|
'transform-runtime'?: any,
|
|
|
|
'styled-jsx'?: StyledJsxBabelOptions
|
|
|
|
}
|
|
|
|
|
|
|
|
type BabelPreset = {
|
|
|
|
presets?: PluginItem[] | null,
|
|
|
|
plugins?: PluginItem[] | null
|
|
|
|
}
|
|
|
|
|
2019-03-05 16:57:07 +01:00
|
|
|
// Taken from https://github.com/babel/babel/commit/d60c5e1736543a6eac4b549553e107a9ba967051#diff-b4beead8ad9195361b4537601cc22532R158
|
|
|
|
function supportsStaticESM(caller: any) {
|
|
|
|
return !!(caller && caller.supportsStaticESM);
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = (api: any, options: NextBabelPresetOptions = {}): BabelPreset => {
|
|
|
|
const supportsESM = api.caller(supportsStaticESM)
|
2018-12-04 20:10:05 +01:00
|
|
|
const presetEnvConfig = {
|
|
|
|
// In the test environment `modules` is often needed to be set to true, babel figures that out by itself using the `'auto'` option
|
|
|
|
// In production/development this option is set to `false` so that webpack can handle import/export with tree-shaking
|
2019-03-05 16:57:07 +01:00
|
|
|
modules: 'auto',
|
2018-12-04 20:10:05 +01:00
|
|
|
...options['preset-env']
|
|
|
|
}
|
2018-12-02 18:30:00 +01:00
|
|
|
return {
|
|
|
|
presets: [
|
2018-12-04 20:10:05 +01:00
|
|
|
[require('@babel/preset-env').default, presetEnvConfig],
|
2018-12-02 18:30:00 +01:00
|
|
|
[require('@babel/preset-react'), {
|
|
|
|
// This adds @babel/plugin-transform-react-jsx-source and
|
|
|
|
// @babel/plugin-transform-react-jsx-self automatically in development
|
|
|
|
development: isDevelopment || isTest,
|
|
|
|
...options['preset-react']
|
|
|
|
}]
|
|
|
|
],
|
|
|
|
plugins: [
|
|
|
|
require('babel-plugin-react-require'),
|
|
|
|
require('@babel/plugin-syntax-dynamic-import'),
|
2019-03-30 01:50:24 +01:00
|
|
|
// Transform dynamic import to require
|
|
|
|
isTest && require('babel-plugin-dynamic-import-node'),
|
2018-12-02 18:30:00 +01:00
|
|
|
require('./plugins/react-loadable-plugin'),
|
|
|
|
[require('@babel/plugin-proposal-class-properties'), options['class-properties'] || {}],
|
|
|
|
require('@babel/plugin-proposal-object-rest-spread'),
|
|
|
|
[require('@babel/plugin-transform-runtime'), {
|
|
|
|
corejs: 2,
|
|
|
|
helpers: true,
|
|
|
|
regenerator: true,
|
2019-03-05 16:57:07 +01:00
|
|
|
useESModules: supportsESM && presetEnvConfig.modules !== 'commonjs',
|
2018-12-02 18:30:00 +01:00
|
|
|
...options['transform-runtime']
|
|
|
|
}],
|
|
|
|
[require('styled-jsx/babel'), styledJsxOptions(options['styled-jsx'])],
|
2019-02-28 23:04:29 +01:00
|
|
|
require('./plugins/amp-attributes'),
|
2019-03-27 12:26:01 +01:00
|
|
|
isProduction && [require('babel-plugin-transform-react-remove-prop-types'), {
|
|
|
|
removeImport: true
|
|
|
|
}]
|
2018-12-02 18:30:00 +01:00
|
|
|
].filter(Boolean)
|
|
|
|
}
|
|
|
|
}
|