forked from react-native-webview/react-native-webview
-
Notifications
You must be signed in to change notification settings - Fork 2
/
metro.config.js
57 lines (50 loc) · 1.66 KB
/
metro.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/**
* Metro configuration for React Native
* https://github.com/facebook/react-native
*
* @format
*/
const path = require('path');
const exclusionList = (() => {
try {
return require('metro-config/src/defaults/exclusionList');
} catch (_) {
// `blacklist` was renamed to `exclusionList` in 0.60
return require('metro-config/src/defaults/blacklist');
}
})();
const blockList = exclusionList([
/node_modules\/.*\/node_modules\/react-native\/.*/,
// Workaround for `EPERM: operation not permitted, lstat '~\midl-MIDLRT-cl.read.1.tlog'`
/.*\.tlog/,
// This stops "react-native run-windows" from causing the metro server to
// crash if its already running
new RegExp(`${path.join(__dirname, 'windows').replace(/[/\\]+/g, '/')}.*`),
// Workaround for `EBUSY: resource busy or locked, open '~\msbuild.ProjectImports.zip'`
/.*\.ProjectImports\.zip/,
]);
/**
* This config is a bit exotic because our example app is not its own package
* (that would require setting this repo up as a monorepo). We need to tell
* Metro that the root of the project is our `example` folder (`projectRoot`),
* and that it should look for modules in repo root (`watchFolders`) as this is
* where the `node_modules` folder lives. Metro will otherwise fail to resolve
* anything.
*/
module.exports = {
projectRoot: path.join(__dirname, 'example'),
watchFolders: [__dirname],
resolver: {
resolverMainFields: ['main-internal', 'browser', 'main'],
blacklistRE: blockList,
blockList,
},
transformer: {
getTransformOptions: async () => ({
transform: {
experimentalImportSupport: false,
inlineRequires: false,
},
}),
},
};