mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
8fba154b66
Summary: Pull Request resolved: https://github.com/facebook/react-native/pull/46452 `babel-plugin-codegen` transforms `codegenNativeComponent`s by expending it with a whole set of many commands (~40 lines) that don't have a good equivalent on the source file. Currently these lines are pointing to random parts of the due to a bug that causes the source maps to be incorrect and confusing. Instead, I point all these generated lines of code to the default export as the only line that can represent them. This way, if an error is thrown from that generated code it would point to that export. If the users are confused by how it works, there's a comment in the function that is used in the default export in these that explains it: ``` // If this function runs then that means the view configs were not // generated at build time using `GenerateViewConfigJs.js`. Thus // we need to `requireNativeComponent` to get the view configs from view managers. // `requireNativeComponent` is not available in Bridgeless mode. // e.g. This function runs at runtime if `codegenNativeComponent` was not called // from a file suffixed with NativeComponent.js. function codegenNativeComponent<Props>( componentName: string, options?: Options, ): NativeComponentType<Props> { ``` The transformation is from all the types and exports after the imports: [`MyNativeViewNativeComponent` for example](https://github.com/facebook/react-native/blob/773a02ad5d3cc38e0f5837b42ba9a5e05a206bf9/packages/rn-tester/NativeComponentExample/js/MyNativeViewNativeComponent.js#L4) Which is roughly (ignoring all typing): ``` // types and exports export const Commands: NativeCommands = codegenNativeCommands<NativeCommands>({ supportedCommands: [ 'callNativeMethodToChangeBackgroundColor', 'callNativeMethodToAddOverlays', 'callNativeMethodToRemoveOverlays', 'fireLagacyStyleEvent', ], }); export default (codegenNativeComponent<NativeProps>( 'RNTMyNativeView', ): MyNativeViewType); ``` to roughly: ``` var React = require('react'); var nativeComponentName = 'RNTMyNativeView'; var __INTERNAL_VIEW_CONFIG = { uiViewClassName: 'RNTMyNativeView', bubblingEventTypes: { topIntArrayChanged: { /* */ }, topAlternativeLegacyName: { /* */ }, }, validAttributes: { opacity: true, values: true, ...require('ViewConfigIgnore').ConditionallyIgnoredEventHandlers({ onIntArrayChanged: true, onLegacyStyleEvent: true }) } }; var _default = require('NativeComponentRegistry').get(nativeComponentName, () => __INTERNAL_VIEW_CONFIG); var Commands = { callNativeMethodToChangeBackgroundColor(ref, color) { require('RendererProxy').dispatchCommand(ref, "callNativeMethodToChangeBackgroundColor", [color]); }, callNativeMethodToAddOverlays(ref, overlayColors) { require('RendererProxy').dispatchCommand(ref, "callNativeMethodToAddOverlays", [overlayColors]); }, callNativeMethodToRemoveOverlays(ref) { require('RendererProxy').dispatchCommand(ref, "callNativeMethodToRemoveOverlays", []); }, fireLagacyStyleEvent(ref) { require('RendererProxy').dispatchCommand(ref, "fireLagacyStyleEvent", []); } }; exports.default = _default; exports.__INTERNAL_VIEW_CONFIG = __INTERNAL_VIEW_CONFIG; exports.Commands = Commands; ``` Changelog: [Fix] Fixed source maps in Native Components JS files that use codegenNativeComponent Reviewed By: robhogan, huntie Differential Revision: D62443699 fbshipit-source-id: 522b4382736a8fed93a1bc687a78d6885fe7c9d5
@react-native/babel-plugin-codegen
Installation
yarn add --dev @babel/core @react-native/babel-plugin-codegen
Note: We're using yarn to install deps. Feel free to change commands to use npm 3+ and npx if you like
Testing
To run the tests in this package, run the following commands from the React Native root folder:
yarnto install the dependencies. You just need to run this onceyarn jest packages/babel-plugin-codegen.