metroPlatformResolver.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.reactNativePlatformResolver = reactNativePlatformResolver;
  6. function _metroResolver() {
  7. const data = require("metro-resolver");
  8. _metroResolver = function () {
  9. return data;
  10. };
  11. return data;
  12. }
  13. /**
  14. * This is an implementation of a metro resolveRequest option which will remap react-native imports
  15. * to different npm packages based on the platform requested. This allows a single metro instance/config
  16. * to produce bundles for multiple out of tree platforms at a time.
  17. *
  18. * @param platformImplementations
  19. * A map of platform to npm package that implements that platform
  20. *
  21. * Ex:
  22. * {
  23. * windows: 'react-native-windows'
  24. * macos: 'react-native-macos'
  25. * }
  26. */
  27. // @ts-ignore - no typed definition for the package
  28. function reactNativePlatformResolver(platformImplementations) {
  29. return (context, _realModuleName, platform, moduleName) => {
  30. let backupResolveRequest = context.resolveRequest;
  31. delete context.resolveRequest;
  32. try {
  33. let modifiedModuleName = moduleName;
  34. if (platformImplementations[platform]) {
  35. if (moduleName === 'react-native') {
  36. modifiedModuleName = platformImplementations[platform];
  37. } else if (moduleName.startsWith('react-native/')) {
  38. modifiedModuleName = `${platformImplementations[platform]}/${modifiedModuleName.slice('react-native/'.length)}`;
  39. }
  40. }
  41. let result = (0, _metroResolver().resolve)(context, modifiedModuleName, platform);
  42. return result;
  43. } catch (e) {
  44. throw e;
  45. } finally {
  46. context.resolveRequest = backupResolveRequest;
  47. }
  48. };
  49. }
  50. //# sourceMappingURL=metroPlatformResolver.js.map