fix: example apps metro paths (#2511)

# Summary

Fixes paths in Metro config
This commit is contained in:
Jakub Grzywacz
2024-10-25 19:27:23 +02:00
committed by GitHub
parent 8be900eee3
commit cc527dfd49
7 changed files with 28 additions and 34 deletions
+3 -6
View File
@@ -2,19 +2,16 @@ const { getDefaultConfig, mergeConfig } = require('@react-native/metro-config');
/** /**
* Metro configuration * Metro configuration
* https://facebook.github.io/metro/docs/configuration * https://reactnative.dev/docs/metro
* *
* @type {import('metro-config').MetroConfig} * @type {import('metro-config').MetroConfig}
*/ */
/* eslint-disable import/no-commonjs */
const path = require('path'); const path = require('path');
const exclusionList = require('metro-config/src/defaults/exclusionList'); const exclusionList = require('metro-config/src/defaults/exclusionList');
const escape = require('escape-string-regexp'); const escape = require('escape-string-regexp');
const pack = require('../package.json'); const pack = require('../../package.json');
const root = path.resolve(__dirname, '..'); const root = path.resolve(__dirname, '../..');
const projectNodeModules = path.join(__dirname, 'node_modules'); const projectNodeModules = path.join(__dirname, 'node_modules');
const modules = [...Object.keys(pack.peerDependencies)]; const modules = [...Object.keys(pack.peerDependencies)];
+2 -2
View File
@@ -9,9 +9,9 @@ const {getDefaultConfig, mergeConfig} = require('@react-native/metro-config');
const path = require('path'); const path = require('path');
const exclusionList = require('metro-config/src/defaults/exclusionList'); const exclusionList = require('metro-config/src/defaults/exclusionList');
const pack = require('../package.json'); const pack = require('../../package.json');
const root = path.resolve(__dirname, '..'); const root = path.resolve(__dirname, '../..');
const projectNodeModules = path.join(__dirname, 'node_modules'); const projectNodeModules = path.join(__dirname, 'node_modules');
const modules = [...Object.keys(pack.peerDependencies), 'react-native-macos']; const modules = [...Object.keys(pack.peerDependencies), 'react-native-macos'];
+9 -8
View File
@@ -1,4 +1,4 @@
const { getDefaultConfig, mergeConfig } = require('@react-native/metro-config'); const {getDefaultConfig, mergeConfig} = require('@react-native/metro-config');
/** /**
* Metro configuration * Metro configuration
@@ -9,14 +9,14 @@ const { getDefaultConfig, mergeConfig } = require('@react-native/metro-config');
const path = require('path'); const path = require('path');
const exclusionList = require('metro-config/src/defaults/exclusionList'); const exclusionList = require('metro-config/src/defaults/exclusionList');
const escape = require('escape-string-regexp'); const escape = require('escape-string-regexp');
const pack = require('../package.json'); const pack = require('../../package.json');
const root = path.resolve(__dirname, '..'); const root = path.resolve(__dirname, '../..');
const projectNodeModules = path.join(__dirname, 'node_modules'); const projectNodeModules = path.join(__dirname, 'node_modules');
const fs = require('fs'); const fs = require('fs');
const rnwPath = fs.realpathSync( const rnwPath = fs.realpathSync(
path.resolve(require.resolve('react-native-windows/package.json'), '..') path.resolve(require.resolve('react-native-windows/package.json'), '..'),
); );
const modules = [...Object.keys(pack.peerDependencies), 'react-native-windows']; const modules = [...Object.keys(pack.peerDependencies), 'react-native-windows'];
@@ -30,16 +30,17 @@ const config = {
resolver: { resolver: {
blockList: exclusionList( blockList: exclusionList(
modules.map( modules.map(
(m) => m => new RegExp(`^${escape(path.join(root, 'node_modules', m))}\\/.*$`),
new RegExp(`^${escape(path.join(root, 'node_modules', m))}\\/.*$`)
), ),
// This stops "react-native run-windows" from causing the metro server to // This stops "react-native run-windows" from causing the metro server to
// crash if its already running // crash if its already running
new RegExp(`${path.join(__dirname, 'windows').replace(/[/\\]+/g, '/')}.*`), new RegExp(
`${path.join(__dirname, 'windows').replace(/[/\\]+/g, '/')}.*`,
),
// This prevents "react-native run-windows" from hitting: EBUSY: resource busy or locked, open msbuild.ProjectImports.zip or other files produced by msbuild // This prevents "react-native run-windows" from hitting: EBUSY: resource busy or locked, open msbuild.ProjectImports.zip or other files produced by msbuild
new RegExp(`${rnwPath}/build/.*`), new RegExp(`${rnwPath}/build/.*`),
new RegExp(`${rnwPath}/target/.*`), new RegExp(`${rnwPath}/target/.*`),
/.*\.ProjectImports\.zip/ /.*\.ProjectImports\.zip/,
), ),
nodeModulesPaths: [projectNodeModules, path.join(__dirname, '../../')], nodeModulesPaths: [projectNodeModules, path.join(__dirname, '../../')],
extraNodeModules: modules.reduce((acc, name) => { extraNodeModules: modules.reduce((acc, name) => {
+1 -1
View File
@@ -11,7 +11,7 @@ const exclusionList = require('metro-config/src/defaults/exclusionList');
const pack = require('../../package.json'); const pack = require('../../package.json');
const root = path.resolve(__dirname, '..'); const root = path.resolve(__dirname, '../..');
const projectNodeModules = path.join(__dirname, 'node_modules'); const projectNodeModules = path.join(__dirname, 'node_modules');
const modules = [...Object.keys(pack.peerDependencies), 'react-native-macos']; const modules = [...Object.keys(pack.peerDependencies), 'react-native-macos'];
+2 -2
View File
@@ -9,9 +9,9 @@ const { getDefaultConfig, mergeConfig } = require('@react-native/metro-config');
const path = require('path'); const path = require('path');
const exclusionList = require('metro-config/src/defaults/exclusionList'); const exclusionList = require('metro-config/src/defaults/exclusionList');
const escape = require('escape-string-regexp'); const escape = require('escape-string-regexp');
const pack = require('../package.json'); const pack = require('../../package.json');
const root = path.resolve(__dirname, '..'); const root = path.resolve(__dirname, '../..');
const projectNodeModules = path.join(__dirname, 'node_modules'); const projectNodeModules = path.join(__dirname, 'node_modules');
const fs = require('fs'); const fs = require('fs');
+7 -11
View File
@@ -6,14 +6,12 @@ const { getDefaultConfig, mergeConfig } = require('@react-native/metro-config');
* *
* @type {import('metro-config').MetroConfig} * @type {import('metro-config').MetroConfig}
*/ */
/* eslint-disable import/no-commonjs */
const path = require('path'); const path = require('path');
const exclusionList = require('metro-config/src/defaults/exclusionList'); const exclusionList = require('metro-config/src/defaults/exclusionList');
const escape = require('escape-string-regexp'); const escape = require('escape-string-regexp');
const pack = require('../package.json'); const pack = require('../../package.json');
const root = path.resolve(__dirname, '..'); const root = path.resolve(__dirname, '../..');
const projectNodeModules = path.join(__dirname, 'node_modules'); const projectNodeModules = path.join(__dirname, 'node_modules');
const modules = [...Object.keys(pack.peerDependencies)]; const modules = [...Object.keys(pack.peerDependencies)];
@@ -32,19 +30,17 @@ const config = {
) )
), ),
nodeModulesPaths: [projectNodeModules, path.join(__dirname, '../../')], nodeModulesPaths: [projectNodeModules, path.join(__dirname, '../../')],
extraNodeModules: modules.reduce( extraNodeModules: modules.reduce((acc, name) => {
(acc, name) => { acc[name] = path.join(__dirname, 'node_modules', name);
acc[name] = path.join(__dirname, 'node_modules', name); return acc;
return acc; }, {}),
},
{ 'react-native-svg': `${__dirname}/../` }
),
}, },
transformer: { transformer: {
getTransformOptions: async () => ({ getTransformOptions: async () => ({
transform: { transform: {
experimentalImportSupport: false, experimentalImportSupport: false,
inlineRequires: true,
}, },
}), }),
}, },
+4 -4
View File
@@ -9,16 +9,16 @@ const config = getDefaultConfig(__dirname);
// excludes the one from the parent folder when bundling. // excludes the one from the parent folder when bundling.
config.resolver.blockList = [ config.resolver.blockList = [
...Array.from(config.resolver.blockList ?? []), ...Array.from(config.resolver.blockList ?? []),
new RegExp(path.resolve('..', 'node_modules', 'react-native')), new RegExp(path.resolve('../..', 'node_modules', 'react-native')),
new RegExp(path.resolve('..', 'node_modules', 'react')), new RegExp(path.resolve('../..', 'node_modules', 'react')),
]; ];
config.resolver.nodeModulesPaths = [ config.resolver.nodeModulesPaths = [
path.resolve(__dirname, './node_modules'), path.resolve(__dirname, './node_modules'),
path.resolve(__dirname, '../node_modules'), path.resolve(__dirname, '../../node_modules'),
]; ];
config.watchFolders = [path.resolve(__dirname, '..')]; config.watchFolders = [path.resolve(__dirname, '../..')];
config.transformer.getTransformOptions = async () => ({ config.transformer.getTransformOptions = async () => ({
transform: { transform: {