From 0d3854c6c35e84702f58bfc78b9a91a1440a093d Mon Sep 17 00:00:00 2001 From: Dmitry Rykun Date: Wed, 27 Sep 2023 10:05:33 -0700 Subject: [PATCH] Export Commands and Constants only if native view config interop is enabled (#39696) Summary: Pull Request resolved: https://github.com/facebook/react-native/pull/39696 `Commands` and `Constants` should be set in native only if component data is instantiated via native view config interop layer. Changelog: [Internal] Reviewed By: RSNara Differential Revision: D49684166 fbshipit-source-id: ceaa29c2ed3336aa6e21a116a3f5f94e03c225c1 --- .../react-native/React/Modules/RCTUIManager.m | 7 ++++--- .../React/Views/RCTComponentData.m | 20 ++++++++++--------- 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/packages/react-native/React/Modules/RCTUIManager.m b/packages/react-native/React/Modules/RCTUIManager.m index 14963e7d4a64bf..7027921fda706b 100644 --- a/packages/react-native/React/Modules/RCTUIManager.m +++ b/packages/react-native/React/Modules/RCTUIManager.m @@ -1489,9 +1489,10 @@ static void RCTMeasureLayout(RCTShadowView *view, RCTShadowView *ancestor, RCTRe // lazifyViewManagerConfig function in JS. This fuction uses NativeModules global object that is not available in the // New Architecture. To make native view configs work in the New Architecture we will populate these properties in // native. - moduleConstants[@"Commands"] = viewConfig[@"Commands"]; - moduleConstants[@"Constants"] = viewConfig[@"Constants"]; - + if (RCTGetUseNativeViewConfigsInBridgelessMode()) { + moduleConstants[@"Commands"] = viewConfig[@"Commands"]; + moduleConstants[@"Constants"] = viewConfig[@"Constants"]; + } // Add direct events for (NSString *eventName in viewConfig[@"directEvents"]) { if (!directEvents[eventName]) { diff --git a/packages/react-native/React/Views/RCTComponentData.m b/packages/react-native/React/Views/RCTComponentData.m index 2c627b6cbef573..888cad59b88e27 100644 --- a/packages/react-native/React/Views/RCTComponentData.m +++ b/packages/react-native/React/Views/RCTComponentData.m @@ -480,11 +480,6 @@ - (void)setProps:(NSDictionary *)props forShadowView:(RCTShadowV } } - NSDictionary *commands = [self commandsForViewMangerClass:managerClass - methods:methods - methodCount:count]; - free(methods); - #if RCT_DEBUG for (NSString *event in bubblingEvents) { if ([directEvents containsObject:event]) { @@ -499,15 +494,22 @@ - (void)setProps:(NSDictionary *)props forShadowView:(RCTShadowV Class superClass = [managerClass superclass]; - return @{ + NSMutableDictionary *result = [[NSMutableDictionary alloc] initWithDictionary:@{ @"propTypes" : propTypes, @"directEvents" : directEvents, @"bubblingEvents" : bubblingEvents, @"capturingEvents" : capturingEvents, @"baseModuleName" : superClass == [NSObject class] ? (id)kCFNull : RCTViewManagerModuleNameForClass(superClass), - @"Commands" : commands, - @"Constants" : [self constantsForViewMangerClass:managerClass], - }; + }]; + + if (RCTGetUseNativeViewConfigsInBridgelessMode()) { + result[@"Commands"] = [self commandsForViewMangerClass:managerClass methods:methods methodCount:count]; + result[@"Constants"] = [self constantsForViewMangerClass:managerClass]; + } + + free(methods); + + return result; } - (NSDictionary *)viewConfig