react-native-tvos 0.83.1-1 → 0.84.0-0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Libraries/Animated/AnimatedEvent.js +2 -2
- package/Libraries/Animated/animations/Animation.js +1 -3
- package/Libraries/Animated/createAnimatedComponent.js +8 -5
- package/Libraries/Animated/nodes/AnimatedColor.js +1 -1
- package/Libraries/Animated/nodes/AnimatedInterpolation.js +40 -4
- package/Libraries/Animated/nodes/AnimatedNode.js +3 -3
- package/Libraries/Animated/nodes/AnimatedObject.js +16 -11
- package/Libraries/Animated/nodes/AnimatedProps.js +43 -12
- package/Libraries/Animated/nodes/AnimatedStyle.js +12 -12
- package/Libraries/Animated/nodes/AnimatedValue.js +6 -3
- package/Libraries/Animated/nodes/AnimatedValueXY.js +1 -1
- package/Libraries/AppDelegate/RCTReactNativeFactory.h +3 -0
- package/Libraries/AppDelegate/RCTReactNativeFactory.mm +33 -31
- package/Libraries/AppDelegate/RCTRootViewFactory.h +10 -4
- package/Libraries/AppDelegate/RCTRootViewFactory.mm +21 -5
- package/Libraries/BatchedBridge/MessageQueue.js +24 -22
- package/Libraries/Blob/RCTBlobPlugins.mm +14 -14
- package/Libraries/Blob/URL.js +34 -3
- package/Libraries/Blob/URLSearchParams.js +1 -0
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +9 -1
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +6 -1
- package/Libraries/Components/Button.js +2 -5
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +1 -1
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroidTypes.js +4 -4
- package/Libraries/Components/Keyboard/Keyboard.js +2 -2
- package/Libraries/Components/Pressable/Pressable.js +8 -8
- package/Libraries/Components/TextInput/TextInput.flow.js +13 -13
- package/Libraries/Components/TextInput/TextInput.js +33 -34
- package/Libraries/Components/Touchable/PooledClass.js +2 -2
- package/Libraries/Components/Touchable/TouchableBounce.js +6 -6
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +1 -1
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +9 -9
- package/Libraries/Components/View/ViewPropTypes.js +16 -6
- package/Libraries/Core/Devtools/loadBundleFromServer.js +6 -3
- package/Libraries/Core/Devtools/symbolicateStackTrace.js +1 -1
- package/Libraries/Core/ExceptionsManager.js +3 -3
- package/Libraries/Core/RawEventEmitter.js +1 -1
- package/Libraries/Core/ReactFiberErrorDialog.js +1 -1
- package/Libraries/Core/ReactNativeVersion.js +3 -3
- package/Libraries/Core/setUpDeveloperTools.js +1 -1
- package/Libraries/Core/setUpErrorHandling.js +1 -1
- package/Libraries/EventEmitter/NativeEventEmitter.js +2 -2
- package/Libraries/Image/Image.android.js +2 -2
- package/Libraries/Image/Image.ios.js +2 -2
- package/Libraries/Image/ImageProps.js +1 -1
- package/Libraries/Image/ImageTypes.flow.js +2 -2
- package/Libraries/Image/RCTImagePlugins.h +1 -0
- package/Libraries/Image/RCTImagePlugins.mm +30 -17
- package/Libraries/Interaction/InteractionManager.js +3 -3
- package/Libraries/Interaction/PanResponder.js +1 -1
- package/Libraries/LayoutAnimation/LayoutAnimation.js +1 -1
- package/Libraries/Linking/Linking.js +1 -1
- package/Libraries/LinkingIOS/RCTLinkingPlugins.mm +10 -13
- package/Libraries/Lists/FlatList.js +2 -2
- package/Libraries/LogBox/Data/LogBoxData.js +31 -4
- package/Libraries/LogBox/Data/LogBoxLog.js +2 -2
- package/Libraries/LogBox/Data/LogBoxSymbolication.js +1 -1
- package/Libraries/LogBox/Data/parseLogBoxLog.js +5 -5
- package/Libraries/LogBox/LogBox.js +7 -7
- package/Libraries/NativeAnimation/RCTAnimationPlugins.mm +14 -14
- package/Libraries/NativeAnimation/RCTNativeAnimatedTurboModule.mm +7 -0
- package/Libraries/NativeAnimation/React-RCTAnimation.podspec +1 -0
- package/Libraries/NativeComponent/BaseViewConfig.android.js +12 -0
- package/Libraries/NativeComponent/StaticViewConfigValidator.js +4 -4
- package/Libraries/NativeComponent/ViewConfigIgnore.js +1 -1
- package/Libraries/Network/RCTInspectorNetworkReporter.mm +26 -3
- package/Libraries/Network/RCTNetworkPlugins.mm +22 -16
- package/Libraries/Network/RCTNetworking.android.js +3 -3
- package/Libraries/Network/RCTNetworking.ios.js +2 -2
- package/Libraries/Network/RCTNetworking.js.flow +2 -2
- package/Libraries/Pressability/Pressability.js +9 -9
- package/Libraries/PushNotificationIOS/RCTPushNotificationPlugins.mm +10 -13
- package/Libraries/ReactNative/AppRegistry.flow.js +1 -1
- package/Libraries/ReactNative/BridgelessUIManager.js +1 -1
- package/Libraries/ReactNative/FabricUIManager.js +1 -1
- package/Libraries/ReactNative/PaperUIManager.js +1 -1
- package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricPublicInstance.js +1 -1
- package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricPublicInstanceUtils.js +2 -2
- package/Libraries/ReactNative/ReactFabricPublicInstance/ReactNativeAttributePayload.js +1 -1
- package/Libraries/ReactNative/RendererImplementation.js +1 -1
- package/Libraries/ReactNative/getNativeComponentAttributes.js +1 -1
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +1 -2
- package/Libraries/Renderer/implementations/ReactFabric-dev.js +3 -3
- package/Libraries/Renderer/implementations/ReactFabric-prod.js +3 -3
- package/Libraries/Renderer/implementations/ReactFabric-profiling.js +3 -3
- package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +11 -4
- package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +11 -4
- package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +11 -4
- package/Libraries/Renderer/shims/ReactFabric.js +3 -1
- package/Libraries/Renderer/shims/ReactFeatureFlags.js +3 -1
- package/Libraries/Renderer/shims/ReactNative.js +2 -2
- package/Libraries/Renderer/shims/ReactNativeTypes.js +3 -1
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +3 -1
- package/Libraries/Renderer/shims/createReactNativeComponentClass.js +3 -1
- package/Libraries/Settings/RCTSettingsManager.mm +1 -1
- package/Libraries/Settings/RCTSettingsPlugins.mm +10 -13
- package/Libraries/Settings/Settings.ios.js +1 -1
- package/Libraries/StyleSheet/PlatformColorValueTypes.android.js +2 -2
- package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +1 -1
- package/Libraries/StyleSheet/PlatformColorValueTypes.js.flow +4 -2
- package/Libraries/StyleSheet/StyleSheetExports.js +1 -1
- package/Libraries/StyleSheet/StyleSheetTypes.d.ts +99 -4
- package/Libraries/StyleSheet/StyleSheetTypes.js +6 -8
- package/Libraries/StyleSheet/processFilter.js +1 -1
- package/Libraries/Text/Text.js +46 -6
- package/Libraries/Text/TextInput/RCTBaseTextInputView.mm +3 -2
- package/Libraries/Text/TextNativeComponent.js +1 -1
- package/Libraries/Text/TextProps.js +7 -7
- package/Libraries/TypeSafety/RCTTypedModuleConstants.h +36 -1
- package/Libraries/Types/CodegenTypes.js +1 -1
- package/Libraries/Types/CoreEventTypes.js +31 -0
- package/Libraries/Types/ReactDevToolsTypes.js +2 -2
- package/Libraries/Utilities/Appearance.js +2 -2
- package/Libraries/Utilities/DevLoadingView.js +8 -1
- package/Libraries/Utilities/DevSettings.js +3 -3
- package/Libraries/Utilities/HMRClient.js +4 -3
- package/Libraries/Utilities/RCTLog.js +3 -3
- package/Libraries/Utilities/ReactNativeTestTools.js +1 -1
- package/Libraries/Utilities/SceneTracker.js +1 -1
- package/Libraries/Utilities/codegenNativeCommands.js +1 -1
- package/Libraries/Utilities/deepFreezeAndThrowOnMutationInDev.js +3 -3
- package/Libraries/Utilities/logError.js +1 -1
- package/Libraries/Utilities/stringifySafe.js +7 -7
- package/Libraries/Utilities/useRefEffect.js +1 -1
- package/Libraries/Vibration/RCTVibrationPlugins.mm +10 -13
- package/Libraries/WebSocket/WebSocketInterceptor.js +3 -3
- package/Libraries/promiseRejectionTrackingOptions.js +8 -8
- package/Libraries/vendor/core/ErrorUtils.js +10 -10
- package/Libraries/vendor/emitter/EventEmitter.js +6 -6
- package/README.md +56 -18
- package/React/Base/RCTAssert.m +2 -2
- package/React/Base/RCTBridge.h +0 -4
- package/React/Base/RCTBridge.mm +1 -12
- package/React/Base/RCTBundleManager.h +59 -7
- package/React/Base/RCTBundleManager.m +112 -1
- package/React/Base/RCTBundleURLProvider.h +24 -0
- package/React/Base/RCTBundleURLProvider.mm +49 -4
- package/React/Base/RCTConvert.mm +2 -0
- package/React/Base/RCTModuleData.mm +2 -2
- package/React/Base/RCTUtils.h +4 -0
- package/React/Base/RCTUtils.mm +60 -3
- package/React/Base/RCTVersion.m +3 -3
- package/React/CoreModules/CoreModulesPlugins.mm +97 -35
- package/React/CoreModules/PlatformStubs/RCTStatusBarManager.mm +1 -1
- package/React/CoreModules/RCTAccessibilityManager.mm +18 -1
- package/React/CoreModules/RCTAppState.mm +1 -1
- package/React/CoreModules/RCTDevLoadingView.mm +116 -36
- package/React/CoreModules/RCTDevSettings.h +36 -1
- package/React/CoreModules/RCTDevSettings.mm +44 -8
- package/React/CoreModules/RCTExceptionsManager.mm +5 -2
- package/React/CoreModules/RCTPlatform.mm +3 -2
- package/React/CoreModules/RCTStatusBarManager.mm +1 -1
- package/React/CxxBridge/RCTCxxBridge.mm +1 -2
- package/React/CxxModule/RCTCxxMethod.mm +1 -1
- package/React/CxxModule/RCTCxxUtils.mm +2 -12
- package/React/DevSupport/RCTDevLoadingViewProtocol.h +4 -1
- package/React/DevSupport/RCTPackagerConnection.h +4 -2
- package/React/DevSupport/RCTPackagerConnection.mm +30 -33
- package/React/FBReactNativeSpec/FBReactNativeSpec/FBReactNativeSpec-generated.mm +9 -2
- package/React/FBReactNativeSpec/FBReactNativeSpec/FBReactNativeSpec.h +62 -17
- package/React/FBReactNativeSpec/FBReactNativeSpecJSI.h +529 -494
- package/React/FBReactNativeSpec/react/renderer/components/FBReactNativeSpec/EventEmitters.h +1 -0
- package/React/FBReactNativeSpec/react/renderer/components/FBReactNativeSpec/Props.h +14 -0
- package/React/Fabric/Mounting/ComponentViews/LegacyViewManagerInterop/RCTLegacyViewManagerInteropComponentView.mm +11 -0
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTEnhancedScrollView.mm +6 -0
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTScrollViewComponentView.mm +2 -0
- package/React/Fabric/Mounting/ComponentViews/View/RCTViewComponentView.mm +39 -2
- package/React/Fabric/Mounting/ComponentViews/VirtualView/RCTVirtualViewComponentView.mm +5 -7
- package/React/Fabric/Mounting/ComponentViews/VirtualViewExperimental/RCTVirtualViewExperimentalComponentView.mm +5 -7
- package/React/Fabric/RCTSurfaceTouchHandler.mm +1 -1
- package/React/Fabric/Surface/RCTFabricSurface.mm +1 -1
- package/React/Inspector/RCTCxxInspectorWebSocketAdapter.mm +6 -2
- package/React/Modules/RCTEventEmitter.m +1 -0
- package/React/Views/RCTModalHostView.h +2 -0
- package/React/Views/RCTTVView.m +2 -0
- package/ReactAndroid/api/ReactAndroid.api +14 -73
- package/ReactAndroid/build.gradle.kts +2 -0
- package/ReactAndroid/gradle.properties +1 -1
- package/ReactAndroid/hermes-engine/build.gradle.kts +97 -29
- package/ReactAndroid/src/main/java/com/facebook/react/NativeModuleRegistryBuilder.kt +1 -4
- package/ReactAndroid/src/main/java/com/facebook/react/ReactActivity.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/ReactDelegate.kt +10 -13
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManager.java +1 -119
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManagerBuilder.kt +0 -10
- package/ReactAndroid/src/main/java/com/facebook/react/ReactPackageHelper.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/ReactPackageTurboModuleManagerDelegate.kt +4 -29
- package/ReactAndroid/src/main/java/com/facebook/react/ReactRootView.java +43 -2
- package/ReactAndroid/src/main/java/com/facebook/react/ViewManagerOnDemandReactPackage.kt +53 -4
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CatalystInstance.kt +0 -18
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CatalystInstanceImpl.java +6 -96
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JavaMethodWrapper.kt +17 -2
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ModuleHolder.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/NativeModuleRegistry.kt +1 -33
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/Promise.kt +6 -6
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/PromiseImpl.kt +6 -6
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReadableNativeArray.kt +1 -12
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/BridgelessDevSupportManager.kt +4 -5
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/ChangeBundleLocationDialog.kt +11 -10
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/CxxInspectorPackagerConnection.kt +99 -9
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DefaultDevLoadingViewImplementation.kt +58 -13
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DefaultDevSupportManagerFactory.kt +10 -60
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerBase.kt +7 -7
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerFactory.kt +1 -4
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/FrameTimingSequence.kt +17 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/FrameTimingsObserver.kt +144 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/InspectorNetworkHelper.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/TracingState.kt +17 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/TracingStateListener.kt +15 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/{interfaces → inspector}/TracingStateProvider.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/DevLoadingViewManager.kt +6 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/DevSupportManager.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/RedBoxHandler.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/perfmonitor/PerfMonitorInspectorTargetBinding.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/perfmonitor/PerfMonitorOverlayManager.kt +31 -6
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/perfmonitor/PerfMonitorOverlayView.kt +7 -6
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/perfmonitor/PerfMonitorUpdateListener.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManager.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/SurfaceMountingManager.java +2 -1
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlags.kt +63 -45
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxAccessor.kt +106 -76
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxInterop.kt +22 -16
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsDefaults.kt +23 -17
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsLocalAccessor.kt +117 -84
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsOverrides_RNOSS_Experimental_Android.kt +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsOverrides_RNOSS_Stable_Android.kt +0 -2
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsProvider.kt +22 -16
- package/ReactAndroid/src/main/java/com/facebook/react/internal/turbomodule/core/TurboModuleManager.kt +5 -43
- package/ReactAndroid/src/main/java/com/facebook/react/internal/turbomodule/core/TurboModuleManagerDelegate.kt +0 -3
- package/ReactAndroid/src/main/java/com/facebook/react/modules/appearance/AppearanceModule.kt +36 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/FpsDebugFrameCallback.kt +3 -27
- package/ReactAndroid/src/main/java/com/facebook/react/modules/devloading/DevLoadingModule.kt +7 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/NetworkEventUtil.kt +23 -0
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/NetworkingModule.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/ReactNativeVersion.kt +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/packagerconnection/PackagerConnectionSettings.kt +15 -8
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BridgelessCatalystInstance.kt +0 -9
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostImpl.kt +46 -12
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostImplDevHelper.kt +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostInspectorTarget.kt +11 -17
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactSurfaceView.kt +52 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BackgroundStyleApplicator.kt +92 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BaseViewManager.java +62 -8
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/JSKeyDispatcher.kt +65 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/JSPointerDispatcher.java +19 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/JSTouchDispatcher.kt +1 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeViewHierarchyManager.java +5 -36
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeViewHierarchyOptimizer.java +9 -91
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactAccessibilityDelegate.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactAxOrderHelper.kt +47 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactShadowNode.java +0 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactShadowNodeImpl.java +4 -23
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/TransformHelper.kt +1 -7
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIImplementation.java +1 -11
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIManagerModule.java +1 -47
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIViewOperationQueue.java +0 -16
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/drawable/OutlineDrawable.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/FabricEventDispatcher.kt +3 -36
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/KeyDownEvent.kt +23 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/KeyEvent.kt +156 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/KeyUpEvent.kt +24 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/PointerEvent.kt +29 -4
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ReactImageView.kt +12 -9
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ReactModalHostView.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollView.java +36 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollView.java +21 -11
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/VirtualViewContainerStateExperimental.kt +7 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextViewAccessibilityDelegate.kt +31 -15
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutManager.kt +127 -32
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewGroup.kt +11 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/virtual/view/ReactVirtualView.kt +3 -11
- package/ReactAndroid/src/main/java/com/facebook/react/views/virtual/viewexperimental/ReactVirtualViewExperimental.kt +3 -12
- package/ReactAndroid/src/main/jni/react/devsupport/JCxxInspectorPackagerConnectionWebSocket.cpp +29 -2
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.cpp +98 -3
- package/ReactAndroid/src/main/jni/react/fabric/FabricUIManagerBinding.cpp +62 -26
- package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.cpp +145 -103
- package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.h +31 -22
- package/ReactAndroid/src/main/jni/react/hermes/reactexecutor/CMakeLists.txt +0 -4
- package/ReactAndroid/src/main/jni/react/jni/CMakeLists.txt +1 -3
- package/ReactAndroid/src/main/jni/react/jni/CatalystInstanceImpl.cpp +5 -23
- package/ReactAndroid/src/main/jni/react/jni/CatalystInstanceImpl.h +2 -7
- package/ReactAndroid/src/main/jni/react/jni/CxxModuleWrapperBase.h +0 -24
- package/ReactAndroid/src/main/jni/react/jni/JSLoader.cpp +1 -1
- package/ReactAndroid/src/main/jni/react/jni/JSLoader.h +2 -1
- package/ReactAndroid/src/main/jni/react/jni/JavaModuleWrapper.cpp +0 -1
- package/ReactAndroid/src/main/jni/react/jni/ModuleRegistryBuilder.cpp +1 -29
- package/ReactAndroid/src/main/jni/react/jni/ModuleRegistryBuilder.h +1 -2
- package/ReactAndroid/src/main/jni/react/jni/OnLoad.cpp +0 -4
- package/ReactAndroid/src/main/jni/react/runtime/hermes/jni/CMakeLists.txt +0 -4
- package/ReactAndroid/src/main/jni/react/runtime/jni/CMakeLists.txt +0 -4
- package/ReactAndroid/src/main/jni/react/runtime/jni/JReactHostInspectorTarget.cpp +145 -17
- package/ReactAndroid/src/main/jni/react/runtime/jni/JReactHostInspectorTarget.h +193 -19
- package/ReactAndroid/src/main/jni/react/runtime/jni/JReactInstance.cpp +2 -1
- package/ReactAndroid/src/main/jni/react/tracing/PerformanceTracerCxxInterop.cpp +1 -1
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.cpp +62 -63
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.h +5 -7
- package/ReactAndroid/src/main/jni/third-party/folly/CMakeLists.txt +1 -0
- package/ReactAndroid/src/main/res/devsupport/drawable/ic_perf_issue.xml +10 -0
- package/ReactAndroid/src/main/res/devsupport/layout/dev_loading_view.xml +41 -15
- package/ReactAndroid/src/main/res/devsupport/layout/fps_view.xml +1 -1
- package/ReactAndroid/src/main/res/devsupport/values/strings.xml +1 -0
- package/ReactAndroid/src/main/res/views/uimanager/values-ne/strings.xml +16 -0
- package/ReactApple/RCTAnimatedModuleProvider/RCTAnimatedModuleProvider.h +2 -0
- package/ReactApple/RCTAnimatedModuleProvider/RCTAnimatedModuleProvider.mm +38 -5
- package/ReactCommon/cmake-utils/react-native-flags.cmake +3 -0
- package/ReactCommon/cxxreact/JSBigString.h +14 -5
- package/ReactCommon/cxxreact/JSIndexedRAMBundle.cpp +4 -5
- package/ReactCommon/cxxreact/ReactMarker.cpp +0 -1
- package/ReactCommon/cxxreact/ReactNativeVersion.h +5 -5
- package/ReactCommon/devtoolsruntimesettings/DevToolsRuntimeSettings.cpp +1 -1
- package/ReactCommon/hermes/React-hermes.podspec +1 -0
- package/ReactCommon/hermes/executor/CMakeLists.txt +0 -4
- package/ReactCommon/hermes/executor/HermesExecutorFactory.cpp +2 -0
- package/ReactCommon/hermes/inspector-modern/CMakeLists.txt +0 -4
- package/ReactCommon/jsi/jsi/jsi.cpp +6 -1
- package/ReactCommon/jsi/jsi/jsi.h +73 -0
- package/ReactCommon/jsi/jsi/test/testlib.cpp +2 -2
- package/ReactCommon/jsiexecutor/CMakeLists.txt +3 -1
- package/ReactCommon/jsiexecutor/React-jsiexecutor.podspec +3 -0
- package/ReactCommon/jsiexecutor/jsireact/JSIExecutor.cpp +2 -43
- package/ReactCommon/jsiexecutor/jsireact/JSIExecutor.h +3 -8
- package/ReactCommon/jsinspector-modern/ConsoleTask.cpp +27 -0
- package/ReactCommon/jsinspector-modern/ConsoleTask.h +38 -0
- package/ReactCommon/jsinspector-modern/ConsoleTaskContext.cpp +46 -0
- package/ReactCommon/jsinspector-modern/ConsoleTaskContext.h +102 -0
- package/ReactCommon/jsinspector-modern/ConsoleTaskOrchestrator.cpp +55 -0
- package/ReactCommon/jsinspector-modern/ConsoleTaskOrchestrator.h +48 -0
- package/ReactCommon/jsinspector-modern/HostAgent.cpp +9 -10
- package/ReactCommon/jsinspector-modern/HostAgent.h +2 -2
- package/ReactCommon/jsinspector-modern/HostTarget.cpp +7 -6
- package/ReactCommon/jsinspector-modern/HostTarget.h +73 -16
- package/ReactCommon/jsinspector-modern/HostTargetTraceRecording.cpp +40 -8
- package/ReactCommon/jsinspector-modern/HostTargetTraceRecording.h +42 -5
- package/ReactCommon/jsinspector-modern/HostTargetTracing.cpp +54 -21
- package/ReactCommon/jsinspector-modern/InstanceAgent.cpp +2 -11
- package/ReactCommon/jsinspector-modern/InstanceTarget.h +2 -2
- package/ReactCommon/jsinspector-modern/PerfMonitorV2.cpp +9 -1
- package/ReactCommon/jsinspector-modern/PerfMonitorV2.h +4 -1
- package/ReactCommon/jsinspector-modern/RuntimeAgent.cpp +3 -2
- package/ReactCommon/jsinspector-modern/RuntimeAgent.h +1 -1
- package/ReactCommon/jsinspector-modern/RuntimeTarget.cpp +12 -0
- package/ReactCommon/jsinspector-modern/RuntimeTarget.h +16 -13
- package/ReactCommon/jsinspector-modern/RuntimeTargetConsole.cpp +106 -1
- package/ReactCommon/jsinspector-modern/TracingAgent.cpp +30 -18
- package/ReactCommon/jsinspector-modern/TracingAgent.h +5 -4
- package/ReactCommon/jsinspector-modern/tests/ConsoleCreateTaskTest.cpp +131 -0
- package/ReactCommon/jsinspector-modern/tests/HostTargetTest.cpp +53 -0
- package/ReactCommon/jsinspector-modern/tests/InspectorMocks.h +20 -0
- package/ReactCommon/jsinspector-modern/tests/NetworkReporterTest.cpp +25 -55
- package/ReactCommon/jsinspector-modern/tests/ReactInstanceIntegrationTest.cpp +1 -0
- package/ReactCommon/jsinspector-modern/tests/TracingTest.cpp +116 -0
- package/ReactCommon/jsinspector-modern/tests/TracingTest.h +95 -0
- package/ReactCommon/jsinspector-modern/tracing/FrameTimingSequence.h +60 -0
- package/ReactCommon/jsinspector-modern/tracing/HostTracingProfile.h +43 -0
- package/ReactCommon/jsinspector-modern/tracing/HostTracingProfileSerializer.cpp +144 -0
- package/ReactCommon/jsinspector-modern/tracing/{TraceRecordingStateSerializer.h → HostTracingProfileSerializer.h} +16 -8
- package/ReactCommon/jsinspector-modern/tracing/PerformanceTracer.cpp +67 -16
- package/ReactCommon/jsinspector-modern/tracing/PerformanceTracer.h +21 -2
- package/ReactCommon/jsinspector-modern/tracing/TargetTracingAgent.h +5 -0
- package/ReactCommon/jsinspector-modern/tracing/TimeWindowedBuffer.h +158 -0
- package/ReactCommon/jsinspector-modern/tracing/TraceEvent.h +2 -1
- package/ReactCommon/jsinspector-modern/tracing/TraceEventGenerator.cpp +104 -0
- package/ReactCommon/jsinspector-modern/tracing/TraceEventGenerator.h +59 -0
- package/ReactCommon/jsinspector-modern/tracing/TraceEventSerializer.cpp +2 -1
- package/ReactCommon/jsinspector-modern/tracing/TraceRecordingState.h +18 -7
- package/ReactCommon/jsinspector-modern/tracing/TracingCategory.h +139 -0
- package/ReactCommon/jsinspector-modern/tracing/tests/TimeWindowedBufferTest.cpp +352 -0
- package/ReactCommon/jsitooling/React-jsitooling.podspec +4 -0
- package/ReactCommon/jsitooling/react/runtime/JSRuntimeBindings.cpp +54 -0
- package/{ReactAndroid/src/main/jni/react/jni/JReactCxxErrorHandler.h → ReactCommon/jsitooling/react/runtime/JSRuntimeBindings.h} +4 -6
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.cpp +43 -31
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.h +55 -40
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.cpp +234 -180
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.h +24 -18
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsDefaults.h +43 -31
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsDynamicProvider.h +91 -64
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsOverridesOSSExperimental.h +5 -1
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsOverridesOSSStable.h +0 -4
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsProvider.h +12 -9
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModule.h +7 -2
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleBinding.cpp +30 -10
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleBinding.h +17 -6
- package/ReactCommon/react/nativemodule/core/iostests/RCTTurboModuleTests.mm +0 -1
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTInteropTurboModule.mm +1 -4
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModule.h +0 -4
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModule.mm +43 -60
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModuleManager.mm +11 -36
- package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.cpp +53 -38
- package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.h +22 -16
- package/ReactCommon/react/nativemodule/samples/ReactCommon-Samples.podspec +1 -0
- package/ReactCommon/react/nativemodule/samples/platform/android/NativeSampleTurboModuleSpec.java +24 -3
- package/ReactCommon/react/nativemodule/samples/platform/ios/ReactCommon/RCTNativeSampleTurboModuleSpec.h +76 -13
- package/ReactCommon/react/nativemodule/samples/platform/ios/ReactCommon/RCTNativeSampleTurboModuleSpec.mm +74 -64
- package/ReactCommon/react/nativemodule/samples/platform/ios/ReactCommon/RCTSampleTurboModule.mm +17 -13
- package/ReactCommon/react/networking/NetworkReporter.cpp +26 -22
- package/ReactCommon/react/networking/React-networking.podspec +0 -1
- package/ReactCommon/react/performance/cdpmetrics/CdpPerfIssuesReporter.cpp +4 -2
- package/ReactCommon/react/performance/timeline/CMakeLists.txt +1 -0
- package/ReactCommon/react/performance/timeline/PerformanceEntryReporter.cpp +10 -2
- package/ReactCommon/react/performance/timeline/React-performancetimeline.podspec +1 -0
- package/ReactCommon/react/renderer/animated/AnimatedModule.cpp +104 -78
- package/ReactCommon/react/renderer/animated/AnimatedModule.h +10 -2
- package/ReactCommon/react/renderer/animated/NativeAnimatedNodesManager.cpp +174 -75
- package/ReactCommon/react/renderer/animated/NativeAnimatedNodesManager.h +19 -1
- package/ReactCommon/react/renderer/animated/NativeAnimatedNodesManagerProvider.cpp +68 -46
- package/ReactCommon/react/renderer/animated/drivers/FrameAnimationDriver.cpp +1 -0
- package/ReactCommon/react/renderer/animated/internal/AnimatedMountingOverrideDelegate.cpp +1 -1
- package/ReactCommon/react/renderer/animated/nodes/ColorAnimatedNode.cpp +0 -1
- package/ReactCommon/react/renderer/animated/nodes/InterpolationAnimatedNode.cpp +103 -4
- package/ReactCommon/react/renderer/animated/nodes/InterpolationAnimatedNode.h +9 -0
- package/ReactCommon/react/renderer/animated/nodes/PropsAnimatedNode.cpp +5 -1
- package/ReactCommon/react/renderer/animated/nodes/PropsAnimatedNode.h +9 -0
- package/ReactCommon/react/renderer/animated/nodes/RoundAnimatedNode.cpp +1 -1
- package/ReactCommon/react/renderer/animated/nodes/ValueAnimatedNode.cpp +1 -1
- package/ReactCommon/react/renderer/animated/tests/AnimatedNodeTests.cpp +67 -0
- package/ReactCommon/react/renderer/animated/tests/AnimationDriverTests.cpp +59 -0
- package/ReactCommon/react/renderer/animated/tests/AnimationTestsBase.h +2 -1
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropSerializer.cpp +715 -0
- package/ReactCommon/react/renderer/animationbackend/AnimatedProps.h +388 -1
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropsBuilder.h +191 -2
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropsRegistry.cpp +100 -0
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropsRegistry.h +298 -0
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropsSerializer.h +17 -0
- package/ReactCommon/react/renderer/animationbackend/AnimationBackend.cpp +90 -94
- package/ReactCommon/react/renderer/animationbackend/AnimationBackend.h +23 -5
- package/ReactCommon/react/renderer/animationbackend/AnimationBackendCommitHook.cpp +75 -0
- package/ReactCommon/react/renderer/animationbackend/AnimationBackendCommitHook.h +32 -0
- package/ReactCommon/react/renderer/animations/LayoutAnimationKeyFrameManager.cpp +2 -2
- package/ReactCommon/react/renderer/attributedstring/AttributedStringBox.h +3 -0
- package/ReactCommon/react/renderer/components/image/ImageProps.cpp +2 -2
- package/ReactCommon/react/renderer/components/image/ImageProps.h +2 -2
- package/ReactCommon/react/renderer/components/image/ImageShadowNode.cpp +9 -2
- package/ReactCommon/react/renderer/components/image/conversions.h +5 -0
- package/ReactCommon/react/renderer/components/text/BaseTextProps.cpp +2 -1
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/HostPlatformViewProps.cpp +5 -1
- package/ReactCommon/react/renderer/core/ConcreteComponentDescriptor.h +21 -1
- package/ReactCommon/react/renderer/core/ConcreteShadowNode.h +14 -0
- package/ReactCommon/react/renderer/core/DynamicEventPayload.cpp +10 -0
- package/ReactCommon/react/renderer/core/DynamicEventPayload.h +6 -1
- package/ReactCommon/react/renderer/core/DynamicPointerEvent.cpp +30 -0
- package/ReactCommon/react/renderer/core/DynamicPointerEvent.h +29 -0
- package/ReactCommon/react/renderer/core/EventDispatcher.cpp +1 -1
- package/ReactCommon/react/renderer/core/EventEmitter.cpp +11 -14
- package/ReactCommon/react/renderer/core/EventQueueProcessor.cpp +3 -3
- package/ReactCommon/react/renderer/core/Props.cpp +23 -8
- package/ReactCommon/react/renderer/core/Props.h +6 -4
- package/ReactCommon/react/renderer/core/ShadowNode.cpp +4 -10
- package/ReactCommon/react/renderer/core/tests/ShadowNodeTest.cpp +32 -0
- package/ReactCommon/react/renderer/css/CSSSyntaxParser.h +7 -0
- package/ReactCommon/react/renderer/debug/CMakeLists.txt +7 -0
- package/ReactCommon/react/renderer/debug/flags.h +3 -2
- package/ReactCommon/react/renderer/graphics/BlendMode.h +2 -0
- package/ReactCommon/react/renderer/graphics/Filter.h +2 -0
- package/ReactCommon/react/renderer/imagemanager/ImageManager.h +3 -0
- package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageFetcher.cpp +23 -12
- package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageFetcher.h +8 -3
- package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageManager.cpp +16 -4
- package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageRequestParams.h +9 -4
- package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/conversions.h +8 -4
- package/ReactCommon/react/renderer/imagemanager/platform/ios/react/renderer/imagemanager/RCTSyncImageManager.mm +1 -1
- package/ReactCommon/react/renderer/imagemanager/primitives.h +15 -6
- package/ReactCommon/react/renderer/mounting/MountingCoordinator.cpp +0 -11
- package/ReactCommon/react/renderer/mounting/MountingCoordinator.h +0 -4
- package/ReactCommon/react/renderer/scheduler/SurfaceHandler.cpp +0 -20
- package/ReactCommon/react/renderer/scheduler/SurfaceHandler.h +3 -3
- package/ReactCommon/react/renderer/scheduler/SurfaceManager.cpp +2 -3
- package/ReactCommon/react/renderer/uimanager/UIManager.cpp +6 -0
- package/ReactCommon/react/renderer/uimanager/UIManagerAnimationBackend.h +1 -0
- package/ReactCommon/react/runtime/CMakeLists.txt +0 -4
- package/ReactCommon/react/runtime/PlatformTimerRegistry.h +2 -0
- package/ReactCommon/react/runtime/ReactInstance.cpp +21 -14
- package/ReactCommon/react/runtime/ReactInstance.h +5 -1
- package/ReactCommon/react/runtime/TimerManager.cpp +11 -53
- package/ReactCommon/react/runtime/TimerManager.h +7 -12
- package/ReactCommon/react/runtime/hermes/CMakeLists.txt +0 -4
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost.h +3 -2
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost.mm +10 -6
- package/ReactCommon/yoga/yoga/algorithm/FlexDirection.h +6 -6
- package/ReactCommon/yoga/yoga/algorithm/SizingMode.h +4 -4
- package/ReactCommon/yoga/yoga/style/Style.h +8 -8
- package/ReactCommon/yoga/yoga/style/StyleLength.h +7 -0
- package/ReactCommon/yoga/yoga/style/StyleSizeLength.h +7 -0
- package/flow/HermesInternalType.js +6 -6
- package/flow/bom.js.flow +35 -28
- package/flow/cssom.js.flow +3 -3
- package/flow/dom.js.flow +34 -33
- package/index.js +3 -0
- package/index.js.flow +8 -0
- package/jest/mock.js +2 -2
- package/jest/mockComponent.js +1 -1
- package/jest/setup.js +1 -1
- package/package.json +11 -11
- package/react-native.config.js +0 -17
- package/scripts/cocoapods/new_architecture.rb +7 -1
- package/scripts/cocoapods/spm.rb +28 -10
- package/scripts/cocoapods/utils.rb +4 -4
- package/scripts/codegen/generate-artifacts-executor/generateRCTThirdPartyComponents.js +5 -5
- package/scripts/codegen/generate-artifacts-executor/generateSchemaInfos.js +7 -6
- package/scripts/ios-configure-glog.sh +24 -1
- package/scripts/react_native_pods.rb +13 -0
- package/sdks/.hermesv1version +1 -1
- package/sdks/.hermesversion +1 -1
- package/sdks/hermes-engine/hermes-engine.podspec +53 -36
- package/sdks/hermes-engine/hermes-utils.rb +8 -15
- package/sdks/hermes-engine/version.properties +2 -2
- package/src/private/animated/NativeAnimatedHelper.js +130 -125
- package/src/private/animated/NativeAnimatedValidation.js +7 -4
- package/src/private/animated/createAnimatedPropsHook.js +13 -5
- package/src/private/animated/createAnimatedPropsMemoHook.js +10 -10
- package/src/private/components/virtualview/VirtualView.js +16 -9
- package/src/private/components/virtualview/logger/VirtualViewLogger.js +21 -0
- package/src/private/components/virtualview/logger/VirtualViewLoggerTypes.js +24 -0
- package/src/private/devsupport/devmenu/elementinspector/ElementProperties.js +1 -1
- package/src/private/devsupport/devmenu/elementinspector/Inspector.js +6 -25
- package/src/private/devsupport/devmenu/elementinspector/InspectorPanel.js +1 -27
- package/src/private/devsupport/devmenu/elementinspector/XHRInterceptor.js +3 -2
- package/src/private/featureflags/ReactNativeFeatureFlags.js +63 -42
- package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +3 -3
- package/src/private/featureflags/specs/NativeReactNativeFeatureFlags.js +12 -9
- package/src/private/renderer/errorhandling/ErrorHandlers.js +7 -4
- package/src/private/specs_DEPRECATED/modules/NativeAccessibilityManager.js +1 -1
- package/src/private/specs_DEPRECATED/modules/NativeAnimatedModule.js +4 -0
- package/src/private/specs_DEPRECATED/modules/NativeDevLoadingView.js +1 -0
- package/src/private/webapis/dom/events/CustomEvent.js +3 -3
- package/src/private/webapis/dom/nodes/internals/ReactNativeDocumentElementInstanceHandle.js +1 -1
- package/src/private/webapis/dom/nodes/internals/ReactNativeDocumentInstanceHandle.js +1 -1
- package/src/private/webapis/dom/nodes/specs/NativeDOM.js +29 -29
- package/src/private/webapis/dom/oldstylecollections/HTMLCollection.js +1 -1
- package/src/private/webapis/dom/oldstylecollections/HTMLCollection.js.flow +2 -0
- package/src/private/webapis/dom/oldstylecollections/NodeList.js +2 -2
- package/src/private/webapis/dom/oldstylecollections/NodeList.js.flow +4 -1
- package/src/private/webapis/geometry/DOMRectReadOnly.js +1 -1
- package/src/private/webapis/html/events/MessageEvent.js +3 -3
- package/src/private/webapis/idlecallbacks/specs/NativeIdleCallbacks.js +3 -3
- package/src/private/webapis/intersectionobserver/IntersectionObserver.js +53 -5
- package/src/private/webapis/intersectionobserver/internals/IntersectionObserverManager.js +2 -2
- package/src/private/webapis/intersectionobserver/specs/NativeIntersectionObserver.js +4 -4
- package/src/private/webapis/microtasks/specs/NativeMicrotasks.js +1 -1
- package/src/private/webapis/mutationobserver/MutationObserver.js +1 -1
- package/src/private/webapis/mutationobserver/MutationRecord.js +1 -1
- package/src/private/webapis/mutationobserver/specs/NativeMutationObserver.js +4 -4
- package/src/private/webapis/performance/Performance.js +1 -1
- package/src/private/webapis/performance/UserTiming.js +1 -1
- package/src/private/webapis/performance/specs/NativePerformance.js +3 -3
- package/src/private/webapis/structuredClone/structuredClone.js +3 -3
- package/src/types/globals.d.ts +30 -1
- package/third-party-podspecs/RCT-Folly.podspec +1 -0
- package/third-party-podspecs/glog.podspec +1 -0
- package/React/CxxModule/RCTCxxModule.h +0 -29
- package/React/CxxModule/RCTCxxModule.mm +0 -87
- package/ReactAndroid/src/main/java/com/facebook/react/LazyReactPackage.kt +0 -146
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CallbackImpl.kt +0 -45
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CxxModuleWrapper.kt +0 -25
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CxxModuleWrapperBase.kt +0 -61
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/NotThreadSafeBridgeIdleDebugListener.kt +0 -36
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/OnBatchCompleteListener.kt +0 -21
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactCxxErrorHandler.kt +0 -54
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactInstanceManagerInspectorTarget.kt +0 -78
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/BridgeDevSupportManager.kt +0 -105
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/TracingState.kt +0 -19
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector.kt +0 -157
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeKind.kt +0 -32
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/debug/NotThreadSafeViewHierarchyUpdateDebugListener.kt +0 -30
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/LayoutAnimationController.kt +0 -87
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/layoutanimation/LayoutAnimationListener.kt +0 -23
- package/ReactAndroid/src/main/jni/react/jni/CxxModuleWrapper.h +0 -37
- package/ReactAndroid/src/main/jni/react/jni/JReactCxxErrorHandler.cpp +0 -20
- package/ReactAndroid/src/main/jni/react/jni/ReactInstanceManagerInspectorTarget.cpp +0 -175
- package/ReactAndroid/src/main/jni/react/jni/ReactInstanceManagerInspectorTarget.h +0 -75
- package/ReactCommon/jsinspector-modern/tracing/TraceRecordingStateSerializer.cpp +0 -68
- package/ReactCommon/jsinspector-modern/tracing/TracingState.h +0 -24
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboCxxModule.cpp +0 -212
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboCxxModule.h +0 -40
- package/src/private/devsupport/devmenu/elementinspector/NetworkOverlay.js +0 -628
- package/src/private/devsupport/devmenu/perfmonitor/PerformanceOverlay.js +0 -66
- package/tvosCommands.js +0 -51
- /package/ReactCommon/jsi/jsi/{hermes.h → hermes-interfaces.h} +0 -0
|
@@ -73,11 +73,13 @@ thread_local bool NativeAnimatedNodesManager::isOnRenderThread_{false};
|
|
|
73
73
|
NativeAnimatedNodesManager::NativeAnimatedNodesManager(
|
|
74
74
|
DirectManipulationCallback&& directManipulationCallback,
|
|
75
75
|
FabricCommitCallback&& fabricCommitCallback,
|
|
76
|
+
ResolvePlatformColor&& resolvePlatformColor,
|
|
76
77
|
StartOnRenderCallback&& startOnRenderCallback,
|
|
77
78
|
StopOnRenderCallback&& stopOnRenderCallback,
|
|
78
79
|
FrameRateListenerCallback&& frameRateListenerCallback) noexcept
|
|
79
80
|
: directManipulationCallback_(std::move(directManipulationCallback)),
|
|
80
81
|
fabricCommitCallback_(std::move(fabricCommitCallback)),
|
|
82
|
+
resolvePlatformColor_(std::move(resolvePlatformColor)),
|
|
81
83
|
startOnRenderCallback_(std::move(startOnRenderCallback)),
|
|
82
84
|
stopOnRenderCallback_(std::move(stopOnRenderCallback)),
|
|
83
85
|
frameRateListenerCallback_(std::move(frameRateListenerCallback)) {
|
|
@@ -236,6 +238,20 @@ void NativeAnimatedNodesManager::connectAnimatedNodeToView(
|
|
|
236
238
|
}
|
|
237
239
|
}
|
|
238
240
|
|
|
241
|
+
void NativeAnimatedNodesManager::connectAnimatedNodeToShadowNodeFamily(
|
|
242
|
+
Tag propsNodeTag,
|
|
243
|
+
std::shared_ptr<const ShadowNodeFamily> family) noexcept {
|
|
244
|
+
react_native_assert(propsNodeTag);
|
|
245
|
+
auto node = getAnimatedNode<PropsAnimatedNode>(propsNodeTag);
|
|
246
|
+
if (node != nullptr && family != nullptr) {
|
|
247
|
+
std::lock_guard<std::mutex> lock(tagToShadowNodeFamilyMutex_);
|
|
248
|
+
tagToShadowNodeFamily_[family->getTag()] = family;
|
|
249
|
+
} else {
|
|
250
|
+
LOG(WARNING)
|
|
251
|
+
<< "Cannot ConnectAnimatedNodeToShadowNodeFamily, animated node has to be props type";
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
|
|
239
255
|
void NativeAnimatedNodesManager::disconnectAnimatedNodeFromView(
|
|
240
256
|
Tag propsNodeTag,
|
|
241
257
|
Tag viewTag) noexcept {
|
|
@@ -249,6 +265,10 @@ void NativeAnimatedNodesManager::disconnectAnimatedNodeFromView(
|
|
|
249
265
|
std::lock_guard<std::mutex> lock(connectedAnimatedNodesMutex_);
|
|
250
266
|
connectedAnimatedNodes_.erase(viewTag);
|
|
251
267
|
}
|
|
268
|
+
{
|
|
269
|
+
std::lock_guard<std::mutex> lock(tagToShadowNodeFamilyMutex_);
|
|
270
|
+
tagToShadowNodeFamily_.erase(viewTag);
|
|
271
|
+
}
|
|
252
272
|
updatedNodeTags_.insert(node->tag());
|
|
253
273
|
|
|
254
274
|
onManagedPropsRemoved(viewTag);
|
|
@@ -519,6 +539,17 @@ NativeAnimatedNodesManager::ensureEventEmitterListener() noexcept {
|
|
|
519
539
|
}
|
|
520
540
|
|
|
521
541
|
void NativeAnimatedNodesManager::startRenderCallbackIfNeeded(bool isAsync) {
|
|
542
|
+
// This method can be called from either the UI thread or JavaScript thread.
|
|
543
|
+
// It ensures `startOnRenderCallback_` is called exactly once using atomic
|
|
544
|
+
// operations. We use std::atomic_bool rather than std::mutex to avoid
|
|
545
|
+
// potential deadlocks that could occur if we called external code while
|
|
546
|
+
// holding a mutex.
|
|
547
|
+
auto isRenderCallbackStarted = isRenderCallbackStarted_.exchange(true);
|
|
548
|
+
if (isRenderCallbackStarted) {
|
|
549
|
+
// onRender callback is already started.
|
|
550
|
+
return;
|
|
551
|
+
}
|
|
552
|
+
|
|
522
553
|
if (ReactNativeFeatureFlags::useSharedAnimatedBackend()) {
|
|
523
554
|
#ifdef RN_USE_ANIMATION_BACKEND
|
|
524
555
|
if (auto animationBackend = animationBackend_.lock()) {
|
|
@@ -531,16 +562,6 @@ void NativeAnimatedNodesManager::startRenderCallbackIfNeeded(bool isAsync) {
|
|
|
531
562
|
|
|
532
563
|
return;
|
|
533
564
|
}
|
|
534
|
-
// This method can be called from either the UI thread or JavaScript thread.
|
|
535
|
-
// It ensures `startOnRenderCallback_` is called exactly once using atomic
|
|
536
|
-
// operations. We use std::atomic_bool rather than std::mutex to avoid
|
|
537
|
-
// potential deadlocks that could occur if we called external code while
|
|
538
|
-
// holding a mutex.
|
|
539
|
-
auto isRenderCallbackStarted = isRenderCallbackStarted_.exchange(true);
|
|
540
|
-
if (isRenderCallbackStarted) {
|
|
541
|
-
// onRender callback is already started.
|
|
542
|
-
return;
|
|
543
|
-
}
|
|
544
565
|
|
|
545
566
|
if (startOnRenderCallback_) {
|
|
546
567
|
startOnRenderCallback_([this]() { onRender(); }, isAsync);
|
|
@@ -549,25 +570,28 @@ void NativeAnimatedNodesManager::startRenderCallbackIfNeeded(bool isAsync) {
|
|
|
549
570
|
|
|
550
571
|
void NativeAnimatedNodesManager::stopRenderCallbackIfNeeded(
|
|
551
572
|
bool isAsync) noexcept {
|
|
552
|
-
if (ReactNativeFeatureFlags::useSharedAnimatedBackend()) {
|
|
553
|
-
if (auto animationBackend = animationBackend_.lock()) {
|
|
554
|
-
animationBackend->stop(isAsync);
|
|
555
|
-
}
|
|
556
|
-
return;
|
|
557
|
-
}
|
|
558
573
|
// When multiple threads reach this point, only one thread should call
|
|
559
574
|
// stopOnRenderCallback_. This synchronization is primarily needed during
|
|
560
575
|
// destruction of NativeAnimatedNodesManager. In normal operation,
|
|
561
576
|
// stopRenderCallbackIfNeeded is always called from the UI thread.
|
|
562
577
|
auto isRenderCallbackStarted = isRenderCallbackStarted_.exchange(false);
|
|
563
578
|
|
|
579
|
+
if (ReactNativeFeatureFlags::useSharedAnimatedBackend()) {
|
|
580
|
+
if (isRenderCallbackStarted) {
|
|
581
|
+
if (auto animationBackend = animationBackend_.lock()) {
|
|
582
|
+
animationBackend->stop(isAsync);
|
|
583
|
+
}
|
|
584
|
+
}
|
|
585
|
+
return;
|
|
586
|
+
}
|
|
587
|
+
|
|
564
588
|
if (isRenderCallbackStarted) {
|
|
565
589
|
if (stopOnRenderCallback_) {
|
|
566
590
|
stopOnRenderCallback_(isAsync);
|
|
567
|
-
}
|
|
568
591
|
|
|
569
|
-
|
|
570
|
-
|
|
592
|
+
if (frameRateListenerCallback_) {
|
|
593
|
+
frameRateListenerCallback_(false);
|
|
594
|
+
}
|
|
571
595
|
}
|
|
572
596
|
}
|
|
573
597
|
}
|
|
@@ -629,20 +653,22 @@ void NativeAnimatedNodesManager::updateNodes(
|
|
|
629
653
|
// in Animated, value nodes like RGBA are parents and Color node is child
|
|
630
654
|
// (the opposite of tree structure)
|
|
631
655
|
for (const auto childTag : nextNode.node->getChildren()) {
|
|
632
|
-
auto child = getAnimatedNode<AnimatedNode>(childTag)
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
656
|
+
if (auto child = getAnimatedNode<AnimatedNode>(childTag)) {
|
|
657
|
+
child->activeIncomingNodes++;
|
|
658
|
+
if (child->bfsColor != animatedGraphBFSColor_) {
|
|
659
|
+
child->bfsColor = animatedGraphBFSColor_;
|
|
636
660
|
#ifdef REACT_NATIVE_DEBUG
|
|
637
|
-
|
|
661
|
+
activeNodesCount++;
|
|
638
662
|
#endif
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
663
|
+
const auto connectedToFinishedAnimation =
|
|
664
|
+
is_node_connected_to_finished_animation(
|
|
665
|
+
child, childTag, nextNode.connectedToFinishedAnimation);
|
|
666
|
+
nodesQueue.emplace_back(
|
|
667
|
+
NodesQueueItem{
|
|
668
|
+
.node = child,
|
|
669
|
+
.connectedToFinishedAnimation =
|
|
670
|
+
connectedToFinishedAnimation});
|
|
671
|
+
}
|
|
646
672
|
}
|
|
647
673
|
}
|
|
648
674
|
}
|
|
@@ -697,26 +723,29 @@ void NativeAnimatedNodesManager::updateNodes(
|
|
|
697
723
|
}
|
|
698
724
|
|
|
699
725
|
for (auto childTag : nextNode.node->getChildren()) {
|
|
700
|
-
auto child = getAnimatedNode<AnimatedNode>(childTag)
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
726
|
+
if (auto child = getAnimatedNode<AnimatedNode>(childTag)) {
|
|
727
|
+
child->activeIncomingNodes--;
|
|
728
|
+
if (child->activeIncomingNodes == 0 &&
|
|
729
|
+
child->bfsColor != animatedGraphBFSColor_) {
|
|
730
|
+
child->bfsColor = animatedGraphBFSColor_;
|
|
704
731
|
#ifdef REACT_NATIVE_DEBUG
|
|
705
|
-
|
|
732
|
+
updatedNodesCount++;
|
|
706
733
|
#endif
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
734
|
+
const auto connectedToFinishedAnimation =
|
|
735
|
+
is_node_connected_to_finished_animation(
|
|
736
|
+
child, childTag, nextNode.connectedToFinishedAnimation);
|
|
737
|
+
nodesQueue.emplace_back(
|
|
738
|
+
NodesQueueItem{
|
|
739
|
+
.node = child,
|
|
740
|
+
.connectedToFinishedAnimation =
|
|
741
|
+
connectedToFinishedAnimation});
|
|
742
|
+
}
|
|
715
743
|
#ifdef REACT_NATIVE_DEBUG
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
744
|
+
else if (child->bfsColor == animatedGraphBFSColor_) {
|
|
745
|
+
cyclesDetected++;
|
|
746
|
+
}
|
|
719
747
|
#endif
|
|
748
|
+
}
|
|
720
749
|
}
|
|
721
750
|
}
|
|
722
751
|
|
|
@@ -758,12 +787,7 @@ bool NativeAnimatedNodesManager::onAnimationFrame(double timestamp) {
|
|
|
758
787
|
|
|
759
788
|
if (driver->getIsComplete()) {
|
|
760
789
|
hasFinishedAnimations = true;
|
|
761
|
-
|
|
762
|
-
ReactNativeFeatureFlags::cxxNativeAnimatedRemoveJsSync() &&
|
|
763
|
-
!ReactNativeFeatureFlags::disableFabricCommitInCXXAnimated();
|
|
764
|
-
if (shouldRemoveJsSync) {
|
|
765
|
-
finishedAnimationValueNodes.insert(driver->getAnimatedValueTag());
|
|
766
|
-
}
|
|
790
|
+
finishedAnimationValueNodes.insert(driver->getAnimatedValueTag());
|
|
767
791
|
}
|
|
768
792
|
}
|
|
769
793
|
|
|
@@ -790,7 +814,7 @@ bool NativeAnimatedNodesManager::onAnimationFrame(double timestamp) {
|
|
|
790
814
|
return commitProps();
|
|
791
815
|
}
|
|
792
816
|
|
|
793
|
-
folly::dynamic NativeAnimatedNodesManager::
|
|
817
|
+
folly::dynamic NativeAnimatedNodesManager::getManagedProps(
|
|
794
818
|
Tag tag) const noexcept {
|
|
795
819
|
std::lock_guard<std::mutex> lock(connectedAnimatedNodesMutex_);
|
|
796
820
|
if (const auto iter = connectedAnimatedNodes_.find(tag);
|
|
@@ -843,6 +867,15 @@ bool NativeAnimatedNodesManager::isOnRenderThread() const noexcept {
|
|
|
843
867
|
return isOnRenderThread_;
|
|
844
868
|
}
|
|
845
869
|
|
|
870
|
+
void NativeAnimatedNodesManager::resolvePlatformColor(
|
|
871
|
+
SurfaceId surfaceId,
|
|
872
|
+
const RawValue& value,
|
|
873
|
+
SharedColor& result) const {
|
|
874
|
+
if (resolvePlatformColor_) {
|
|
875
|
+
resolvePlatformColor_(surfaceId, value, result);
|
|
876
|
+
}
|
|
877
|
+
}
|
|
878
|
+
|
|
846
879
|
#pragma mark - Listeners
|
|
847
880
|
|
|
848
881
|
void NativeAnimatedNodesManager::startListeningToAnimatedNodeValue(
|
|
@@ -950,12 +983,7 @@ AnimationMutations NativeAnimatedNodesManager::pullAnimationMutations() {
|
|
|
950
983
|
|
|
951
984
|
if (driver->getIsComplete()) {
|
|
952
985
|
hasFinishedAnimations = true;
|
|
953
|
-
|
|
954
|
-
ReactNativeFeatureFlags::cxxNativeAnimatedRemoveJsSync() &&
|
|
955
|
-
!ReactNativeFeatureFlags::disableFabricCommitInCXXAnimated();
|
|
956
|
-
if (shouldRemoveJsSync) {
|
|
957
|
-
finishedAnimationValueNodes.insert(driver->getAnimatedValueTag());
|
|
958
|
-
}
|
|
986
|
+
finishedAnimationValueNodes.insert(driver->getAnimatedValueTag());
|
|
959
987
|
}
|
|
960
988
|
}
|
|
961
989
|
|
|
@@ -979,14 +1007,49 @@ AnimationMutations NativeAnimatedNodesManager::pullAnimationMutations() {
|
|
|
979
1007
|
}
|
|
980
1008
|
}
|
|
981
1009
|
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
1010
|
+
{
|
|
1011
|
+
std::lock_guard<std::mutex> lock(tagToShadowNodeFamilyMutex_);
|
|
1012
|
+
for (auto& [tag, props] : updateViewPropsDirect_) {
|
|
1013
|
+
auto familyIt = tagToShadowNodeFamily_.find(tag);
|
|
1014
|
+
if (familyIt == tagToShadowNodeFamily_.end()) {
|
|
1015
|
+
continue;
|
|
1016
|
+
}
|
|
1017
|
+
|
|
1018
|
+
auto weakFamily = familyIt->second;
|
|
1019
|
+
if (auto family = weakFamily.lock()) {
|
|
1020
|
+
propsBuilder.storeDynamic(props);
|
|
1021
|
+
mutations.batch.push_back(
|
|
1022
|
+
AnimationMutation{
|
|
1023
|
+
.tag = tag,
|
|
1024
|
+
.family = family,
|
|
1025
|
+
.props = propsBuilder.get(),
|
|
1026
|
+
});
|
|
1027
|
+
}
|
|
1028
|
+
containsChange = true;
|
|
1029
|
+
}
|
|
1030
|
+
for (auto& [tag, props] : updateViewProps_) {
|
|
1031
|
+
auto familyIt = tagToShadowNodeFamily_.find(tag);
|
|
1032
|
+
if (familyIt == tagToShadowNodeFamily_.end()) {
|
|
1033
|
+
continue;
|
|
1034
|
+
}
|
|
1035
|
+
|
|
1036
|
+
auto weakFamily = familyIt->second;
|
|
1037
|
+
if (auto family = weakFamily.lock()) {
|
|
1038
|
+
propsBuilder.storeDynamic(props);
|
|
1039
|
+
mutations.batch.push_back(
|
|
1040
|
+
AnimationMutation{
|
|
1041
|
+
.tag = tag,
|
|
1042
|
+
.family = family,
|
|
1043
|
+
.props = propsBuilder.get(),
|
|
1044
|
+
.hasLayoutUpdates = true,
|
|
1045
|
+
});
|
|
1046
|
+
}
|
|
1047
|
+
containsChange = true;
|
|
1048
|
+
}
|
|
1049
|
+
}
|
|
1050
|
+
if (containsChange) {
|
|
1051
|
+
updateViewPropsDirect_.clear();
|
|
1052
|
+
updateViewProps_.clear();
|
|
990
1053
|
}
|
|
991
1054
|
}
|
|
992
1055
|
|
|
@@ -1007,17 +1070,52 @@ AnimationMutations NativeAnimatedNodesManager::pullAnimationMutations() {
|
|
|
1007
1070
|
}
|
|
1008
1071
|
}
|
|
1009
1072
|
|
|
1010
|
-
// Step 2: update all nodes that are connected to the finished
|
|
1073
|
+
// Step 2: update all nodes that are connected to the finished
|
|
1074
|
+
// animations.
|
|
1011
1075
|
updateNodes(finishedAnimationValueNodes);
|
|
1012
1076
|
|
|
1013
1077
|
isEventAnimationInProgress_ = false;
|
|
1014
1078
|
|
|
1015
|
-
|
|
1016
|
-
|
|
1017
|
-
|
|
1018
|
-
|
|
1019
|
-
|
|
1079
|
+
{
|
|
1080
|
+
std::lock_guard<std::mutex> lock(tagToShadowNodeFamilyMutex_);
|
|
1081
|
+
for (auto& [tag, props] : updateViewPropsDirect_) {
|
|
1082
|
+
auto familyIt = tagToShadowNodeFamily_.find(tag);
|
|
1083
|
+
if (familyIt == tagToShadowNodeFamily_.end()) {
|
|
1084
|
+
continue;
|
|
1085
|
+
}
|
|
1086
|
+
|
|
1087
|
+
auto weakFamily = familyIt->second;
|
|
1088
|
+
if (auto family = weakFamily.lock()) {
|
|
1089
|
+
propsBuilder.storeDynamic(props);
|
|
1090
|
+
mutations.batch.push_back(
|
|
1091
|
+
AnimationMutation{
|
|
1092
|
+
.tag = tag,
|
|
1093
|
+
.family = family,
|
|
1094
|
+
.props = propsBuilder.get(),
|
|
1095
|
+
});
|
|
1096
|
+
}
|
|
1097
|
+
}
|
|
1098
|
+
for (auto& [tag, props] : updateViewProps_) {
|
|
1099
|
+
auto familyIt = tagToShadowNodeFamily_.find(tag);
|
|
1100
|
+
if (familyIt == tagToShadowNodeFamily_.end()) {
|
|
1101
|
+
continue;
|
|
1102
|
+
}
|
|
1103
|
+
|
|
1104
|
+
auto weakFamily = familyIt->second;
|
|
1105
|
+
if (auto family = weakFamily.lock()) {
|
|
1106
|
+
propsBuilder.storeDynamic(props);
|
|
1107
|
+
mutations.batch.push_back(
|
|
1108
|
+
AnimationMutation{
|
|
1109
|
+
.tag = tag,
|
|
1110
|
+
.family = family,
|
|
1111
|
+
.props = propsBuilder.get(),
|
|
1112
|
+
.hasLayoutUpdates = true,
|
|
1113
|
+
});
|
|
1114
|
+
}
|
|
1115
|
+
}
|
|
1020
1116
|
}
|
|
1117
|
+
updateViewProps_.clear();
|
|
1118
|
+
updateViewPropsDirect_.clear();
|
|
1021
1119
|
}
|
|
1022
1120
|
} else {
|
|
1023
1121
|
// There is no active animation. Stop the render callback.
|
|
@@ -1097,7 +1195,8 @@ void NativeAnimatedNodesManager::onRender() {
|
|
|
1097
1195
|
}
|
|
1098
1196
|
}
|
|
1099
1197
|
|
|
1100
|
-
// Step 2: update all nodes that are connected to the finished
|
|
1198
|
+
// Step 2: update all nodes that are connected to the finished
|
|
1199
|
+
// animations.
|
|
1101
1200
|
updateNodes(finishedAnimationValueNodes);
|
|
1102
1201
|
|
|
1103
1202
|
isEventAnimationInProgress_ = false;
|
|
@@ -21,6 +21,7 @@
|
|
|
21
21
|
#include <react/renderer/animationbackend/AnimationBackend.h>
|
|
22
22
|
#endif
|
|
23
23
|
#include <react/renderer/core/ReactPrimitives.h>
|
|
24
|
+
#include <react/renderer/core/ShadowNode.h>
|
|
24
25
|
#include <react/renderer/uimanager/UIManagerAnimationBackend.h>
|
|
25
26
|
#include <chrono>
|
|
26
27
|
#include <memory>
|
|
@@ -58,10 +59,12 @@ class NativeAnimatedNodesManager {
|
|
|
58
59
|
using StartOnRenderCallback = std::function<void(std::function<void()> &&, bool isAsync)>;
|
|
59
60
|
using StopOnRenderCallback = std::function<void(bool isAsync)>;
|
|
60
61
|
using FrameRateListenerCallback = std::function<void(bool /* shouldEnableListener */)>;
|
|
62
|
+
using ResolvePlatformColor = std::function<void(SurfaceId surfaceId, const RawValue &value, SharedColor &result)>;
|
|
61
63
|
|
|
62
64
|
explicit NativeAnimatedNodesManager(
|
|
63
65
|
DirectManipulationCallback &&directManipulationCallback,
|
|
64
66
|
FabricCommitCallback &&fabricCommitCallback,
|
|
67
|
+
ResolvePlatformColor &&resolvePlatformColor,
|
|
65
68
|
StartOnRenderCallback &&startOnRenderCallback = nullptr,
|
|
66
69
|
StopOnRenderCallback &&stopOnRenderCallback = nullptr,
|
|
67
70
|
FrameRateListenerCallback &&frameRateListenerCallback = nullptr) noexcept;
|
|
@@ -70,6 +73,12 @@ class NativeAnimatedNodesManager {
|
|
|
70
73
|
|
|
71
74
|
~NativeAnimatedNodesManager() noexcept;
|
|
72
75
|
|
|
76
|
+
// Non-copyable and non-movable to prevent accidental copies or moves of this resource-heavy manager
|
|
77
|
+
NativeAnimatedNodesManager(const NativeAnimatedNodesManager &) = delete;
|
|
78
|
+
NativeAnimatedNodesManager &operator=(const NativeAnimatedNodesManager &) = delete;
|
|
79
|
+
NativeAnimatedNodesManager(NativeAnimatedNodesManager &&) = delete;
|
|
80
|
+
NativeAnimatedNodesManager &operator=(NativeAnimatedNodesManager &&) = delete;
|
|
81
|
+
|
|
73
82
|
template <typename T, typename = std::enable_if_t<std::is_base_of_v<AnimatedNode, T>>>
|
|
74
83
|
T *getAnimatedNode(Tag tag) const
|
|
75
84
|
requires(std::is_base_of_v<AnimatedNode, T>)
|
|
@@ -93,6 +102,8 @@ class NativeAnimatedNodesManager {
|
|
|
93
102
|
|
|
94
103
|
void connectAnimatedNodeToView(Tag propsNodeTag, Tag viewTag) noexcept;
|
|
95
104
|
|
|
105
|
+
void connectAnimatedNodeToShadowNodeFamily(Tag propsNodeTag, std::shared_ptr<const ShadowNodeFamily> family) noexcept;
|
|
106
|
+
|
|
96
107
|
void disconnectAnimatedNodes(Tag parentTag, Tag childTag) noexcept;
|
|
97
108
|
|
|
98
109
|
void disconnectAnimatedNodeFromView(Tag propsNodeTag, Tag viewTag) noexcept;
|
|
@@ -177,7 +188,7 @@ class NativeAnimatedNodesManager {
|
|
|
177
188
|
|
|
178
189
|
void updateNodes(const std::set<int> &finishedAnimationValueNodes = {}) noexcept;
|
|
179
190
|
|
|
180
|
-
folly::dynamic
|
|
191
|
+
folly::dynamic getManagedProps(Tag tag) const noexcept;
|
|
181
192
|
|
|
182
193
|
bool hasManagedProps() const noexcept;
|
|
183
194
|
|
|
@@ -185,6 +196,8 @@ class NativeAnimatedNodesManager {
|
|
|
185
196
|
|
|
186
197
|
bool isOnRenderThread() const noexcept;
|
|
187
198
|
|
|
199
|
+
void resolvePlatformColor(SurfaceId surfaceId, const RawValue &value, SharedColor &result) const;
|
|
200
|
+
|
|
188
201
|
private:
|
|
189
202
|
void stopRenderCallbackIfNeeded(bool isAsync) noexcept;
|
|
190
203
|
|
|
@@ -233,6 +246,8 @@ class NativeAnimatedNodesManager {
|
|
|
233
246
|
const DirectManipulationCallback directManipulationCallback_;
|
|
234
247
|
const FabricCommitCallback fabricCommitCallback_;
|
|
235
248
|
|
|
249
|
+
const ResolvePlatformColor resolvePlatformColor_;
|
|
250
|
+
|
|
236
251
|
/*
|
|
237
252
|
* Tracks whether the render callback loop for animations is currently active.
|
|
238
253
|
*/
|
|
@@ -246,6 +261,9 @@ class NativeAnimatedNodesManager {
|
|
|
246
261
|
std::unordered_map<Tag, folly::dynamic> updateViewProps_{};
|
|
247
262
|
std::unordered_map<Tag, folly::dynamic> updateViewPropsDirect_{};
|
|
248
263
|
|
|
264
|
+
mutable std::mutex tagToShadowNodeFamilyMutex_;
|
|
265
|
+
std::unordered_map<Tag, std::weak_ptr<const ShadowNodeFamily>> tagToShadowNodeFamily_{};
|
|
266
|
+
|
|
249
267
|
/*
|
|
250
268
|
* Sometimes a view is not longer connected to a PropsAnimatedNode, but
|
|
251
269
|
* NativeAnimated has previously changed the view's props via direct
|
|
@@ -14,6 +14,9 @@
|
|
|
14
14
|
#ifdef RN_USE_ANIMATION_BACKEND
|
|
15
15
|
#include <react/renderer/animationbackend/AnimationBackend.h>
|
|
16
16
|
#endif
|
|
17
|
+
#include <react/renderer/animated/internal/primitives.h>
|
|
18
|
+
#include <react/renderer/components/view/conversions.h>
|
|
19
|
+
#include <react/renderer/scheduler/Scheduler.h>
|
|
17
20
|
#include <react/renderer/uimanager/UIManagerBinding.h>
|
|
18
21
|
|
|
19
22
|
namespace facebook::react {
|
|
@@ -47,29 +50,42 @@ NativeAnimatedNodesManagerProvider::getOrCreate(
|
|
|
47
50
|
if (nativeAnimatedNodesManager_ == nullptr) {
|
|
48
51
|
auto* uiManager = &UIManagerBinding::getBinding(runtime)->getUIManager();
|
|
49
52
|
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
},
|
|
58
|
-
[uiManager](std::unordered_map<Tag, folly::dynamic>&& tagToProps) {
|
|
59
|
-
uiManager->updateShadowTree(std::move(tagToProps));
|
|
60
|
-
});
|
|
53
|
+
mergedValueDispatcher_ = std::make_unique<MergedValueDispatcher>(
|
|
54
|
+
[jsInvoker](std::function<void()>&& func) {
|
|
55
|
+
jsInvoker->invokeAsync(std::move(func));
|
|
56
|
+
},
|
|
57
|
+
[uiManager](std::unordered_map<Tag, folly::dynamic>&& tagToProps) {
|
|
58
|
+
uiManager->updateShadowTree(std::move(tagToProps));
|
|
59
|
+
});
|
|
61
60
|
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
}
|
|
61
|
+
NativeAnimatedNodesManager::FabricCommitCallback fabricCommitCallback =
|
|
62
|
+
[this](std::unordered_map<Tag, folly::dynamic>& tagToProps) {
|
|
63
|
+
mergedValueDispatcher_->dispatch(tagToProps);
|
|
64
|
+
};
|
|
67
65
|
|
|
68
66
|
auto directManipulationCallback =
|
|
69
67
|
[uiManager](Tag viewTag, const folly::dynamic& props) {
|
|
70
68
|
uiManager->synchronouslyUpdateViewOnUIThread(viewTag, props);
|
|
71
69
|
};
|
|
72
70
|
|
|
71
|
+
// TODO: remove force casting.
|
|
72
|
+
auto* scheduler = (Scheduler*)uiManager->getDelegate();
|
|
73
|
+
auto resolvePlatformColor = [scheduler, uiManager](
|
|
74
|
+
SurfaceId surfaceId,
|
|
75
|
+
const RawValue& value,
|
|
76
|
+
SharedColor& result) {
|
|
77
|
+
if (uiManager) {
|
|
78
|
+
if (surfaceId != animated::undefinedAnimatedNodeIdentifier) {
|
|
79
|
+
PropsParserContext propsParserContext{
|
|
80
|
+
surfaceId, *scheduler->getContextContainer()};
|
|
81
|
+
fromRawValue(propsParserContext, value, result);
|
|
82
|
+
} else {
|
|
83
|
+
LOG(ERROR)
|
|
84
|
+
<< "Cannot resolve platformColor because surfaceId is unavailable.";
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
|
|
73
89
|
if (ReactNativeFeatureFlags::useSharedAnimatedBackend()) {
|
|
74
90
|
#ifdef RN_USE_ANIMATION_BACKEND
|
|
75
91
|
// TODO: this should be initialized outside of animated, but for now it
|
|
@@ -80,19 +96,29 @@ NativeAnimatedNodesManagerProvider::getOrCreate(
|
|
|
80
96
|
std::move(directManipulationCallback),
|
|
81
97
|
std::move(fabricCommitCallback),
|
|
82
98
|
uiManager);
|
|
83
|
-
#endif
|
|
84
99
|
|
|
85
100
|
nativeAnimatedNodesManager_ =
|
|
86
101
|
std::make_shared<NativeAnimatedNodesManager>(animationBackend_);
|
|
87
102
|
|
|
103
|
+
nativeAnimatedDelegate_ =
|
|
104
|
+
std::make_shared<UIManagerNativeAnimatedDelegateBackendImpl>(
|
|
105
|
+
animationBackend_);
|
|
106
|
+
|
|
88
107
|
uiManager->unstable_setAnimationBackend(animationBackend_);
|
|
108
|
+
#endif
|
|
89
109
|
} else {
|
|
90
110
|
nativeAnimatedNodesManager_ =
|
|
91
111
|
std::make_shared<NativeAnimatedNodesManager>(
|
|
92
112
|
std::move(directManipulationCallback),
|
|
93
113
|
std::move(fabricCommitCallback),
|
|
114
|
+
std::move(resolvePlatformColor),
|
|
94
115
|
std::move(startOnRenderCallback_),
|
|
95
|
-
std::move(stopOnRenderCallback_)
|
|
116
|
+
std::move(stopOnRenderCallback_),
|
|
117
|
+
std::move(frameRateListenerCallback_));
|
|
118
|
+
|
|
119
|
+
nativeAnimatedDelegate_ =
|
|
120
|
+
std::make_shared<UIManagerNativeAnimatedDelegateImpl>(
|
|
121
|
+
nativeAnimatedNodesManager_);
|
|
96
122
|
}
|
|
97
123
|
|
|
98
124
|
addEventEmitterListener(
|
|
@@ -117,36 +143,32 @@ NativeAnimatedNodesManagerProvider::getOrCreate(
|
|
|
117
143
|
return false;
|
|
118
144
|
}));
|
|
119
145
|
|
|
120
|
-
nativeAnimatedDelegate_ =
|
|
121
|
-
std::make_shared<UIManagerNativeAnimatedDelegateImpl>(
|
|
122
|
-
nativeAnimatedNodesManager_);
|
|
123
|
-
|
|
124
146
|
uiManager->setNativeAnimatedDelegate(nativeAnimatedDelegate_);
|
|
125
147
|
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
148
|
+
if (!ReactNativeFeatureFlags::useSharedAnimatedBackend()) {
|
|
149
|
+
animatedMountingOverrideDelegate_ =
|
|
150
|
+
std::make_shared<AnimatedMountingOverrideDelegate>(
|
|
151
|
+
*nativeAnimatedNodesManager_, *scheduler);
|
|
152
|
+
|
|
153
|
+
// Register on existing surfaces
|
|
154
|
+
uiManager->getShadowTreeRegistry().enumerate(
|
|
155
|
+
[animatedMountingOverrideDelegate =
|
|
156
|
+
std::weak_ptr<const AnimatedMountingOverrideDelegate>(
|
|
157
|
+
animatedMountingOverrideDelegate_)](
|
|
158
|
+
const ShadowTree& shadowTree, bool& /*stop*/) {
|
|
159
|
+
shadowTree.getMountingCoordinator()->setMountingOverrideDelegate(
|
|
160
|
+
animatedMountingOverrideDelegate);
|
|
161
|
+
});
|
|
162
|
+
// Register on surfaces started in the future
|
|
163
|
+
uiManager->setOnSurfaceStartCallback(
|
|
164
|
+
[animatedMountingOverrideDelegate =
|
|
165
|
+
std::weak_ptr<const AnimatedMountingOverrideDelegate>(
|
|
166
|
+
animatedMountingOverrideDelegate_)](
|
|
167
|
+
const ShadowTree& shadowTree) {
|
|
168
|
+
shadowTree.getMountingCoordinator()->setMountingOverrideDelegate(
|
|
169
|
+
animatedMountingOverrideDelegate);
|
|
170
|
+
});
|
|
171
|
+
}
|
|
150
172
|
}
|
|
151
173
|
return nativeAnimatedNodesManager_;
|
|
152
174
|
}
|
|
@@ -43,6 +43,7 @@ void FrameAnimationDriver::updateConfig(folly::dynamic config) {
|
|
|
43
43
|
void FrameAnimationDriver::onConfigChanged() {
|
|
44
44
|
auto frames = config_["frames"];
|
|
45
45
|
react_native_assert(frames.type() == folly::dynamic::ARRAY);
|
|
46
|
+
frames_.clear();
|
|
46
47
|
for (const auto& frame : frames) {
|
|
47
48
|
auto frameValue = frame.asDouble();
|
|
48
49
|
frames_.push_back(frameValue);
|
|
@@ -40,7 +40,7 @@ AnimatedMountingOverrideDelegate::pullTransaction(
|
|
|
40
40
|
for (const auto& mutation : mutations) {
|
|
41
41
|
if (mutation.type == ShadowViewMutation::Update) {
|
|
42
42
|
const auto tag = mutation.newChildShadowView.tag;
|
|
43
|
-
auto props = animatedManager_->
|
|
43
|
+
auto props = animatedManager_->getManagedProps(tag);
|
|
44
44
|
if (!props.isNull()) {
|
|
45
45
|
animatedManagedProps.insert({tag, std::move(props)});
|
|
46
46
|
}
|