1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.reactNativePlatformResolver = reactNativePlatformResolver;
- function _metroResolver() {
- const data = require("metro-resolver");
- _metroResolver = function () {
- return data;
- };
- return data;
- }
- /**
- * This is an implementation of a metro resolveRequest option which will remap react-native imports
- * to different npm packages based on the platform requested. This allows a single metro instance/config
- * to produce bundles for multiple out of tree platforms at a time.
- *
- * @param platformImplementations
- * A map of platform to npm package that implements that platform
- *
- * Ex:
- * {
- * windows: 'react-native-windows'
- * macos: 'react-native-macos'
- * }
- */
- // @ts-ignore - no typed definition for the package
- function reactNativePlatformResolver(platformImplementations) {
- return (context, _realModuleName, platform, moduleName) => {
- let backupResolveRequest = context.resolveRequest;
- delete context.resolveRequest;
- try {
- let modifiedModuleName = moduleName;
- if (platformImplementations[platform]) {
- if (moduleName === 'react-native') {
- modifiedModuleName = platformImplementations[platform];
- } else if (moduleName.startsWith('react-native/')) {
- modifiedModuleName = `${platformImplementations[platform]}/${modifiedModuleName.slice('react-native/'.length)}`;
- }
- }
- let result = (0, _metroResolver().resolve)(context, modifiedModuleName, platform);
- return result;
- } catch (e) {
- throw e;
- } finally {
- context.resolveRequest = backupResolveRequest;
- }
- };
- }
- //# sourceMappingURL=metroPlatformResolver.js.map
|