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
|
@@ -7,6 +7,30 @@
|
|
|
7
7
|
|
|
8
8
|
#import "RCTNativeSampleTurboModuleSpec.h"
|
|
9
9
|
|
|
10
|
+
@implementation NativeSampleTurboModuleSpecBase
|
|
11
|
+
- (void)emitOnPress
|
|
12
|
+
{
|
|
13
|
+
_eventEmitterCallback("onPress", nil);
|
|
14
|
+
}
|
|
15
|
+
- (void)emitOnClick:(NSString *_Nonnull)value
|
|
16
|
+
{
|
|
17
|
+
_eventEmitterCallback("onClick", value);
|
|
18
|
+
}
|
|
19
|
+
- (void)emitOnChange:(NSDictionary *)value
|
|
20
|
+
{
|
|
21
|
+
_eventEmitterCallback("onChange", value);
|
|
22
|
+
}
|
|
23
|
+
- (void)emitOnSubmit:(NSArray<id<NSObject>> *)value
|
|
24
|
+
{
|
|
25
|
+
_eventEmitterCallback("onSubmit", value);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
- (void)setEventEmitterCallback:(EventEmitterCallbackWrapper *)eventEmitterCallbackWrapper
|
|
29
|
+
{
|
|
30
|
+
_eventEmitterCallback = std::move(eventEmitterCallbackWrapper->_eventEmitterCallback);
|
|
31
|
+
}
|
|
32
|
+
@end
|
|
33
|
+
|
|
10
34
|
namespace facebook::react {
|
|
11
35
|
|
|
12
36
|
static facebook::jsi::Value __hostFunction_NativeSampleTurboModuleSpecJSI_voidFunc(
|
|
@@ -190,6 +214,16 @@ static facebook::jsi::Value __hostFunction_NativeSampleTurboModuleSpecJSI_promis
|
|
|
190
214
|
.invokeObjCMethod(rt, PromiseKind, "promiseAssert", @selector(promiseAssert:reject:), args, count);
|
|
191
215
|
}
|
|
192
216
|
|
|
217
|
+
static facebook::jsi::Value __hostFunction_NativeSampleTurboModuleSpecJSI_getImageUrl(
|
|
218
|
+
facebook::jsi::Runtime &rt,
|
|
219
|
+
TurboModule &turboModule,
|
|
220
|
+
const facebook::jsi::Value *args,
|
|
221
|
+
size_t count)
|
|
222
|
+
{
|
|
223
|
+
return static_cast<ObjCTurboModule &>(turboModule)
|
|
224
|
+
.invokeObjCMethod(rt, PromiseKind, "getImageUrl", @selector(getImageUrl:reject:), args, count);
|
|
225
|
+
}
|
|
226
|
+
|
|
193
227
|
static facebook::jsi::Value __hostFunction_NativeSampleTurboModuleSpecJSI_getConstants(
|
|
194
228
|
facebook::jsi::Runtime &rt,
|
|
195
229
|
TurboModule &turboModule,
|
|
@@ -203,44 +237,48 @@ static facebook::jsi::Value __hostFunction_NativeSampleTurboModuleSpecJSI_getCon
|
|
|
203
237
|
NativeSampleTurboModuleSpecJSI::NativeSampleTurboModuleSpecJSI(const ObjCTurboModule::InitParams ¶ms)
|
|
204
238
|
: ObjCTurboModule(params)
|
|
205
239
|
{
|
|
206
|
-
methodMap_["voidFunc"] =
|
|
207
|
-
|
|
208
|
-
methodMap_["getBool"] =
|
|
209
|
-
|
|
210
|
-
methodMap_["getEnum"] =
|
|
211
|
-
|
|
212
|
-
methodMap_["getNumber"] =
|
|
213
|
-
|
|
214
|
-
methodMap_["getString"] =
|
|
215
|
-
|
|
216
|
-
methodMap_["getArray"] =
|
|
217
|
-
|
|
218
|
-
methodMap_["getObject"] =
|
|
219
|
-
|
|
220
|
-
methodMap_["getUnsafeObject"] =
|
|
221
|
-
|
|
222
|
-
methodMap_["getRootTag"] =
|
|
223
|
-
|
|
224
|
-
methodMap_["getValue"] =
|
|
225
|
-
|
|
240
|
+
methodMap_["voidFunc"] = MethodMetadata{0, __hostFunction_NativeSampleTurboModuleSpecJSI_voidFunc};
|
|
241
|
+
|
|
242
|
+
methodMap_["getBool"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getBool};
|
|
243
|
+
|
|
244
|
+
methodMap_["getEnum"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getEnum};
|
|
245
|
+
|
|
246
|
+
methodMap_["getNumber"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getNumber};
|
|
247
|
+
|
|
248
|
+
methodMap_["getString"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getString};
|
|
249
|
+
|
|
250
|
+
methodMap_["getArray"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getArray};
|
|
251
|
+
|
|
252
|
+
methodMap_["getObject"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getObject};
|
|
253
|
+
|
|
254
|
+
methodMap_["getUnsafeObject"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getUnsafeObject};
|
|
255
|
+
|
|
256
|
+
methodMap_["getRootTag"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getRootTag};
|
|
257
|
+
|
|
258
|
+
methodMap_["getValue"] = MethodMetadata{3, __hostFunction_NativeSampleTurboModuleSpecJSI_getValue};
|
|
259
|
+
|
|
226
260
|
methodMap_["getValueWithCallback"] =
|
|
227
|
-
MethodMetadata{
|
|
261
|
+
MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getValueWithCallback};
|
|
262
|
+
|
|
228
263
|
methodMap_["getValueWithPromise"] =
|
|
229
|
-
MethodMetadata{
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
264
|
+
MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getValueWithPromise};
|
|
265
|
+
|
|
266
|
+
methodMap_["voidFuncThrows"] = MethodMetadata{0, __hostFunction_NativeSampleTurboModuleSpecJSI_voidFuncThrows};
|
|
267
|
+
|
|
268
|
+
methodMap_["getObjectThrows"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getObjectThrows};
|
|
269
|
+
|
|
270
|
+
methodMap_["promiseThrows"] = MethodMetadata{0, __hostFunction_NativeSampleTurboModuleSpecJSI_promiseThrows};
|
|
271
|
+
|
|
272
|
+
methodMap_["voidFuncAssert"] = MethodMetadata{0, __hostFunction_NativeSampleTurboModuleSpecJSI_voidFuncAssert};
|
|
273
|
+
|
|
274
|
+
methodMap_["getObjectAssert"] = MethodMetadata{1, __hostFunction_NativeSampleTurboModuleSpecJSI_getObjectAssert};
|
|
275
|
+
|
|
276
|
+
methodMap_["promiseAssert"] = MethodMetadata{0, __hostFunction_NativeSampleTurboModuleSpecJSI_promiseAssert};
|
|
277
|
+
|
|
278
|
+
methodMap_["getImageUrl"] = MethodMetadata{0, __hostFunction_NativeSampleTurboModuleSpecJSI_getImageUrl};
|
|
279
|
+
|
|
280
|
+
methodMap_["getConstants"] = MethodMetadata{0, __hostFunction_NativeSampleTurboModuleSpecJSI_getConstants};
|
|
281
|
+
|
|
244
282
|
eventEmitterMap_["onPress"] = std::make_shared<AsyncEventEmitter<id>>();
|
|
245
283
|
eventEmitterMap_["onClick"] = std::make_shared<AsyncEventEmitter<id>>();
|
|
246
284
|
eventEmitterMap_["onChange"] = std::make_shared<AsyncEventEmitter<id>>();
|
|
@@ -249,32 +287,4 @@ NativeSampleTurboModuleSpecJSI::NativeSampleTurboModuleSpecJSI(const ObjCTurboMo
|
|
|
249
287
|
static_cast<AsyncEventEmitter<id> &>(*eventEmitterMap_[name]).emit(value);
|
|
250
288
|
});
|
|
251
289
|
}
|
|
252
|
-
|
|
253
290
|
} // namespace facebook::react
|
|
254
|
-
|
|
255
|
-
@implementation NativeSampleTurboModuleSpecBase
|
|
256
|
-
- (void)setEventEmitterCallback:(EventEmitterCallbackWrapper *_Nonnull)eventEmitterCallbackWrapper
|
|
257
|
-
{
|
|
258
|
-
_eventEmitterCallback = std::move(eventEmitterCallbackWrapper->_eventEmitterCallback);
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
- (void)emitOnPress
|
|
262
|
-
{
|
|
263
|
-
_eventEmitterCallback("onPress", nil);
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
- (void)emitOnClick:(NSString *)value
|
|
267
|
-
{
|
|
268
|
-
_eventEmitterCallback("onClick", value);
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
- (void)emitOnChange:(NSDictionary *)value
|
|
272
|
-
{
|
|
273
|
-
_eventEmitterCallback("onChange", value);
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
- (void)emitOnSubmit:(NSArray *)value
|
|
277
|
-
{
|
|
278
|
-
_eventEmitterCallback("onSubmit", value);
|
|
279
|
-
}
|
|
280
|
-
@end
|
package/ReactCommon/react/nativemodule/samples/platform/ios/ReactCommon/RCTSampleTurboModule.mm
CHANGED
|
@@ -20,7 +20,7 @@ using namespace facebook::react;
|
|
|
20
20
|
@end
|
|
21
21
|
|
|
22
22
|
@implementation RCTSampleTurboModule {
|
|
23
|
-
|
|
23
|
+
facebook::react::ModuleConstants<JS::NativeSampleTurboModule::Constants> _constants;
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
// Backward-compatible export
|
|
@@ -37,11 +37,11 @@ RCT_EXPORT_MODULE()
|
|
|
37
37
|
UIScreen *mainScreen = UIScreen.mainScreen;
|
|
38
38
|
CGSize screenSize = mainScreen.bounds.size;
|
|
39
39
|
|
|
40
|
-
_constants =
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
};
|
|
40
|
+
_constants = facebook::react::typedConstants<JS::NativeSampleTurboModule::Constants>({
|
|
41
|
+
.const1 = YES,
|
|
42
|
+
.const2 = screenSize.width,
|
|
43
|
+
.const3 = @"something",
|
|
44
|
+
});
|
|
45
45
|
}
|
|
46
46
|
|
|
47
47
|
- (dispatch_queue_t)methodQueue
|
|
@@ -62,15 +62,19 @@ RCT_EXPORT_MODULE()
|
|
|
62
62
|
NSLog(@"Invalidating RCTSampleTurboModule...");
|
|
63
63
|
}
|
|
64
64
|
|
|
65
|
-
- (
|
|
65
|
+
- (facebook::react::ModuleConstants<JS::NativeSampleTurboModule::Constants>)constantsToExport
|
|
66
|
+
{
|
|
67
|
+
return _constants;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
- (facebook::react::ModuleConstants<JS::NativeSampleTurboModule::Constants>)getConstants
|
|
66
71
|
{
|
|
67
72
|
return _constants;
|
|
68
73
|
}
|
|
69
74
|
|
|
70
|
-
|
|
71
|
-
- (NSDictionary *)constantsToExport
|
|
75
|
+
- (void)getImageUrl:(RCTPromiseResolveBlock)resolve reject:(RCTPromiseRejectBlock)reject
|
|
72
76
|
{
|
|
73
|
-
|
|
77
|
+
reject(@"Exception", @"Not implemented", nil);
|
|
74
78
|
}
|
|
75
79
|
|
|
76
80
|
#pragma mark - RCTTurboModuleWithJSIBindings
|
|
@@ -168,7 +172,7 @@ RCT_EXPORT_METHOD(
|
|
|
168
172
|
|
|
169
173
|
RCT_EXPORT_METHOD(voidFuncThrows)
|
|
170
174
|
{
|
|
171
|
-
NSException *myException = [NSException exceptionWithName:@"
|
|
175
|
+
NSException *myException = [NSException exceptionWithName:@"Exception"
|
|
172
176
|
reason:@"Intentional exception from ObjC voidFuncThrows"
|
|
173
177
|
userInfo:nil];
|
|
174
178
|
@throw myException;
|
|
@@ -176,7 +180,7 @@ RCT_EXPORT_METHOD(voidFuncThrows)
|
|
|
176
180
|
|
|
177
181
|
RCT_EXPORT_SYNCHRONOUS_TYPED_METHOD(NSDictionary *, getObjectThrows : (NSDictionary *)arg)
|
|
178
182
|
{
|
|
179
|
-
NSException *myException = [NSException exceptionWithName:@"
|
|
183
|
+
NSException *myException = [NSException exceptionWithName:@"Exception"
|
|
180
184
|
reason:@"Intentional exception from ObjC getObjectThrows"
|
|
181
185
|
userInfo:nil];
|
|
182
186
|
@throw myException;
|
|
@@ -184,7 +188,7 @@ RCT_EXPORT_SYNCHRONOUS_TYPED_METHOD(NSDictionary *, getObjectThrows : (NSDiction
|
|
|
184
188
|
|
|
185
189
|
RCT_EXPORT_METHOD(promiseThrows : (RCTPromiseResolveBlock)resolve reject : (RCTPromiseRejectBlock)reject)
|
|
186
190
|
{
|
|
187
|
-
NSException *myException = [NSException exceptionWithName:@"
|
|
191
|
+
NSException *myException = [NSException exceptionWithName:@"Exception"
|
|
188
192
|
reason:@"Intentional exception from ObjC promiseThrows"
|
|
189
193
|
userInfo:nil];
|
|
190
194
|
@throw myException;
|
|
@@ -13,7 +13,6 @@
|
|
|
13
13
|
#include <jsinspector-modern/tracing/PerformanceTracer.h>
|
|
14
14
|
#endif
|
|
15
15
|
#include <jsinspector-modern/network/HttpUtils.h>
|
|
16
|
-
#include <react/featureflags/ReactNativeFeatureFlags.h>
|
|
17
16
|
#include <react/performance/timeline/PerformanceEntryReporter.h>
|
|
18
17
|
|
|
19
18
|
namespace facebook::react {
|
|
@@ -169,9 +168,16 @@ void NetworkReporter::reportDataReceived(
|
|
|
169
168
|
int dataLength,
|
|
170
169
|
const std::optional<int>& encodedDataLength) {
|
|
171
170
|
#ifdef REACT_NATIVE_DEBUGGER_ENABLED
|
|
171
|
+
auto now = HighResTimeStamp::now();
|
|
172
|
+
|
|
172
173
|
// Debugger enabled: CDP event handling
|
|
173
174
|
jsinspector_modern::NetworkHandler::getInstance().onDataReceived(
|
|
174
175
|
requestId, dataLength, encodedDataLength.value_or(dataLength));
|
|
176
|
+
|
|
177
|
+
// Debugger enabled: Add trace event to Performance timeline
|
|
178
|
+
jsinspector_modern::tracing::PerformanceTracer::getInstance()
|
|
179
|
+
.reportResourceReceivedData(
|
|
180
|
+
requestId, now, encodedDataLength.value_or(dataLength));
|
|
175
181
|
#endif
|
|
176
182
|
}
|
|
177
183
|
|
|
@@ -180,27 +186,25 @@ void NetworkReporter::reportResponseEnd(
|
|
|
180
186
|
int encodedDataLength) {
|
|
181
187
|
auto now = HighResTimeStamp::now();
|
|
182
188
|
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
perfTimingsBuffer_.erase(requestId);
|
|
203
|
-
}
|
|
189
|
+
// All builds: Report PerformanceResourceTiming event
|
|
190
|
+
{
|
|
191
|
+
std::lock_guard<std::mutex> lock(perfTimingsMutex_);
|
|
192
|
+
auto it = perfTimingsBuffer_.find(requestId);
|
|
193
|
+
if (it != perfTimingsBuffer_.end()) {
|
|
194
|
+
auto& eventData = it->second;
|
|
195
|
+
PerformanceEntryReporter::getInstance()->reportResourceTiming(
|
|
196
|
+
eventData.url,
|
|
197
|
+
eventData.fetchStart,
|
|
198
|
+
eventData.requestStart,
|
|
199
|
+
eventData.connectStart.value_or(now),
|
|
200
|
+
eventData.connectEnd.value_or(now),
|
|
201
|
+
eventData.responseStart.value_or(now),
|
|
202
|
+
now,
|
|
203
|
+
eventData.responseStatus,
|
|
204
|
+
eventData.contentType,
|
|
205
|
+
eventData.encodedBodySize,
|
|
206
|
+
eventData.decodedBodySize);
|
|
207
|
+
perfTimingsBuffer_.erase(requestId);
|
|
204
208
|
}
|
|
205
209
|
}
|
|
206
210
|
|
|
@@ -41,7 +41,6 @@ Pod::Spec.new do |s|
|
|
|
41
41
|
s.module_name = "React_networking"
|
|
42
42
|
s.header_mappings_dir = "../.."
|
|
43
43
|
end
|
|
44
|
-
add_dependency(s, "React-featureflags")
|
|
45
44
|
add_dependency(s, "React-jsinspectornetwork", :framework_name => 'jsinspector_modernnetwork')
|
|
46
45
|
add_dependency(s, "React-jsinspectortracing", :framework_name => 'jsinspector_moderntracing')
|
|
47
46
|
s.dependency "React-performancetimeline"
|
|
@@ -42,8 +42,10 @@ void CdpPerfIssuesReporter::onMeasureEntry(
|
|
|
42
42
|
return;
|
|
43
43
|
}
|
|
44
44
|
|
|
45
|
-
if (detail.count("
|
|
46
|
-
|
|
45
|
+
if (detail.count("devtools") != 0 && detail["devtools"].isObject() &&
|
|
46
|
+
detail["devtools"].count("performanceIssue") != 0 &&
|
|
47
|
+
detail["devtools"]["performanceIssue"].isObject()) {
|
|
48
|
+
auto& perfIssue = detail["devtools"]["performanceIssue"];
|
|
47
49
|
|
|
48
50
|
if (perfIssue.count("name") != 0 && perfIssue.count("severity") != 0 &&
|
|
49
51
|
perfIssue.count("description") != 0) {
|
|
@@ -16,6 +16,7 @@ target_compile_options(react_performance_timeline PRIVATE -Wpedantic)
|
|
|
16
16
|
|
|
17
17
|
target_include_directories(react_performance_timeline PUBLIC ${REACT_COMMON_DIR})
|
|
18
18
|
target_link_libraries(react_performance_timeline
|
|
19
|
+
jsinspector
|
|
19
20
|
jsinspector_tracing
|
|
20
21
|
reactperflogger
|
|
21
22
|
react_featureflags
|
|
@@ -7,6 +7,7 @@
|
|
|
7
7
|
|
|
8
8
|
#include "PerformanceEntryReporter.h"
|
|
9
9
|
|
|
10
|
+
#include <jsinspector-modern/ConsoleTaskOrchestrator.h>
|
|
10
11
|
#include <jsinspector-modern/tracing/PerformanceTracer.h>
|
|
11
12
|
#include <react/featureflags/ReactNativeFeatureFlags.h>
|
|
12
13
|
#include <react/timing/primitives.h>
|
|
@@ -30,7 +31,7 @@ std::vector<PerformanceEntryType> getSupportedEntryTypesInternal() {
|
|
|
30
31
|
PerformanceEntryType::LONGTASK,
|
|
31
32
|
};
|
|
32
33
|
|
|
33
|
-
if (ReactNativeFeatureFlags::
|
|
34
|
+
if (ReactNativeFeatureFlags::enableNetworkEventReporting()) {
|
|
34
35
|
supportedEntryTypes.emplace_back(PerformanceEntryType::RESOURCE);
|
|
35
36
|
}
|
|
36
37
|
|
|
@@ -381,8 +382,15 @@ void PerformanceEntryReporter::traceMeasure(
|
|
|
381
382
|
}
|
|
382
383
|
|
|
383
384
|
if (performanceTracer.isTracing()) {
|
|
385
|
+
auto taskContext =
|
|
386
|
+
jsinspector_modern::ConsoleTaskOrchestrator::getInstance().top();
|
|
387
|
+
|
|
384
388
|
performanceTracer.reportMeasure(
|
|
385
|
-
entry.name,
|
|
389
|
+
entry.name,
|
|
390
|
+
entry.startTime,
|
|
391
|
+
entry.duration,
|
|
392
|
+
std::move(detail),
|
|
393
|
+
taskContext ? taskContext->getSerializedStackTrace() : nullptr);
|
|
386
394
|
}
|
|
387
395
|
}
|
|
388
396
|
}
|
|
@@ -41,6 +41,7 @@ Pod::Spec.new do |s|
|
|
|
41
41
|
resolve_use_frameworks(s, header_mappings_dir: "../../..", module_name: "React_performancetimeline")
|
|
42
42
|
|
|
43
43
|
s.dependency "React-featureflags"
|
|
44
|
+
add_dependency(s, "React-jsinspector", :framework_name => 'jsinspector_modern')
|
|
44
45
|
add_dependency(s, "React-jsinspectortracing", :framework_name => 'jsinspector_moderntracing')
|
|
45
46
|
s.dependency "React-timing"
|
|
46
47
|
s.dependency "React-perflogger"
|
|
@@ -9,9 +9,9 @@
|
|
|
9
9
|
|
|
10
10
|
#include <glog/logging.h>
|
|
11
11
|
#include <jsi/JSIDynamic.h>
|
|
12
|
+
#include <react/renderer/bridging/bridging.h>
|
|
12
13
|
|
|
13
14
|
namespace facebook::react {
|
|
14
|
-
|
|
15
15
|
AnimatedModule::AnimatedModule(
|
|
16
16
|
std::shared_ptr<CallInvoker> jsInvoker,
|
|
17
17
|
std::shared_ptr<NativeAnimatedNodesManagerProvider> nodesManagerProvider)
|
|
@@ -27,17 +27,18 @@ void AnimatedModule::finishOperationBatch(jsi::Runtime& /*rt*/) {
|
|
|
27
27
|
std::swap(preOperations_, preOperations);
|
|
28
28
|
std::swap(operations_, operations);
|
|
29
29
|
|
|
30
|
-
if (nodesManager_) {
|
|
30
|
+
if (auto nodesManager = nodesManager_.lock()) {
|
|
31
31
|
// TODO: nodesManager_ must exist at all times. But without this check
|
|
32
32
|
// AnimatedProps-itest.js fails.
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
33
|
+
nodesManager->scheduleOnUI([this,
|
|
34
|
+
preOperations = std::move(preOperations),
|
|
35
|
+
operations = std::move(operations),
|
|
36
|
+
nodesManager = nodesManager_]() {
|
|
36
37
|
for (auto& preOperation : preOperations) {
|
|
37
|
-
executeOperation(preOperation);
|
|
38
|
+
executeOperation(preOperation, nodesManager);
|
|
38
39
|
}
|
|
39
40
|
for (auto& operation : operations) {
|
|
40
|
-
executeOperation(operation);
|
|
41
|
+
executeOperation(operation, nodesManager);
|
|
41
42
|
}
|
|
42
43
|
});
|
|
43
44
|
}
|
|
@@ -50,8 +51,8 @@ void AnimatedModule::createAnimatedNode(
|
|
|
50
51
|
auto configDynamic = dynamicFromValue(rt, jsi::Value(rt, config));
|
|
51
52
|
if (auto it = configDynamic.find("disableBatchingForNativeCreate");
|
|
52
53
|
it != configDynamic.items().end() && it->second == true) {
|
|
53
|
-
if (nodesManager_) {
|
|
54
|
-
|
|
54
|
+
if (auto nodesManager = nodesManager_.lock()) {
|
|
55
|
+
nodesManager->createAnimatedNodeAsync(tag, configDynamic);
|
|
55
56
|
}
|
|
56
57
|
} else {
|
|
57
58
|
operations_.emplace_back(
|
|
@@ -159,6 +160,19 @@ void AnimatedModule::connectAnimatedNodeToView(
|
|
|
159
160
|
ConnectAnimatedNodeToViewOp{.nodeTag = nodeTag, .viewTag = viewTag});
|
|
160
161
|
}
|
|
161
162
|
|
|
163
|
+
void AnimatedModule::connectAnimatedNodeToShadowNodeFamily(
|
|
164
|
+
jsi::Runtime& rt,
|
|
165
|
+
Tag nodeTag,
|
|
166
|
+
jsi::Object shadowNodeObj) {
|
|
167
|
+
const auto& shadowNode = Bridging<std::shared_ptr<const ShadowNode>>::fromJs(
|
|
168
|
+
rt, jsi::Value(rt, shadowNodeObj));
|
|
169
|
+
|
|
170
|
+
operations_.emplace_back(
|
|
171
|
+
ConnectAnimatedNodeToShadowNodeFamilyOp{
|
|
172
|
+
.nodeTag = nodeTag,
|
|
173
|
+
.shadowNodeFamily = shadowNode->getFamilyShared()});
|
|
174
|
+
}
|
|
175
|
+
|
|
162
176
|
void AnimatedModule::disconnectAnimatedNodeFromView(
|
|
163
177
|
jsi::Runtime& /*rt*/,
|
|
164
178
|
Tag nodeTag,
|
|
@@ -220,76 +234,88 @@ void AnimatedModule::queueAndExecuteBatchedOperations(
|
|
|
220
234
|
// TODO(T225953475): missing implementation
|
|
221
235
|
}
|
|
222
236
|
|
|
223
|
-
void AnimatedModule::executeOperation(
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
237
|
+
void AnimatedModule::executeOperation(
|
|
238
|
+
const Operation& operation,
|
|
239
|
+
std::weak_ptr<NativeAnimatedNodesManager> nodesManagerWeak) {
|
|
240
|
+
if (auto nodesManager = nodesManagerWeak.lock()) {
|
|
241
|
+
std::visit(
|
|
242
|
+
[&](const auto& op) {
|
|
243
|
+
using T = std::decay_t<decltype(op)>;
|
|
244
|
+
|
|
245
|
+
if constexpr (std::is_same_v<T, CreateAnimatedNodeOp>) {
|
|
246
|
+
nodesManager->createAnimatedNode(op.tag, op.config);
|
|
247
|
+
} else if constexpr (std::is_same_v<T, GetValueOp>) {
|
|
248
|
+
auto animValue = nodesManager->getValue(op.tag);
|
|
249
|
+
if (animValue) {
|
|
250
|
+
op.callback.call(animValue.value());
|
|
251
|
+
}
|
|
252
|
+
} else if constexpr (std::is_same_v<
|
|
253
|
+
T,
|
|
254
|
+
StartListeningToAnimatedNodeValueOp>) {
|
|
255
|
+
nodesManager->startListeningToAnimatedNodeValue(
|
|
256
|
+
op.tag, [this, tag = op.tag](double value) {
|
|
257
|
+
emitDeviceEvent(
|
|
258
|
+
"onAnimatedValueUpdate",
|
|
259
|
+
[tag, value](
|
|
260
|
+
jsi::Runtime& rt, std::vector<jsi::Value>& args) {
|
|
261
|
+
auto arg = jsi::Object(rt);
|
|
262
|
+
arg.setProperty(rt, "tag", jsi::Value(tag));
|
|
263
|
+
arg.setProperty(rt, "value", jsi::Value(value));
|
|
264
|
+
args.emplace_back(rt, arg);
|
|
265
|
+
});
|
|
266
|
+
});
|
|
267
|
+
} else if constexpr (std::is_same_v<
|
|
268
|
+
T,
|
|
269
|
+
StopListeningToAnimatedNodeValueOp>) {
|
|
270
|
+
nodesManager->stopListeningToAnimatedNodeValue(op.tag);
|
|
271
|
+
} else if constexpr (std::is_same_v<T, ConnectAnimatedNodesOp>) {
|
|
272
|
+
nodesManager->connectAnimatedNodes(op.parentTag, op.childTag);
|
|
273
|
+
} else if constexpr (std::is_same_v<T, DisconnectAnimatedNodesOp>) {
|
|
274
|
+
nodesManager->disconnectAnimatedNodes(op.parentTag, op.childTag);
|
|
275
|
+
} else if constexpr (std::is_same_v<T, StartAnimatingNodeOp>) {
|
|
276
|
+
nodesManager->startAnimatingNode(
|
|
277
|
+
op.animationId,
|
|
278
|
+
op.nodeTag,
|
|
279
|
+
std::move(op.config),
|
|
280
|
+
std::move(op.endCallback));
|
|
281
|
+
} else if constexpr (std::is_same_v<T, StopAnimationOp>) {
|
|
282
|
+
nodesManager->stopAnimation(op.animationId, false);
|
|
283
|
+
} else if constexpr (std::is_same_v<T, SetAnimatedNodeValueOp>) {
|
|
284
|
+
nodesManager->setAnimatedNodeValue(op.nodeTag, op.value);
|
|
285
|
+
} else if constexpr (std::is_same_v<T, SetAnimatedNodeOffsetOp>) {
|
|
286
|
+
nodesManager->setAnimatedNodeOffset(op.nodeTag, op.offset);
|
|
287
|
+
} else if constexpr (std::is_same_v<T, FlattenAnimatedNodeOffsetOp>) {
|
|
288
|
+
nodesManager->flattenAnimatedNodeOffset(op.nodeTag);
|
|
289
|
+
} else if constexpr (std::is_same_v<T, ExtractAnimatedNodeOffsetOp>) {
|
|
290
|
+
nodesManager->extractAnimatedNodeOffsetOp(op.nodeTag);
|
|
291
|
+
} else if constexpr (std::is_same_v<T, ConnectAnimatedNodeToViewOp>) {
|
|
292
|
+
nodesManager->connectAnimatedNodeToView(op.nodeTag, op.viewTag);
|
|
293
|
+
} else if constexpr (std::is_same_v<
|
|
294
|
+
T,
|
|
295
|
+
DisconnectAnimatedNodeFromViewOp>) {
|
|
296
|
+
nodesManager->disconnectAnimatedNodeFromView(
|
|
297
|
+
op.nodeTag, op.viewTag);
|
|
298
|
+
} else if constexpr (std::is_same_v<
|
|
299
|
+
T,
|
|
300
|
+
ConnectAnimatedNodeToShadowNodeFamilyOp>) {
|
|
301
|
+
nodesManager->connectAnimatedNodeToShadowNodeFamily(
|
|
302
|
+
op.nodeTag, op.shadowNodeFamily);
|
|
303
|
+
} else if constexpr (std::is_same_v<T, RestoreDefaultValuesOp>) {
|
|
304
|
+
nodesManager->restoreDefaultValues(op.nodeTag);
|
|
305
|
+
} else if constexpr (std::is_same_v<T, DropAnimatedNodeOp>) {
|
|
306
|
+
nodesManager->dropAnimatedNode(op.tag);
|
|
307
|
+
} else if constexpr (std::is_same_v<T, AddAnimatedEventToViewOp>) {
|
|
308
|
+
nodesManager->addAnimatedEventToView(
|
|
309
|
+
op.viewTag, op.eventName, op.eventMapping);
|
|
310
|
+
} else if constexpr (std::is_same_v<
|
|
311
|
+
T,
|
|
312
|
+
RemoveAnimatedEventFromViewOp>) {
|
|
313
|
+
nodesManager->removeAnimatedEventFromView(
|
|
314
|
+
op.viewTag, op.eventName, op.animatedNodeTag);
|
|
234
315
|
}
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
nodesManager_->startListeningToAnimatedNodeValue(
|
|
239
|
-
op.tag, [this, tag = op.tag](double value) {
|
|
240
|
-
emitDeviceEvent(
|
|
241
|
-
"onAnimatedValueUpdate",
|
|
242
|
-
[tag, value](
|
|
243
|
-
jsi::Runtime& rt, std::vector<jsi::Value>& args) {
|
|
244
|
-
auto arg = jsi::Object(rt);
|
|
245
|
-
arg.setProperty(rt, "tag", jsi::Value(tag));
|
|
246
|
-
arg.setProperty(rt, "value", jsi::Value(value));
|
|
247
|
-
args.emplace_back(rt, arg);
|
|
248
|
-
});
|
|
249
|
-
});
|
|
250
|
-
} else if constexpr (std::is_same_v<
|
|
251
|
-
T,
|
|
252
|
-
StopListeningToAnimatedNodeValueOp>) {
|
|
253
|
-
nodesManager_->stopListeningToAnimatedNodeValue(op.tag);
|
|
254
|
-
} else if constexpr (std::is_same_v<T, ConnectAnimatedNodesOp>) {
|
|
255
|
-
nodesManager_->connectAnimatedNodes(op.parentTag, op.childTag);
|
|
256
|
-
} else if constexpr (std::is_same_v<T, DisconnectAnimatedNodesOp>) {
|
|
257
|
-
nodesManager_->disconnectAnimatedNodes(op.parentTag, op.childTag);
|
|
258
|
-
} else if constexpr (std::is_same_v<T, StartAnimatingNodeOp>) {
|
|
259
|
-
nodesManager_->startAnimatingNode(
|
|
260
|
-
op.animationId,
|
|
261
|
-
op.nodeTag,
|
|
262
|
-
std::move(op.config),
|
|
263
|
-
std::move(op.endCallback));
|
|
264
|
-
} else if constexpr (std::is_same_v<T, StopAnimationOp>) {
|
|
265
|
-
nodesManager_->stopAnimation(op.animationId, false);
|
|
266
|
-
} else if constexpr (std::is_same_v<T, SetAnimatedNodeValueOp>) {
|
|
267
|
-
nodesManager_->setAnimatedNodeValue(op.nodeTag, op.value);
|
|
268
|
-
} else if constexpr (std::is_same_v<T, SetAnimatedNodeOffsetOp>) {
|
|
269
|
-
nodesManager_->setAnimatedNodeOffset(op.nodeTag, op.offset);
|
|
270
|
-
} else if constexpr (std::is_same_v<T, FlattenAnimatedNodeOffsetOp>) {
|
|
271
|
-
nodesManager_->flattenAnimatedNodeOffset(op.nodeTag);
|
|
272
|
-
} else if constexpr (std::is_same_v<T, ExtractAnimatedNodeOffsetOp>) {
|
|
273
|
-
nodesManager_->extractAnimatedNodeOffsetOp(op.nodeTag);
|
|
274
|
-
} else if constexpr (std::is_same_v<T, ConnectAnimatedNodeToViewOp>) {
|
|
275
|
-
nodesManager_->connectAnimatedNodeToView(op.nodeTag, op.viewTag);
|
|
276
|
-
} else if constexpr (std::is_same_v<
|
|
277
|
-
T,
|
|
278
|
-
DisconnectAnimatedNodeFromViewOp>) {
|
|
279
|
-
nodesManager_->disconnectAnimatedNodeFromView(op.nodeTag, op.viewTag);
|
|
280
|
-
} else if constexpr (std::is_same_v<T, RestoreDefaultValuesOp>) {
|
|
281
|
-
nodesManager_->restoreDefaultValues(op.nodeTag);
|
|
282
|
-
} else if constexpr (std::is_same_v<T, DropAnimatedNodeOp>) {
|
|
283
|
-
nodesManager_->dropAnimatedNode(op.tag);
|
|
284
|
-
} else if constexpr (std::is_same_v<T, AddAnimatedEventToViewOp>) {
|
|
285
|
-
nodesManager_->addAnimatedEventToView(
|
|
286
|
-
op.viewTag, op.eventName, op.eventMapping);
|
|
287
|
-
} else if constexpr (std::is_same_v<T, RemoveAnimatedEventFromViewOp>) {
|
|
288
|
-
nodesManager_->removeAnimatedEventFromView(
|
|
289
|
-
op.viewTag, op.eventName, op.animatedNodeTag);
|
|
290
|
-
}
|
|
291
|
-
},
|
|
292
|
-
operation);
|
|
316
|
+
},
|
|
317
|
+
operation);
|
|
318
|
+
}
|
|
293
319
|
}
|
|
294
320
|
|
|
295
321
|
void AnimatedModule::installJSIBindingsWithRuntime(jsi::Runtime& runtime) {
|
|
@@ -87,6 +87,11 @@ class AnimatedModule : public NativeAnimatedModuleCxxSpec<AnimatedModule>, publi
|
|
|
87
87
|
Tag viewTag{};
|
|
88
88
|
};
|
|
89
89
|
|
|
90
|
+
struct ConnectAnimatedNodeToShadowNodeFamilyOp {
|
|
91
|
+
Tag nodeTag{};
|
|
92
|
+
std::shared_ptr<const ShadowNodeFamily> shadowNodeFamily{};
|
|
93
|
+
};
|
|
94
|
+
|
|
90
95
|
struct DisconnectAnimatedNodeFromViewOp {
|
|
91
96
|
Tag nodeTag{};
|
|
92
97
|
Tag viewTag{};
|
|
@@ -124,6 +129,7 @@ class AnimatedModule : public NativeAnimatedModuleCxxSpec<AnimatedModule>, publi
|
|
|
124
129
|
SetAnimatedNodeOffsetOp,
|
|
125
130
|
SetAnimatedNodeValueOp,
|
|
126
131
|
ConnectAnimatedNodeToViewOp,
|
|
132
|
+
ConnectAnimatedNodeToShadowNodeFamilyOp,
|
|
127
133
|
DisconnectAnimatedNodeFromViewOp,
|
|
128
134
|
RestoreDefaultValuesOp,
|
|
129
135
|
FlattenAnimatedNodeOffsetOp,
|
|
@@ -176,6 +182,8 @@ class AnimatedModule : public NativeAnimatedModuleCxxSpec<AnimatedModule>, publi
|
|
|
176
182
|
|
|
177
183
|
void connectAnimatedNodeToView(jsi::Runtime &rt, Tag nodeTag, Tag viewTag);
|
|
178
184
|
|
|
185
|
+
void connectAnimatedNodeToShadowNodeFamily(jsi::Runtime &rt, Tag nodeTag, jsi::Object shadowNode);
|
|
186
|
+
|
|
179
187
|
void disconnectAnimatedNodeFromView(jsi::Runtime &rt, Tag nodeTag, Tag viewTag);
|
|
180
188
|
|
|
181
189
|
void restoreDefaultValues(jsi::Runtime &rt, Tag nodeTag);
|
|
@@ -194,11 +202,11 @@ class AnimatedModule : public NativeAnimatedModuleCxxSpec<AnimatedModule>, publi
|
|
|
194
202
|
|
|
195
203
|
private:
|
|
196
204
|
std::shared_ptr<NativeAnimatedNodesManagerProvider> nodesManagerProvider_;
|
|
197
|
-
std::
|
|
205
|
+
std::weak_ptr<NativeAnimatedNodesManager> nodesManager_;
|
|
198
206
|
std::vector<Operation> preOperations_;
|
|
199
207
|
std::vector<Operation> operations_;
|
|
200
208
|
|
|
201
|
-
void executeOperation(const Operation &operation);
|
|
209
|
+
void executeOperation(const Operation &operation, std::weak_ptr<NativeAnimatedNodesManager> nodesManagerWeak);
|
|
202
210
|
void installJSIBindingsWithRuntime(jsi::Runtime &runtime) override;
|
|
203
211
|
};
|
|
204
212
|
|