Let Metro handle import/export instead of Babel (#1772)
* Let Metro handle import/export instead of Babel * Keep using Babel for ESM->CJS in testszio/stable
parent
6c11c0b81d
commit
84ee64025f
|
@ -1,11 +1,17 @@
|
||||||
module.exports = function (api) {
|
module.exports = function (api) {
|
||||||
api.cache(true)
|
api.cache(true)
|
||||||
|
const isTestEnv = process.env.NODE_ENV === 'test'
|
||||||
return {
|
return {
|
||||||
presets: [
|
presets: [
|
||||||
[
|
[
|
||||||
'babel-preset-expo',
|
'babel-preset-expo',
|
||||||
{
|
{
|
||||||
lazyImports: true,
|
lazyImports: true,
|
||||||
|
native: {
|
||||||
|
// Disable ESM -> CJS compilation because Metro takes care of it.
|
||||||
|
// However, we need it in Jest tests since those run without Metro.
|
||||||
|
disableImportExportTransform: !isTestEnv,
|
||||||
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
|
|
|
@ -8,7 +8,17 @@ cfg.resolver.sourceExts = process.env.RN_SRC_EXT
|
||||||
|
|
||||||
cfg.transformer.getTransformOptions = async () => ({
|
cfg.transformer.getTransformOptions = async () => ({
|
||||||
transform: {
|
transform: {
|
||||||
|
experimentalImportSupport: true,
|
||||||
inlineRequires: true,
|
inlineRequires: true,
|
||||||
|
nonInlinedRequires: [
|
||||||
|
// We can remove this option and rely on the default after
|
||||||
|
// https://github.com/facebook/metro/pull/1126 is released.
|
||||||
|
'React',
|
||||||
|
'react',
|
||||||
|
'react/jsx-dev-runtime',
|
||||||
|
'react/jsx-runtime',
|
||||||
|
'react-native',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue