react-native 0.71.3 → 0.72.0-rc.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/ActionSheetIOS/ActionSheetIOS.js +1 -1
- package/Libraries/ActionSheetIOS/React-RCTActionSheet.podspec +1 -1
- package/Libraries/Alert/Alert.d.ts +4 -4
- package/Libraries/Animated/Animated.d.ts +17 -6
- package/Libraries/Animated/NativeAnimatedHelper.js +18 -6
- package/Libraries/Animated/bezier.js +1 -1
- package/Libraries/Animated/components/AnimatedFlatList.js +8 -3
- package/Libraries/Animated/components/AnimatedScrollView.js +4 -1
- package/Libraries/Animated/components/AnimatedSectionList.js +12 -3
- package/Libraries/Animated/createAnimatedComponent.js +26 -239
- package/Libraries/Animated/nodes/AnimatedColor.js +47 -80
- package/Libraries/Animated/nodes/AnimatedInterpolation.js +167 -121
- package/Libraries/Animated/nodes/AnimatedNode.js +3 -5
- package/Libraries/Animated/nodes/AnimatedProps.js +7 -6
- package/Libraries/Animated/nodes/AnimatedStyle.js +42 -8
- package/Libraries/Animated/nodes/AnimatedTransform.js +1 -1
- package/Libraries/Animated/nodes/AnimatedValue.js +8 -12
- package/Libraries/Animated/nodes/AnimatedWithChildren.js +1 -1
- package/Libraries/Animated/useAnimatedProps.js +7 -10
- package/Libraries/AppDelegate/RCTAppDelegate.h +1 -8
- package/Libraries/AppDelegate/RCTAppDelegate.mm +49 -25
- package/{React/AppSetup → Libraries/AppDelegate}/RCTAppSetupUtils.h +7 -1
- package/{React/AppSetup → Libraries/AppDelegate}/RCTAppSetupUtils.mm +16 -9
- package/{React/Base/RCTWeakProxy.h → Libraries/AppDelegate/RCTLegacyInteropComponents.h} +5 -3
- package/{React/Views/RCTSliderManager.h → Libraries/AppDelegate/RCTLegacyInteropComponents.mm} +7 -2
- package/Libraries/AppDelegate/React-RCTAppDelegate.podspec +26 -5
- package/Libraries/BatchedBridge/MessageQueue.js +2 -1
- package/Libraries/BatchedBridge/NativeModules.d.ts +1 -1
- package/Libraries/BatchedBridge/NativeModules.js +1 -0
- package/Libraries/Blob/Blob.js +10 -0
- package/Libraries/Blob/FileReader.js +30 -2
- package/Libraries/Blob/React-RCTBlob.podspec +15 -2
- package/Libraries/Blob/URL.js +3 -1
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +2 -2
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +2 -3
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +6 -4
- package/Libraries/Components/Button.js +3 -2
- package/Libraries/Components/Clipboard/Clipboard.js +1 -1
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +4 -0
- package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +1 -0
- package/Libraries/Components/Pressable/Pressable.d.ts +1 -1
- package/Libraries/Components/Pressable/Pressable.js +1 -1
- package/Libraries/Components/RefreshControl/RefreshControl.js +1 -0
- package/Libraries/Components/SafeAreaView/SafeAreaView.js +1 -2
- package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +12 -6
- package/Libraries/Components/ScrollView/ScrollView.d.ts +2 -2
- package/Libraries/Components/ScrollView/ScrollView.js +149 -91
- package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +16 -6
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +5 -7
- package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +1 -1
- package/Libraries/Components/StatusBar/StatusBar.js +3 -0
- package/Libraries/Components/Switch/Switch.js +3 -1
- package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +21 -11
- package/Libraries/Components/TextInput/InputAccessoryView.d.ts +1 -1
- package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +11 -5
- package/Libraries/Components/TextInput/TextInput.d.ts +15 -5
- package/Libraries/Components/TextInput/TextInput.flow.js +1 -1
- package/Libraries/Components/TextInput/TextInput.js +142 -108
- package/Libraries/Components/Touchable/Touchable.d.ts +1 -1
- package/Libraries/Components/Touchable/Touchable.flow.js +30 -4
- package/Libraries/Components/Touchable/Touchable.js +6 -3
- package/Libraries/Components/Touchable/TouchableHighlight.js +1 -1
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -2
- package/Libraries/Components/Touchable/TouchableOpacity.js +5 -3
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts +3 -3
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +5 -5
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +179 -0
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +43 -0
- package/Libraries/Components/View/ReactNativeStyleAttributes.js +26 -0
- package/Libraries/Components/View/View.js +35 -16
- package/Libraries/Components/View/ViewAccessibility.d.ts +6 -6
- package/Libraries/Components/View/ViewAccessibility.js +10 -1
- package/Libraries/Components/View/ViewNativeComponent.js +32 -8
- package/Libraries/Components/View/ViewPropTypes.d.ts +1 -1
- package/Libraries/Components/View/ViewPropTypes.js +1 -1
- package/Libraries/Core/Devtools/openFileInEditor.js +1 -0
- package/Libraries/Core/Devtools/openURLInBrowser.js +1 -0
- package/Libraries/Core/Devtools/parseErrorStack.js +2 -2
- package/Libraries/Core/Devtools/parseHermesStack.js +54 -34
- package/Libraries/Core/ExceptionsManager.js +2 -2
- package/Libraries/Core/InitializeCore.js +2 -1
- package/Libraries/Core/ReactNativeVersion.js +3 -3
- package/Libraries/Core/ReactNativeVersionCheck.js +1 -9
- package/Libraries/Core/Timers/JSTimers.js +1 -1
- package/Libraries/Core/Timers/immediateShim.js +1 -0
- package/Libraries/Core/Timers/queueMicrotask.js +1 -1
- package/Libraries/Core/setUpAlert.js +1 -1
- package/Libraries/Core/setUpDOM.js +18 -0
- package/Libraries/Core/setUpDeveloperTools.js +1 -1
- package/Libraries/Core/setUpGlobals.js +5 -2
- package/Libraries/Core/setUpNavigator.js +6 -5
- package/Libraries/Core/setUpPerformance.js +23 -13
- package/Libraries/Core/setUpReactDevTools.js +2 -0
- package/Libraries/Core/setUpSegmentFetcher.js +0 -41
- package/Libraries/Core/setUpTimers.js +2 -2
- package/Libraries/DOM/Geometry/DOMRect.js +82 -0
- package/Libraries/DOM/Geometry/DOMRectReadOnly.js +188 -0
- package/Libraries/DOM/Nodes/ReactNativeElement.js +75 -0
- package/Libraries/DOM/Nodes/ReadOnlyElement.js +89 -0
- package/Libraries/DOM/Nodes/ReadOnlyNode.js +167 -0
- package/Libraries/DOM/OldStyleCollections/ArrayLikeUtils.js +46 -0
- package/Libraries/DOM/OldStyleCollections/DOMRectList.js +76 -0
- package/Libraries/DOM/OldStyleCollections/DOMRectList.js.flow +27 -0
- package/Libraries/DOM/OldStyleCollections/HTMLCollection.js +82 -0
- package/Libraries/DOM/OldStyleCollections/HTMLCollection.js.flow +27 -0
- package/Libraries/DOM/OldStyleCollections/NodeList.js +104 -0
- package/Libraries/DOM/OldStyleCollections/NodeList.js.flow +31 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.android.js +35 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.d.ts +20 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.ios.js +49 -0
- package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +24 -0
- package/Libraries/EventEmitter/NativeEventEmitter.d.ts +1 -2
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.d.ts +1 -2
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +9 -1
- package/Libraries/Events/EventPolyfill.js +1 -1
- package/Libraries/FBLazyVector/BUCK +2 -2
- package/Libraries/FBLazyVector/FBLazyVector.podspec +1 -1
- package/Libraries/Image/AssetRegistry.js +1 -1
- package/Libraries/Image/AssetSourceResolver.js +3 -3
- package/Libraries/Image/Image.android.js +4 -1
- package/Libraries/Image/Image.d.ts +63 -2
- package/Libraries/Image/Image.ios.js +3 -0
- package/Libraries/Image/ImageBackground.js +1 -0
- package/Libraries/Image/ImageProps.js +1 -1
- package/Libraries/Image/ImageViewNativeComponent.js +4 -4
- package/Libraries/Image/ImageViewNativeComponent.js.flow +1 -4
- package/Libraries/Image/RCTImageCache.h +1 -1
- package/Libraries/Image/RCTImageCache.m +4 -4
- package/Libraries/Image/RCTImageView.mm +1 -1
- package/Libraries/Image/React-RCTImage.podspec +15 -2
- package/Libraries/Image/RelativeImageStub.js +1 -1
- package/Libraries/Image/TextInlineImageNativeComponent.js +1 -1
- package/Libraries/Image/resolveAssetSource.js +1 -1
- package/Libraries/Inspector/DevtoolsOverlay.js +26 -19
- package/Libraries/Inspector/ElementBox.js +4 -1
- package/Libraries/Inspector/Inspector.js +5 -6
- package/Libraries/Inspector/InspectorOverlay.js +3 -3
- package/Libraries/Inspector/NetworkOverlay.js +1 -1
- package/Libraries/Interaction/JSEventLoopWatchdog.js +1 -1
- package/Libraries/Interaction/PanResponder.js +5 -6
- package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -1
- package/Libraries/Linking/Linking.js +1 -4
- package/Libraries/LinkingIOS/React-RCTLinking.podspec +15 -2
- package/Libraries/Lists/FillRateHelper.js +4 -238
- package/Libraries/Lists/FlatList.d.ts +20 -27
- package/Libraries/Lists/FlatList.js +28 -12
- package/Libraries/Lists/FlatList.js.flow +4 -3
- package/Libraries/Lists/SectionList.d.ts +10 -6
- package/Libraries/Lists/SectionList.js +5 -3
- package/Libraries/Lists/SectionListModern.js +3 -3
- package/Libraries/Lists/ViewabilityHelper.js +8 -344
- package/Libraries/Lists/VirtualizeUtils.js +4 -244
- package/Libraries/Lists/VirtualizedList.js +10 -1867
- package/Libraries/Lists/VirtualizedListContext.js +6 -104
- package/Libraries/Lists/VirtualizedSectionList.js +9 -602
- package/Libraries/Lists/__flowtests__/FlatList-flowtest.js +1 -0
- package/Libraries/Lists/__flowtests__/SectionList-flowtest.js +1 -1
- package/Libraries/LogBox/Data/LogBoxData.js +1 -1
- package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
- package/Libraries/LogBox/LogBox.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspector.js +1 -3
- package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +1 -0
- package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.js +2 -2
- package/Libraries/LogBox/UI/LogBoxMessage.js +87 -5
- package/Libraries/LogBox/UI/LogBoxNotification.js +5 -7
- package/Libraries/Modal/Modal.js +2 -2
- package/Libraries/NativeAnimation/Nodes/RCTColorAnimatedNode.m +3 -2
- package/Libraries/NativeAnimation/Nodes/RCTInterpolationAnimatedNode.h +14 -0
- package/Libraries/NativeAnimation/Nodes/RCTInterpolationAnimatedNode.m +108 -102
- package/Libraries/NativeAnimation/Nodes/RCTPropsAnimatedNode.m +1 -1
- package/Libraries/NativeAnimation/Nodes/RCTStyleAnimatedNode.m +6 -1
- package/Libraries/NativeAnimation/Nodes/RCTValueAnimatedNode.h +1 -1
- package/Libraries/NativeAnimation/Nodes/RCTValueAnimatedNode.m +5 -0
- package/Libraries/NativeAnimation/RCTAnimationUtils.h +16 -11
- package/Libraries/NativeAnimation/RCTAnimationUtils.m +24 -6
- package/Libraries/NativeAnimation/React-RCTAnimation.podspec +15 -2
- package/Libraries/NativeComponent/BaseViewConfig.android.js +32 -12
- package/Libraries/NativeComponent/BaseViewConfig.ios.js +43 -19
- package/Libraries/NativeComponent/NativeComponentRegistryUnstable.js +4 -1
- package/Libraries/NativeComponent/ViewConfig.js +1 -0
- package/Libraries/NativeComponent/ViewConfigIgnore.js +1 -4
- package/Libraries/Network/RCTNetworking.android.js +2 -2
- package/Libraries/Network/RCTNetworking.ios.js +1 -1
- package/Libraries/Network/RCTNetworking.mm +3 -2
- package/Libraries/Network/React-RCTNetwork.podspec +15 -2
- package/Libraries/Network/XMLHttpRequest.js +1 -1
- package/Libraries/Pressability/Pressability.js +10 -4
- package/Libraries/PushNotificationIOS/React-RCTPushNotification.podspec +15 -2
- package/Libraries/RCTRequired/BUCK +3 -2
- package/Libraries/RCTRequired/RCTRequired.podspec +1 -1
- package/Libraries/ReactNative/AppContainer.js +7 -1
- package/Libraries/ReactNative/AppRegistry.d.ts +1 -1
- package/Libraries/ReactNative/AppRegistry.js +10 -13
- package/Libraries/ReactNative/FabricUIManager.js +24 -8
- package/Libraries/ReactNative/NativeUIManager.js +5 -5
- package/Libraries/ReactNative/ReactNativeFeatureFlags.js +10 -10
- package/Libraries/ReactNative/UIManager.js +142 -1
- package/Libraries/ReactNative/getCachedComponentWithDebugName.js +5 -5
- package/Libraries/ReactNative/getNativeComponentAttributes.js +1 -1
- package/Libraries/ReactNative/requireNativeComponent.d.ts +1 -1
- package/Libraries/ReactNative/requireNativeComponent.js +1 -1
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +1 -0
- package/Libraries/Renderer/REVISION +1 -1
- package/Libraries/Renderer/public/ReactFabricPublicInstanceUtils.js +38 -0
- package/Libraries/Renderer/shims/ReactNativeTypes.js +6 -6
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -7
- package/Libraries/Renderer/shims/createReactNativeComponentClass.js +2 -2
- package/Libraries/Settings/React-RCTSettings.podspec +15 -2
- package/Libraries/Share/Share.js +1 -1
- package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +1 -1
- package/Libraries/StyleSheet/StyleSheet.js +1 -1
- package/Libraries/StyleSheet/StyleSheetTypes.d.ts +115 -76
- package/Libraries/StyleSheet/StyleSheetTypes.js +188 -33
- package/Libraries/StyleSheet/flattenStyle.js +2 -0
- package/Libraries/StyleSheet/normalizeColor.js +1 -1
- package/Libraries/StyleSheet/processColor.js +1 -1
- package/Libraries/Text/React-RCTText.podspec +1 -1
- package/Libraries/Text/Text/NSTextStorage+FontScaling.m +3 -3
- package/Libraries/Text/Text/RCTTextView.m +4 -4
- package/Libraries/Text/Text.d.ts +12 -2
- package/Libraries/Text/Text.js +50 -41
- package/Libraries/Text/TextInput/Multiline/RCTUITextView.m +1 -1
- package/Libraries/Text/TextInput/RCTBaseTextInputView.m +12 -6
- package/Libraries/Text/TextProps.js +3 -4
- package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +6 -0
- package/Libraries/TypeSafety/RCTConvertHelpers.h +1 -1
- package/Libraries/TypeSafety/RCTTypeSafety.podspec +1 -1
- package/Libraries/Types/CodegenTypes.js +1 -0
- package/Libraries/UTFSequence.js +3 -1
- package/Libraries/Utilities/Appearance.d.ts +10 -0
- package/Libraries/Utilities/Appearance.js +13 -0
- package/Libraries/Utilities/Dimensions.js +1 -1
- package/Libraries/Utilities/GlobalPerformanceLogger.js +12 -1
- package/Libraries/Utilities/HMRClient.js +16 -10
- package/Libraries/Utilities/{createPerformanceLogger.d.ts → IPerformanceLogger.d.ts} +4 -4
- package/Libraries/Utilities/IPerformanceLogger.js +49 -0
- package/Libraries/Utilities/LoadingView.android.js +28 -11
- package/Libraries/Utilities/NativeAppearance.js +1 -0
- package/Libraries/Utilities/PixelRatio.js +2 -2
- package/Libraries/Utilities/ReactNativeTestTools.js +1 -1
- package/Libraries/Utilities/__mocks__/PixelRatio.js +1 -1
- package/Libraries/Utilities/codegenNativeCommands.js +2 -0
- package/Libraries/Utilities/createPerformanceLogger.js +55 -43
- package/Libraries/Utilities/stringifySafe.js +2 -7
- package/Libraries/Utilities/useWindowDimensions.js +3 -3
- package/Libraries/Vibration/React-RCTVibration.podspec +15 -2
- package/Libraries/WebPerformance/EventCounts.js +78 -0
- package/Libraries/WebPerformance/MemoryInfo.js +54 -0
- package/Libraries/WebPerformance/NativePerformance.cpp +74 -0
- package/Libraries/WebPerformance/NativePerformance.h +76 -0
- package/Libraries/WebPerformance/NativePerformance.js +38 -0
- package/Libraries/WebPerformance/NativePerformanceObserver.cpp +69 -11
- package/Libraries/WebPerformance/NativePerformanceObserver.h +38 -7
- package/Libraries/WebPerformance/NativePerformanceObserver.js +22 -7
- package/Libraries/WebPerformance/Performance.js +312 -0
- package/Libraries/WebPerformance/PerformanceEntry.js +45 -0
- package/Libraries/WebPerformance/PerformanceEntryReporter.cpp +408 -0
- package/Libraries/WebPerformance/PerformanceEntryReporter.h +219 -0
- package/Libraries/WebPerformance/PerformanceEventTiming.js +38 -0
- package/Libraries/WebPerformance/PerformanceObserver.js +196 -101
- package/Libraries/WebPerformance/RawPerformanceEntry.js +87 -0
- package/Libraries/WebPerformance/ReactNativeStartupTiming.js +65 -0
- package/Libraries/WebPerformance/__mocks__/NativePerformance.js +65 -0
- package/Libraries/WebPerformance/__mocks__/NativePerformanceObserver.js +101 -0
- package/Libraries/WebSocket/RCTReconnectingWebSocket.m +10 -10
- package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
- package/Libraries/vendor/core/ErrorUtils.js +1 -1
- package/Libraries/vendor/emitter/EventEmitter.d.ts +2 -2
- package/Libraries/vendor/emitter/EventEmitter.js +9 -1
- package/README.md +1 -1
- package/React/Base/RCTBridge+Private.h +1 -1
- package/React/Base/RCTBridge.h +2 -11
- package/React/Base/RCTBridge.m +0 -34
- package/React/Base/RCTBridgeModuleDecorator.h +1 -1
- package/React/Base/RCTBundleURLProvider.mm +5 -1
- package/React/Base/RCTConvert.h +2 -1
- package/React/Base/RCTConvert.m +28 -15
- package/React/Base/RCTDefines.h +37 -8
- package/React/Base/RCTDisplayLink.m +7 -0
- package/React/Base/RCTJSScriptLoaderModule.h +5 -1
- package/React/Base/RCTRootContentView.h +1 -1
- package/React/Base/RCTRootContentView.m +1 -1
- package/React/Base/RCTRootView.m +1 -1
- package/React/Base/RCTVersion.m +3 -3
- package/React/Base/Surface/RCTSurfaceRootShadowViewDelegate.h +1 -1
- package/React/Base/Surface/SurfaceHostingView/RCTSurfaceHostingView.h +3 -3
- package/React/CoreModules/BUCK +3 -6
- package/React/CoreModules/RCTAccessibilityManager+Internal.h +1 -1
- package/React/CoreModules/RCTAlertManager.mm +0 -14
- package/React/CoreModules/RCTAppearance.h +1 -0
- package/React/CoreModules/RCTAppearance.mm +12 -0
- package/React/CoreModules/RCTDevLoadingView.h +0 -1
- package/React/CoreModules/RCTDevMenu.mm +2 -2
- package/React/CoreModules/RCTDevSettings.mm +16 -2
- package/React/CoreModules/RCTDevSplitBundleLoader.mm +6 -4
- package/React/CoreModules/RCTExceptionsManager.mm +13 -6
- package/React/CoreModules/RCTFPSGraph.m +8 -3
- package/React/CoreModules/RCTPlatform.mm +2 -2
- package/React/CoreModules/RCTTiming.h +8 -4
- package/React/CoreModules/RCTWebSocketExecutor.mm +10 -10
- package/React/CoreModules/RCTWebSocketModule.mm +13 -13
- package/React/CoreModules/React-CoreModules.podspec +16 -2
- package/React/CxxBridge/RCTCxxBridge.mm +3 -2
- package/React/CxxBridge/RCTJSIExecutorRuntimeInstaller.mm +1 -10
- package/React/CxxModule/RCTNativeModule.mm +3 -2
- package/React/CxxUtils/RCTFollyConvert.mm +1 -0
- package/React/DevSupport/RCTInspectorDevServerHelper.h +1 -1
- package/React/DevSupport/RCTInspectorDevServerHelper.mm +1 -1
- package/React/DevSupport/RCTPackagerConnection.mm +1 -1
- package/React/FBReactNativeSpec/FBReactNativeSpec.podspec +1 -1
- package/React/Fabric/Mounting/ComponentViews/RCTFabricComponentsPlugins.h +1 -2
- package/React/Fabric/Mounting/ComponentViews/RCTFabricComponentsPlugins.mm +0 -1
- package/React/{Views/RCTDatePicker.h → Fabric/Mounting/ComponentViews/ScrollView/RCTCustomPullToRefreshViewProtocol.h} +4 -1
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTPullToRefreshViewComponentView.h +2 -1
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTPullToRefreshViewComponentView.mm +2 -2
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTScrollViewComponentView.mm +91 -1
- package/React/Fabric/Mounting/ComponentViews/Text/RCTParagraphComponentView.mm +14 -24
- package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputComponentView.mm +9 -5
- package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputUtils.h +0 -2
- package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputUtils.mm +0 -2
- package/React/Fabric/Mounting/ComponentViews/View/RCTViewComponentView.h +0 -6
- package/React/Fabric/Mounting/ComponentViews/View/RCTViewComponentView.mm +1 -2
- package/React/Fabric/Mounting/RCTComponentViewFactory.mm +16 -16
- package/React/Fabric/Mounting/RCTComponentViewRegistry.mm +4 -3
- package/React/Fabric/Mounting/RCTMountingManager.h +2 -1
- package/React/Fabric/Mounting/RCTMountingManager.mm +12 -14
- package/React/Fabric/RCTConversions.h +0 -1
- package/React/Fabric/RCTScheduler.h +1 -1
- package/React/Fabric/RCTScheduler.mm +2 -11
- package/React/Fabric/RCTSurfacePointerHandler.h +28 -0
- package/React/Fabric/RCTSurfacePointerHandler.mm +882 -0
- package/React/Fabric/RCTSurfacePresenter.h +1 -1
- package/React/Fabric/RCTSurfacePresenter.mm +16 -6
- package/React/Fabric/RCTSurfaceRegistry.mm +5 -6
- package/React/Fabric/RCTSurfaceTouchHandler.mm +27 -600
- package/React/Fabric/Utils/RCTIdentifierPool.h +44 -0
- package/React/Fabric/Utils/RCTReactTaggedView.h +1 -1
- package/React/Inspector/RCTInspector.h +1 -1
- package/React/Inspector/RCTInspector.mm +1 -2
- package/React/Inspector/RCTInspectorPackagerConnection.h +1 -1
- package/React/Inspector/RCTInspectorPackagerConnection.m +11 -11
- package/React/Modules/RCTEventEmitter.m +14 -11
- package/React/Profiler/RCTProfileTrampoline-x86_64.S +1 -1
- package/React/React-RCTFabric.podspec +31 -4
- package/React/Views/RCTComponentData.m +3 -15
- package/React/Views/RCTConvert+Transform.m +1 -1
- package/React/Views/RCTFont.mm +2 -2
- package/React/Views/RCTView.h +11 -0
- package/React/Views/RCTView.m +40 -18
- package/React/Views/RCTViewManager.m +17 -1
- package/React/Views/RefreshControl/RCTRefreshControl.h +1 -1
- package/React/Views/RefreshControl/RCTRefreshControl.m +7 -0
- package/React/Views/SafeAreaView/RCTSafeAreaShadowView.m +1 -1
- package/React/Views/ScrollView/RCTScrollView.m +17 -7
- package/React/Views/ScrollView/RCTScrollableProtocol.h +5 -1
- package/React-Core.podspec +15 -4
- package/React.podspec +1 -1
- package/ReactAndroid/build.gradle +91 -23
- package/ReactAndroid/cmake-utils/ReactNative-application.cmake +2 -0
- package/ReactAndroid/gradle.properties +6 -9
- package/ReactAndroid/hermes-engine/build.gradle +14 -5
- package/ReactAndroid/libs/BUCK +1 -1
- package/ReactAndroid/proguard-rules.pro +7 -0
- package/ReactAndroid/publish.gradle +1 -1
- package/ReactAndroid/src/main/java/com/facebook/BUCK +1 -3
- package/ReactAndroid/src/main/java/com/facebook/react/BUCK +15 -14
- package/ReactAndroid/src/main/java/com/facebook/react/DebugCorePackage.java +54 -2
- package/ReactAndroid/src/main/java/com/facebook/react/LazyReactPackage.java +7 -35
- package/ReactAndroid/src/main/java/com/facebook/react/ReactActivityDelegate.java +12 -11
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManager.java +10 -8
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManagerBuilder.java +11 -1
- package/ReactAndroid/src/main/java/com/facebook/react/ReactNativeHost.java +9 -0
- package/ReactAndroid/src/main/java/com/facebook/react/ReactPackageTurboModuleManagerDelegate.java +111 -14
- package/ReactAndroid/src/main/java/com/facebook/react/ReactRootView.java +63 -55
- package/ReactAndroid/src/main/java/com/facebook/react/animated/AnimationDriver.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/BUCK +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/animated/InterpolationAnimatedNode.java +143 -88
- package/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedModule.java +9 -22
- package/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedNodesManager.java +7 -16
- package/ReactAndroid/src/main/java/com/facebook/react/animated/PropsAnimatedNode.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/StyleAnimatedNode.java +8 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/ValueAnimatedNode.java +1 -2
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/BUCK +14 -19
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CatalystInstance.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ColorPropConverter.java +11 -0
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/DimensionPropConverter.java +33 -0
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JSONArguments.java +110 -0
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ModuleHolder.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/NativeModule.java +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactContext.java +30 -2
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactContextBaseJavaModule.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactMarker.java +13 -0
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReadableNativeMap.java +49 -63
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/UIManager.java +0 -12
- package/ReactAndroid/src/main/java/com/facebook/react/common/BUCK +4 -7
- package/ReactAndroid/src/main/java/com/facebook/react/common/JavascriptException.java +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/BUCK +0 -1
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/MapBuffer.kt +18 -2
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/ReadableMapBuffer.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/WritableMapBuffer.kt +5 -0
- package/ReactAndroid/src/main/java/com/facebook/react/config/ReactFeatureFlags.java +29 -25
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultNewArchitectureEntryPoint.kt +29 -7
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactActivityDelegate.kt +16 -16
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/BUCK +6 -9
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/BridgeDevSupportManager.java +18 -2
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/{DevLoadingViewController.java → DefaultDevLoadingViewImplementation.java} +10 -33
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DefaultDevSupportManagerFactory.java +15 -7
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerBase.java +38 -12
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerFactory.java +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/InspectorPackagerConnection.java +4 -4
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/JSCHeapCapture.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/LogBoxModule.java +1 -6
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/PerftestDevSupportManager.java +56 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/DevLoadingViewManager.java +21 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/.clang-tidy +1 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/BUCK +10 -13
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/Binding.java +3 -24
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/DevToolsReactPerfLogger.java +22 -3
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricJSIModuleProvider.java +1 -14
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManager.java +6 -37
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/EventEmitterWrapper.java +2 -5
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/MountItemDispatcher.java +4 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/MountingManager.java +0 -4
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/SurfaceMountingManager.java +9 -7
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/IntBufferBatchMountItem.java +0 -11
- package/ReactAndroid/src/main/java/com/facebook/react/modules/.clang-tidy +1 -0
- package/ReactAndroid/src/main/java/com/facebook/react/modules/accessibilityinfo/AccessibilityInfoModule.java +12 -23
- package/ReactAndroid/src/main/java/com/facebook/react/modules/appearance/AppearanceModule.java +11 -9
- package/ReactAndroid/src/main/java/com/facebook/react/modules/appearance/BUCK +1 -0
- package/ReactAndroid/src/main/java/com/facebook/react/modules/appstate/AppStateModule.java +3 -14
- package/ReactAndroid/src/main/java/com/facebook/react/modules/blob/BUCK +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/blob/BlobCollector.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/blob/BlobModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/blob/FileReaderModule.java +1 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/bundleloader/BUCK +1 -3
- package/ReactAndroid/src/main/java/com/facebook/react/modules/bundleloader/NativeDevSplitBundleLoaderModule.java +1 -9
- package/ReactAndroid/src/main/java/com/facebook/react/modules/camera/ImageStoreManager.java +1 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/clipboard/ClipboardModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/DeviceEventManagerModule.java +3 -12
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/ExceptionsManagerModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/HeadlessJsTaskSupportModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/ReactChoreographer.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/TimingModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/AnimationsDebugModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/DevSettingsModule.java +2 -12
- package/ReactAndroid/src/main/java/com/facebook/react/modules/debug/SourceCodeModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/deviceinfo/DeviceInfoModule.java +5 -15
- package/ReactAndroid/src/main/java/com/facebook/react/modules/devloading/BUCK +25 -0
- package/ReactAndroid/src/main/java/com/facebook/react/modules/devloading/DevLoadingModule.java +67 -0
- package/ReactAndroid/src/main/java/com/facebook/react/modules/devtoolssettings/BUCK +25 -0
- package/ReactAndroid/src/main/java/com/facebook/react/modules/devtoolssettings/DevToolsSettingsManagerModule.java +53 -0
- package/ReactAndroid/src/main/java/com/facebook/react/modules/dialog/BUCK +2 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/dialog/DialogModule.java +2 -13
- package/ReactAndroid/src/main/java/com/facebook/react/modules/fabric/BUCK +0 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/fresco/BUCK +6 -9
- package/ReactAndroid/src/main/java/com/facebook/react/modules/fresco/FrescoModule.java +29 -11
- package/ReactAndroid/src/main/java/com/facebook/react/modules/i18nmanager/BUCK +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/i18nmanager/I18nManagerModule.java +1 -9
- package/ReactAndroid/src/main/java/com/facebook/react/modules/image/ImageLoaderModule.java +1 -9
- package/ReactAndroid/src/main/java/com/facebook/react/modules/intent/IntentModule.java +48 -14
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/BUCK +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/NetworkingModule.java +66 -63
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ResponseUtil.java +26 -25
- package/ReactAndroid/src/main/java/com/facebook/react/modules/permissions/PermissionsModule.java +1 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/share/ShareModule.java +1 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/sound/BUCK +0 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/sound/SoundManagerModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/statusbar/BUCK +4 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/statusbar/StatusBarModule.java +1 -6
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/AndroidInfoHelpers.java +2 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/AndroidInfoModule.java +1 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/ReactNativeVersion.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/modules/toast/ToastModule.java +1 -7
- package/ReactAndroid/src/main/java/com/facebook/react/modules/vibration/VibrationModule.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/react/modules/websocket/WebSocketModule.java +2 -14
- package/ReactAndroid/src/main/java/com/facebook/react/processing/BUCK +2 -1
- package/ReactAndroid/src/main/java/com/facebook/react/processing/ReactPropertyProcessor.java +47 -26
- package/ReactAndroid/src/main/java/com/facebook/react/shell/BUCK +8 -10
- package/ReactAndroid/src/main/java/com/facebook/react/shell/MainReactPackage.java +188 -4
- package/ReactAndroid/src/main/java/com/facebook/react/surface/BUCK +0 -1
- package/ReactAndroid/src/main/java/com/facebook/react/turbomodule/.clang-tidy +1 -0
- package/ReactAndroid/src/main/java/com/facebook/react/turbomodule/core/TurboModuleManager.java +57 -63
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BUCK +7 -14
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BaseViewManager.java +12 -14
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/IViewGroupManager.java +26 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/IViewManagerWithChildren.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/JSPointerDispatcher.java +95 -53
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/LayoutShadowNode.java +36 -20
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeViewHierarchyManager.java +10 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactAccessibilityDelegate.java +355 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/Spacing.java +21 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/TouchTargetHelper.java +9 -11
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/TransformHelper.java +3 -3
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIImplementation.java +16 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIManagerModule.java +1 -55
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewGroupManager.java +5 -11
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewManager.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewManagerRegistry.java +15 -6
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewProps.java +16 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/common/BUCK +4 -7
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/Event.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventCategoryDef.java +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/PointerEvent.java +23 -11
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/PointerEventHelper.java +12 -38
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTEventEmitter.java +4 -4
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/util/ReactFindViewUtil.java +0 -5
- package/ReactAndroid/src/main/java/com/facebook/react/views/common/BUCK +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/BUCK +7 -8
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/ReactDrawerLayout.java +30 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/ReactDrawerLayoutManager.java +11 -5
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/BUCK +10 -15
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ImageResizeMode.java +10 -11
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ReactImageManager.java +4 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/BUCK +2 -4
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ReactModalHostView.java +15 -12
- package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/BUCK +1 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/ReactProgressBarViewManager.java +6 -4
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/BUCK +4 -7
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/MaintainVisibleScrollPositionHelper.java +181 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollView.java +77 -9
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollViewManager.java +12 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollView.java +72 -13
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewHelper.java +9 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewManager.java +10 -6
- package/ReactAndroid/src/main/java/com/facebook/react/views/swiperefresh/BUCK +5 -7
- package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/BUCK +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/ReactSwitch.java +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/BUCK +0 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/CustomLineHeightSpan.java +4 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/DefaultStyleValuesUtil.java +1 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactBaseTextShadowNode.java +8 -5
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextAnchorViewManager.java +7 -6
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextShadowNode.java +7 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextView.java +9 -7
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextViewManager.java +13 -5
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextAttributeProps.java +23 -20
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextAttributes.java +5 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutManager.java +22 -16
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutManagerMapBuffer.java +17 -17
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/BUCK +1 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageShadowNode.java +6 -5
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactEditText.java +34 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputManager.java +28 -15
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputShadowNode.java +4 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/{slider → traceupdateoverlay}/BUCK +7 -7
- package/ReactAndroid/src/main/java/com/facebook/react/views/traceupdateoverlay/TraceUpdateOverlay.java +70 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/traceupdateoverlay/TraceUpdateOverlayManager.java +83 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/unimplementedview/BUCK +5 -8
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/BUCK +6 -9
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/CanvasUtil.java +2 -10
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactMapBufferPropSetter.kt +17 -5
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewBackgroundDrawable.java +147 -32
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewManager.java +18 -6
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewManagerWrapper.kt +5 -5
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfig.java +0 -8
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfigJNIBase.java +0 -11
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaExperimentalFeature.java +5 -1
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaLogLevel.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaLogger.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNative.java +1 -2
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNodeJNIBase.java +1 -8
- package/ReactAndroid/src/main/java/com/facebook/yoga/annotations/DoNotStrip.java +18 -0
- package/ReactAndroid/src/main/jni/CMakeLists.txt +112 -3
- package/ReactAndroid/src/main/jni/CircularDepsValidator.cmake +32 -0
- package/ReactAndroid/src/main/jni/first-party/.clang-tidy +1 -0
- package/ReactAndroid/src/main/jni/first-party/fb/CMakeLists.txt +3 -0
- package/ReactAndroid/src/main/jni/first-party/yogajni/BUCK +1 -1
- package/ReactAndroid/src/main/jni/first-party/yogajni/jni/YGJNI.h +0 -1
- package/ReactAndroid/src/main/jni/first-party/yogajni/jni/YGJNIVanilla.cpp +0 -15
- package/ReactAndroid/src/main/jni/first-party/yogajni/jni/YGJTypesVanilla.h +4 -4
- package/ReactAndroid/src/main/jni/react/fabric/BUCK +0 -2
- package/ReactAndroid/src/main/jni/react/fabric/Binding.cpp +20 -49
- package/ReactAndroid/src/main/jni/react/fabric/Binding.h +5 -10
- package/ReactAndroid/src/main/jni/react/fabric/CMakeLists.txt +0 -2
- package/ReactAndroid/src/main/jni/react/fabric/ComponentFactory.h +1 -7
- package/ReactAndroid/src/main/jni/react/fabric/CoreComponentsRegistry.cpp +2 -3
- package/ReactAndroid/src/main/jni/react/fabric/EventEmitterWrapper.cpp +3 -2
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountItem.h +1 -2
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.cpp +32 -66
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.h +2 -6
- package/ReactAndroid/src/main/jni/react/fabric/JBackgroundExecutor.h +1 -3
- package/ReactAndroid/src/main/jni/react/fabric/JFabricUIManager.h +2 -3
- package/ReactAndroid/src/main/jni/react/fabric/OnLoad.cpp +0 -2
- package/ReactAndroid/src/main/jni/react/fabric/StateWrapperImpl.cpp +3 -7
- package/ReactAndroid/src/main/jni/react/fabric/SurfaceHandlerBinding.cpp +2 -2
- package/ReactAndroid/src/main/jni/react/fabric/SurfaceHandlerBinding.h +3 -1
- package/ReactAndroid/src/main/jni/react/fabric/viewPropConversions.h +10 -2
- package/ReactAndroid/src/main/jni/react/hermes/instrumentation/BUCK +1 -1
- package/ReactAndroid/src/main/jni/react/hermes/reactexecutor/CMakeLists.txt +1 -0
- package/ReactAndroid/src/main/jni/react/hermes/reactexecutor/OnLoad.cpp +1 -5
- package/ReactAndroid/src/main/jni/react/jni/.clang-tidy +1 -0
- package/ReactAndroid/src/main/jni/react/jni/BUCK +5 -4
- package/ReactAndroid/src/main/jni/react/jni/JMessageQueueThread.cpp +2 -0
- package/ReactAndroid/src/main/jni/react/jni/JMessageQueueThread.h +4 -8
- package/ReactAndroid/src/main/jni/react/jni/JReactMarker.cpp +9 -2
- package/ReactAndroid/src/main/jni/react/jni/JReactMarker.h +1 -0
- package/ReactAndroid/src/main/jni/react/jni/JavaModuleWrapper.cpp +2 -2
- package/ReactAndroid/src/main/jni/react/jni/JavaModuleWrapper.h +2 -2
- package/ReactAndroid/src/main/jni/react/jni/MethodInvoker.cpp +2 -2
- package/ReactAndroid/src/main/jni/react/jni/NativeArray.cpp +1 -3
- package/ReactAndroid/src/main/jni/react/jni/NativeArray.h +13 -3
- package/ReactAndroid/src/main/jni/react/jni/NativeMap.cpp +2 -2
- package/ReactAndroid/src/main/jni/react/jni/NativeMap.h +10 -4
- package/ReactAndroid/src/main/jni/react/jni/OnLoad.cpp +6 -0
- package/ReactAndroid/src/main/jni/react/jni/ReadableNativeArray.cpp +0 -6
- package/ReactAndroid/src/main/jni/react/jni/ReadableNativeArray.h +4 -1
- package/ReactAndroid/src/main/jni/react/jni/ReadableNativeMap.cpp +11 -7
- package/ReactAndroid/src/main/jni/react/jni/ReadableNativeMap.h +2 -2
- package/ReactAndroid/src/main/jni/react/jscexecutor/OnLoad.cpp +1 -5
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.cpp +9 -43
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.h +2 -9
- package/ReactAndroid/src/main/libraries/fbcore/src/main/java/com/facebook/common/logging/BUCK +1 -1
- package/ReactAndroid/src/main/libraries/fresco/fresco-react-native/BUCK +15 -15
- package/ReactAndroid/src/main/res/devsupport/values-af/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ar/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-as/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-az/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-be/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-bg/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-bn/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-bs/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ca/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-cb/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-cs/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-da/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-de/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-el/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-en-rGB/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-es/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-es-rES/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-et/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-fa/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-fb/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-fb-rLS/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-fi/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-fr/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-fr-rCA/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-gu/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ha/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-hi/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-hr/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-hu/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-hy/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-in/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-is/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-it/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-iw/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ja/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-jv/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-ka/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-kk/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-km/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-kn/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ko/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ku/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-ky/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-lo/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-lt/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-lv/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-mk/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ml/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-mn/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-mr/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ms/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-my/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-nb/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ne/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-nl/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-pa/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-pl/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ps/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-pt/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-pt-rPT/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-qz/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ro/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ru/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-si/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sk/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sl/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sn/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-so/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-sq/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sr/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sv/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-sw/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ta/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-te/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-tg/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-th/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-tk/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-tl/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-tr/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-uk/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-ur/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-uz/strings.xml +6 -0
- package/ReactAndroid/src/main/res/devsupport/values-vi/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-wo/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-zh-rCN/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-zh-rHK/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-zh-rTW/strings.xml +0 -1
- package/ReactAndroid/src/main/res/devsupport/values-zu/strings.xml +0 -1
- package/ReactAndroid/src/main/res/views/uimanager/values/ids.xml +4 -1
- package/ReactCommon/React-Fabric.podspec +43 -49
- package/ReactCommon/React-rncore.podspec +2 -1
- package/ReactCommon/ReactCommon.podspec +8 -17
- package/ReactCommon/butter/BUCK +1 -9
- package/ReactCommon/butter/function.h +51 -0
- package/ReactCommon/butter/map.h +3 -3
- package/ReactCommon/callinvoker/.clang-tidy +1 -0
- package/ReactCommon/callinvoker/BUCK +0 -1
- package/ReactCommon/callinvoker/React-callinvoker.podspec +1 -1
- package/ReactCommon/callinvoker/ReactCommon/CallInvoker.h +11 -2
- package/ReactCommon/{butter/mutex.h → callinvoker/ReactCommon/SchedulerPriority.h} +10 -6
- package/ReactCommon/cxxreact/.clang-tidy +1 -0
- package/ReactCommon/cxxreact/BUCK +3 -1
- package/ReactCommon/cxxreact/CMakeLists.txt +1 -0
- package/ReactCommon/cxxreact/Instance.h +2 -2
- package/ReactCommon/cxxreact/JSBigString.h +5 -5
- package/ReactCommon/cxxreact/JSExecutor.cpp +12 -0
- package/ReactCommon/cxxreact/JSExecutor.h +2 -0
- package/ReactCommon/cxxreact/MethodCall.cpp +3 -3
- package/ReactCommon/cxxreact/ModuleRegistry.cpp +5 -6
- package/ReactCommon/cxxreact/ModuleRegistry.h +3 -3
- package/ReactCommon/cxxreact/NativeModule.h +2 -2
- package/ReactCommon/cxxreact/React-cxxreact.podspec +3 -2
- package/ReactCommon/cxxreact/ReactMarker.cpp +55 -2
- package/ReactCommon/cxxreact/ReactMarker.h +36 -2
- package/ReactCommon/cxxreact/ReactNativeVersion.h +3 -3
- package/ReactCommon/hermes/.clang-tidy +1 -0
- package/ReactCommon/hermes/React-hermes.podspec +3 -2
- package/ReactCommon/hermes/executor/CMakeLists.txt +8 -1
- package/ReactCommon/hermes/executor/HermesExecutorFactory.cpp +6 -20
- package/ReactCommon/hermes/inspector/BUCK +12 -6
- package/ReactCommon/hermes/inspector/CMakeLists.txt +1 -1
- package/ReactCommon/hermes/inspector/DEFS.bzl +2 -2
- package/ReactCommon/hermes/inspector/Inspector.cpp +2 -2
- package/ReactCommon/hermes/inspector/Inspector.h +7 -7
- package/ReactCommon/hermes/inspector/InspectorState.h +5 -5
- package/ReactCommon/hermes/inspector/README.md +7 -7
- package/ReactCommon/hermes/inspector/RuntimeAdapter.h +1 -1
- package/ReactCommon/hermes/inspector/chrome/Connection.cpp +12 -12
- package/ReactCommon/hermes/inspector/chrome/MessageConverters.h +3 -3
- package/ReactCommon/hermes/inspector/chrome/MessageTypes.h +96 -97
- package/ReactCommon/hermes/inspector/chrome/MessageTypesInlines.h +4 -3
- package/ReactCommon/hermes/inspector/chrome/tests/ConnectionTests.cpp +39 -38
- package/ReactCommon/hermes/inspector/chrome/tests/MessageTests.cpp +67 -64
- package/ReactCommon/hermes/inspector/chrome/tests/SyncConnection.cpp +3 -3
- package/ReactCommon/hermes/inspector/chrome/tests/SyncConnection.h +3 -3
- package/ReactCommon/hermes/inspector/detail/SerialExecutor.h +1 -1
- package/ReactCommon/hermes/inspector/tools/format +1 -1
- package/ReactCommon/hermes/inspector/tools/sandcastle/build_and_test.sh +4 -4
- package/ReactCommon/jsc/CMakeLists.txt +4 -0
- package/ReactCommon/jsc/JSCRuntime.cpp +11 -9
- package/ReactCommon/jsc/React-jsc.podspec +1 -1
- package/ReactCommon/jsengineinstance/.clang-tidy +1 -0
- package/ReactCommon/jserrorhandler/BUCK +1 -1
- package/ReactCommon/jsi/.clang-tidy +1 -0
- package/ReactCommon/jsi/React-jsi.podspec +1 -1
- package/ReactCommon/jsi/jsi/decorator.h +16 -10
- package/ReactCommon/jsi/jsi/jsi-inl.h +7 -5
- package/ReactCommon/jsi/jsi/jsi.cpp +51 -61
- package/ReactCommon/jsi/jsi/jsi.h +22 -16
- package/ReactCommon/jsiexecutor/.clang-tidy +1 -0
- package/ReactCommon/jsiexecutor/CMakeLists.txt +5 -1
- package/ReactCommon/jsiexecutor/React-jsiexecutor.podspec +3 -2
- package/ReactCommon/jsiexecutor/jsireact/JSIExecutor.cpp +16 -16
- package/ReactCommon/jsiexecutor/jsireact/JSIExecutor.h +7 -7
- package/ReactCommon/jsiexecutor/jsireact/JSINativeModules.cpp +7 -7
- package/ReactCommon/jsiexecutor/jsireact/JSINativeModules.h +3 -3
- package/ReactCommon/jsinspector/.clang-tidy +1 -0
- package/ReactCommon/jsinspector/CMakeLists.txt +3 -1
- package/ReactCommon/jsinspector/React-jsinspector.podspec +2 -1
- package/ReactCommon/libraries/fbcore/src/test/java/com/facebook/powermock/BUCK +3 -3
- package/ReactCommon/logger/React-logger.podspec +1 -1
- package/ReactCommon/react/bridging/BUCK +1 -2
- package/ReactCommon/react/bridging/Base.h +3 -3
- package/ReactCommon/react/bridging/CallbackWrapper.h +3 -39
- package/ReactCommon/react/bridging/Function.h +36 -17
- package/ReactCommon/react/bridging/LongLivedObject.cpp +6 -13
- package/ReactCommon/react/bridging/LongLivedObject.h +9 -8
- package/ReactCommon/react/bridging/Number.h +11 -0
- package/ReactCommon/react/bridging/tests/BridgingTest.cpp +16 -1
- package/ReactCommon/react/config/.clang-tidy +1 -0
- package/ReactCommon/react/config/ReactNativeConfig.cpp +3 -0
- package/ReactCommon/react/config/ReactNativeConfig.h +1 -1
- package/ReactCommon/react/debug/CMakeLists.txt +4 -0
- package/ReactCommon/react/debug/flags.h +3 -1
- package/ReactCommon/react/debug/react_native_assert.h +6 -0
- package/ReactCommon/react/debug/react_native_expect.h +41 -0
- package/ReactCommon/react/nativemodule/.clang-tidy +1 -0
- package/ReactCommon/react/nativemodule/core/BUCK +3 -1
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboCxxModule.cpp +6 -1
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModule.cpp +26 -8
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModule.h +31 -3
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleBinding.cpp +39 -44
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleBinding.h +5 -14
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleUtils.cpp +2 -2
- package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleUtils.h +1 -1
- package/ReactCommon/react/nativemodule/core/platform/android/ReactCommon/JavaTurboModule.cpp +28 -48
- package/ReactCommon/react/nativemodule/core/platform/android/ReactCommon/JavaTurboModule.h +3 -9
- package/ReactCommon/react/nativemodule/core/platform/ios/React-NativeModulesApple.podspec +56 -0
- package/ReactCommon/react/nativemodule/core/platform/ios/{RCTBlockGuard.h → ReactCommon/RCTBlockGuard.h} +1 -1
- package/ReactCommon/react/nativemodule/core/platform/ios/{RCTTurboModule.h → ReactCommon/RCTTurboModule.h} +0 -6
- package/ReactCommon/react/nativemodule/core/platform/ios/{RCTTurboModule.mm → ReactCommon/RCTTurboModule.mm} +24 -51
- package/ReactCommon/react/nativemodule/core/platform/ios/{RCTTurboModuleManager.h → ReactCommon/RCTTurboModuleManager.h} +5 -1
- package/ReactCommon/react/nativemodule/core/platform/ios/{RCTTurboModuleManager.mm → ReactCommon/RCTTurboModuleManager.mm} +14 -69
- package/ReactCommon/react/nativemodule/samples/BUCK +3 -1
- package/ReactCommon/react/nativemodule/samples/ReactCommon/NativeSampleTurboCxxModuleSpecJSI.cpp +12 -0
- package/ReactCommon/react/nativemodule/samples/ReactCommon/NativeSampleTurboCxxModuleSpecJSI.h +1 -0
- package/ReactCommon/react/nativemodule/samples/ReactCommon/SampleTurboCxxModule.cpp +4 -0
- package/ReactCommon/react/nativemodule/samples/ReactCommon/SampleTurboCxxModule.h +1 -0
- package/ReactCommon/react/nativemodule/samples/ReactCommon-Samples.podspec +59 -0
- package/ReactCommon/react/nativemodule/samples/platform/android/NativeSampleTurboModuleSpec.java +3 -0
- package/ReactCommon/react/nativemodule/samples/platform/android/ReactCommon/SampleTurboModuleSpec.cpp +15 -0
- package/ReactCommon/react/nativemodule/samples/platform/android/SampleTurboModule.java +8 -0
- package/ReactCommon/react/nativemodule/samples/platform/ios/{RCTNativeSampleTurboModuleSpec.h → ReactCommon/RCTNativeSampleTurboModuleSpec.h} +1 -0
- package/ReactCommon/react/nativemodule/samples/platform/ios/{RCTNativeSampleTurboModuleSpec.mm → ReactCommon/RCTNativeSampleTurboModuleSpec.mm} +11 -0
- package/ReactCommon/react/nativemodule/samples/platform/ios/{RCTSampleTurboModule.mm → ReactCommon/RCTSampleTurboModule.mm} +5 -0
- package/ReactCommon/react/nativemodule/samples/platform/ios/{SampleTurboCxxModuleLegacyImpl.cpp → ReactCommon/SampleTurboCxxModuleLegacyImpl.cpp} +10 -0
- package/ReactCommon/react/nativemodule/samples/platform/ios/{SampleTurboCxxModuleLegacyImpl.h → ReactCommon/SampleTurboCxxModuleLegacyImpl.h} +1 -0
- package/ReactCommon/react/renderer/.clang-tidy +7 -0
- package/ReactCommon/react/renderer/animations/BUCK +2 -0
- package/ReactCommon/react/renderer/animations/LayoutAnimationKeyFrameManager.cpp +41 -65
- package/ReactCommon/react/renderer/animations/LayoutAnimationKeyFrameManager.h +3 -20
- package/ReactCommon/react/renderer/attributedstring/AttributedString.h +1 -1
- package/ReactCommon/react/renderer/attributedstring/ParagraphAttributes.cpp +1 -1
- package/ReactCommon/react/renderer/attributedstring/ParagraphAttributes.h +1 -1
- package/ReactCommon/react/renderer/attributedstring/TextAttributes.cpp +1 -1
- package/ReactCommon/react/renderer/attributedstring/TextAttributes.h +2 -1
- package/ReactCommon/react/renderer/attributedstring/conversions.h +48 -49
- package/ReactCommon/react/renderer/attributedstring/tests/AttributedStringTest.cpp +1 -1
- package/ReactCommon/react/renderer/attributedstring/tests/TextAttributesTest.cpp +1 -1
- package/ReactCommon/react/renderer/componentregistry/ComponentDescriptorProviderRegistry.cpp +4 -4
- package/ReactCommon/react/renderer/componentregistry/ComponentDescriptorProviderRegistry.h +4 -5
- package/ReactCommon/react/renderer/componentregistry/ComponentDescriptorRegistry.cpp +5 -5
- package/ReactCommon/react/renderer/componentregistry/ComponentDescriptorRegistry.h +2 -2
- package/ReactCommon/react/renderer/components/image/ImageProps.cpp +9 -7
- package/ReactCommon/react/renderer/components/image/conversions.h +4 -4
- package/ReactCommon/react/renderer/components/inputaccessory/InputAccessoryState.h +1 -2
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/CMakeLists.txt +31 -0
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/RCTLegacyViewManagerInteropCoordinator.mm +1 -1
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/UnstableLegacyViewManagerInteropComponentDescriptor.h +38 -0
- package/ReactCommon/react/renderer/components/modal/ModalHostViewState.h +1 -2
- package/ReactCommon/react/renderer/components/root/RootProps.cpp +4 -4
- package/ReactCommon/react/renderer/components/root/tests/RootShadowNodeTest.cpp +3 -3
- package/ReactCommon/react/renderer/components/safeareaview/SafeAreaViewState.h +1 -1
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewEventEmitter.h +0 -1
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewProps.cpp +50 -36
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewProps.h +4 -0
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewState.h +4 -1
- package/ReactCommon/react/renderer/components/scrollview/conversions.h +35 -0
- package/ReactCommon/react/renderer/components/scrollview/primitives.h +17 -0
- package/ReactCommon/react/renderer/components/text/BaseTextProps.cpp +1 -1
- package/ReactCommon/react/renderer/components/text/BaseTextProps.h +0 -1
- package/ReactCommon/react/renderer/components/text/BaseTextShadowNode.cpp +1 -0
- package/ReactCommon/react/renderer/components/text/ParagraphLayoutManager.cpp +59 -0
- package/ReactCommon/react/renderer/components/text/ParagraphLayoutManager.h +59 -0
- package/ReactCommon/react/renderer/components/text/ParagraphProps.cpp +4 -2
- package/ReactCommon/react/renderer/components/text/ParagraphShadowNode.cpp +13 -15
- package/ReactCommon/react/renderer/components/text/ParagraphShadowNode.h +2 -6
- package/ReactCommon/react/renderer/components/text/ParagraphState.h +8 -11
- package/ReactCommon/react/renderer/components/text/RawTextShadowNode.h +4 -25
- package/ReactCommon/react/renderer/components/text/TextProps.h +0 -1
- package/ReactCommon/react/renderer/components/text/TextShadowNode.h +5 -23
- package/ReactCommon/react/renderer/components/text/tests/ParagraphLocalDataTest.cpp +7 -10
- package/ReactCommon/react/renderer/components/textinput/androidtextinput/react/renderer/components/androidtextinput/AndroidTextInputProps.cpp +56 -50
- package/ReactCommon/react/renderer/components/textinput/androidtextinput/react/renderer/components/androidtextinput/AndroidTextInputProps.h +0 -1
- package/ReactCommon/react/renderer/components/textinput/androidtextinput/react/renderer/components/androidtextinput/AndroidTextInputShadowNode.cpp +2 -1
- package/ReactCommon/react/renderer/components/textinput/iostextinput/BUCK +3 -0
- package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputEventEmitter.cpp → react/renderer/components/iostextinput/TextInputEventEmitter.cpp} +31 -1
- package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputEventEmitter.h → react/renderer/components/iostextinput/TextInputEventEmitter.h} +5 -0
- package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputProps.cpp → react/renderer/components/iostextinput/TextInputProps.cpp} +1 -1
- package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputShadowNode.cpp → react/renderer/components/iostextinput/TextInputShadowNode.cpp} +2 -1
- package/ReactCommon/react/renderer/components/textinput/iostextinput/{propsConversions.h → react/renderer/components/iostextinput/propsConversions.h} +4 -3
- package/ReactCommon/react/renderer/components/unimplementedview/UnimplementedViewComponentDescriptor.h +1 -1
- package/ReactCommon/react/renderer/components/view/AccessibilityPrimitives.h +3 -3
- package/ReactCommon/react/renderer/components/view/AccessibilityProps.cpp +21 -20
- package/ReactCommon/react/renderer/components/view/AccessibilityPropsMapBuffer.cpp +0 -2
- package/ReactCommon/react/renderer/components/view/AccessibilityPropsMapBuffer.h +4 -2
- package/ReactCommon/react/renderer/components/view/BUCK +1 -0
- package/ReactCommon/react/renderer/components/view/PointerEvent.h +1 -1
- package/ReactCommon/react/renderer/components/view/Touch.h +1 -1
- package/ReactCommon/react/renderer/components/view/ViewProps.cpp +63 -74
- package/ReactCommon/react/renderer/components/view/ViewProps.h +0 -1
- package/ReactCommon/react/renderer/components/view/ViewPropsMapBuffer.cpp +1 -1
- package/ReactCommon/react/renderer/components/view/YogaLayoutableShadowNode.cpp +207 -91
- package/ReactCommon/react/renderer/components/view/YogaLayoutableShadowNode.h +28 -31
- package/ReactCommon/react/renderer/components/view/YogaStylableProps.cpp +155 -7
- package/ReactCommon/react/renderer/components/view/YogaStylableProps.h +38 -1
- package/ReactCommon/react/renderer/components/view/accessibilityPropsConversions.h +10 -7
- package/ReactCommon/react/renderer/components/view/conversions.h +133 -59
- package/ReactCommon/react/renderer/components/view/primitives.h +49 -18
- package/ReactCommon/react/renderer/components/view/propsConversions.h +65 -8
- package/ReactCommon/react/renderer/components/view/tests/LayoutTest.cpp +88 -2
- package/ReactCommon/react/renderer/components/view/viewPropConversions.h +21 -3
- package/ReactCommon/react/renderer/core/BUCK +7 -3
- package/ReactCommon/react/renderer/core/ConcreteComponentDescriptor.h +1 -1
- package/ReactCommon/react/renderer/core/CoreFeatures.cpp +3 -0
- package/ReactCommon/react/renderer/core/CoreFeatures.h +15 -1
- package/ReactCommon/react/renderer/core/DynamicPropsUtilities.cpp +1 -0
- package/ReactCommon/react/renderer/core/DynamicPropsUtilities.h +8 -4
- package/ReactCommon/react/renderer/core/EventBeat.h +1 -1
- package/ReactCommon/react/renderer/core/EventDispatcher.cpp +10 -4
- package/ReactCommon/react/renderer/core/EventDispatcher.h +1 -1
- package/ReactCommon/react/renderer/core/EventListener.cpp +3 -3
- package/ReactCommon/react/renderer/core/EventListener.h +2 -3
- package/ReactCommon/react/renderer/core/EventLogger.cpp +22 -0
- package/ReactCommon/react/renderer/core/EventLogger.h +44 -0
- package/ReactCommon/react/renderer/core/EventQueueProcessor.cpp +12 -2
- package/ReactCommon/react/renderer/core/LayoutConstraints.h +1 -1
- package/ReactCommon/react/renderer/core/LayoutContext.h +0 -1
- package/ReactCommon/react/renderer/core/LayoutMetrics.h +2 -1
- package/ReactCommon/react/renderer/core/LayoutableShadowNode.cpp +16 -2
- package/ReactCommon/react/renderer/core/LayoutableShadowNode.h +2 -26
- package/ReactCommon/react/renderer/core/PropsMacros.h +21 -7
- package/ReactCommon/react/renderer/core/PropsMapBuffer.cpp +2 -3
- package/ReactCommon/react/renderer/core/PropsMapBuffer.h +1 -0
- package/ReactCommon/react/renderer/core/RawEvent.h +2 -0
- package/ReactCommon/react/renderer/core/RawProps.h +1 -1
- package/ReactCommon/react/renderer/core/RawPropsKeyMap.h +1 -1
- package/ReactCommon/react/renderer/core/RawPropsPrimitives.h +1 -1
- package/ReactCommon/react/renderer/core/Sealable.h +2 -2
- package/ReactCommon/react/renderer/core/ShadowNode.cpp +27 -3
- package/ReactCommon/react/renderer/core/ShadowNode.h +6 -20
- package/ReactCommon/react/renderer/core/ShadowNodeFamily.cpp +3 -3
- package/ReactCommon/react/renderer/core/ShadowNodeFamily.h +9 -2
- package/ReactCommon/react/renderer/core/ShadowNodeTraits.h +6 -11
- package/ReactCommon/react/renderer/core/TraitCast.h +90 -0
- package/ReactCommon/react/renderer/core/graphicsConversions.h +260 -0
- package/ReactCommon/react/renderer/core/propsConversions.h +1 -2
- package/ReactCommon/react/renderer/core/tests/EventQueueProcessorTest.cpp +2 -2
- package/ReactCommon/react/renderer/core/tests/LayoutableShadowNodeTest.cpp +147 -1
- package/ReactCommon/react/renderer/core/tests/RawPropsTest.cpp +1 -1
- package/ReactCommon/react/renderer/core/tests/traitCastTest.cpp +12 -2
- package/ReactCommon/react/renderer/debug/DebugStringConvertible.h +9 -0
- package/ReactCommon/react/renderer/debug/SystraceSection.h +13 -3
- package/ReactCommon/react/renderer/element/BUCK +2 -0
- package/ReactCommon/react/renderer/element/CMakeLists.txt +29 -0
- package/ReactCommon/react/renderer/graphics/BUCK +9 -12
- package/ReactCommon/react/renderer/graphics/CMakeLists.txt +4 -8
- package/ReactCommon/react/renderer/graphics/{platform/cxx/react/renderer/graphics/Color.cpp → Color.cpp} +1 -1
- package/ReactCommon/react/renderer/graphics/{platform/ios/Color.h → Color.h} +12 -16
- package/ReactCommon/react/renderer/graphics/Geometry.h +3 -12
- package/ReactCommon/react/renderer/graphics/React-graphics.podspec +18 -3
- package/ReactCommon/react/renderer/graphics/RectangleEdges.h +11 -1
- package/ReactCommon/react/renderer/graphics/Transform.h +5 -2
- package/{ReactAndroid/src/main/jni/react/jni/NativeTime.h → ReactCommon/react/renderer/graphics/Vector.h} +8 -1
- package/ReactCommon/react/renderer/graphics/conversions.h +18 -252
- package/ReactCommon/{yoga/yoga/internal/experiments.h → react/renderer/graphics/platform/android/react/renderer/graphics/Float.h} +8 -12
- package/ReactCommon/react/renderer/graphics/platform/android/react/renderer/graphics/PlatformColorParser.h +0 -1
- package/ReactCommon/react/renderer/graphics/platform/ios/{RCTPlatformColorUtils.mm → react/renderer/graphics/RCTPlatformColorUtils.mm} +1 -2
- package/ReactCommon/react/renderer/imagemanager/BUCK +4 -2
- package/ReactCommon/react/renderer/imagemanager/ImageRequest.h +1 -1
- package/ReactCommon/react/renderer/imagemanager/platform/ios/React-ImageManager.podspec +64 -0
- package/ReactCommon/react/renderer/imagemanager/platform/ios/{ImageManager.mm → react/renderer/imagemanager/ImageManager.mm} +1 -1
- package/ReactCommon/react/renderer/imagemanager/platform/ios/{ImageRequest.cpp → react/renderer/imagemanager/ImageRequest.cpp} +1 -1
- package/ReactCommon/react/renderer/imagemanager/platform/ios/{RCTImageManager.h → react/renderer/imagemanager/RCTImageManager.h} +1 -1
- package/ReactCommon/react/renderer/imagemanager/platform/ios/{RCTSyncImageManager.h → react/renderer/imagemanager/RCTSyncImageManager.h} +1 -1
- package/ReactCommon/react/renderer/imagemanager/primitives.h +2 -1
- package/ReactCommon/react/renderer/mapbuffer/MapBuffer.h +4 -2
- package/ReactCommon/react/renderer/mounting/Differentiator.cpp +1 -1
- package/ReactCommon/react/renderer/mounting/MountingCoordinator.cpp +2 -2
- package/ReactCommon/react/renderer/mounting/MountingCoordinator.h +1 -1
- package/ReactCommon/react/renderer/mounting/ShadowTree.cpp +21 -17
- package/ReactCommon/react/renderer/mounting/ShadowTree.h +11 -5
- package/ReactCommon/react/renderer/mounting/ShadowTreeDelegate.h +2 -2
- package/ReactCommon/react/renderer/mounting/ShadowTreeRegistry.cpp +11 -6
- package/ReactCommon/react/renderer/mounting/ShadowTreeRegistry.h +6 -3
- package/ReactCommon/react/renderer/mounting/ShadowView.cpp +1 -0
- package/ReactCommon/react/renderer/mounting/tests/ShadowTreeLifeCycleTest.cpp +8 -8
- package/ReactCommon/react/renderer/mounting/tests/StackingContextTest.cpp +8 -8
- package/ReactCommon/react/renderer/mounting/tests/StateReconciliationTest.cpp +2 -2
- package/ReactCommon/react/renderer/runtimescheduler/BUCK +1 -0
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler.cpp +17 -5
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler.h +6 -3
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeSchedulerBinding.cpp +3 -3
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeSchedulerCallInvoker.cpp +11 -2
- package/ReactCommon/react/renderer/runtimescheduler/RuntimeSchedulerCallInvoker.h +4 -3
- package/ReactCommon/react/renderer/runtimescheduler/{SchedulerPriority.h → SchedulerPriorityUtils.h} +3 -28
- package/ReactCommon/react/renderer/runtimescheduler/Task.cpp +23 -6
- package/ReactCommon/react/renderer/runtimescheduler/Task.h +13 -7
- package/ReactCommon/react/renderer/runtimescheduler/primitives.h +15 -4
- package/ReactCommon/react/renderer/runtimescheduler/tests/RuntimeSchedulerTest.cpp +1 -1
- package/ReactCommon/react/renderer/runtimescheduler/tests/SchedulerPriorityTest.cpp +1 -0
- package/ReactCommon/react/renderer/scheduler/Scheduler.cpp +42 -10
- package/ReactCommon/react/renderer/scheduler/Scheduler.h +3 -1
- package/ReactCommon/react/renderer/scheduler/SchedulerDelegate.h +3 -5
- package/ReactCommon/react/renderer/scheduler/SurfaceHandler.cpp +32 -34
- package/ReactCommon/react/renderer/scheduler/SurfaceHandler.h +4 -3
- package/ReactCommon/react/renderer/scheduler/SurfaceManager.cpp +3 -3
- package/ReactCommon/react/renderer/scheduler/SurfaceManager.h +2 -1
- package/ReactCommon/react/renderer/telemetry/tests/TransactionTelemetryTest.cpp +1 -1
- package/ReactCommon/react/renderer/templateprocessor/BUCK +2 -0
- package/ReactCommon/react/renderer/textlayoutmanager/BUCK +4 -2
- package/ReactCommon/react/renderer/textlayoutmanager/TextMeasureCache.h +1 -0
- package/ReactCommon/react/renderer/textlayoutmanager/platform/android/react/renderer/textlayoutmanager/TextLayoutManager.cpp +9 -2
- package/ReactCommon/react/renderer/textlayoutmanager/platform/android/react/renderer/textlayoutmanager/TextLayoutManager.h +7 -1
- package/ReactCommon/react/renderer/textlayoutmanager/platform/cxx/TextLayoutManager.cpp +9 -1
- package/ReactCommon/react/renderer/textlayoutmanager/platform/cxx/TextLayoutManager.h +7 -1
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{NSTextStorage+FontScaling.m → react/renderer/textlayoutmanager/NSTextStorage+FontScaling.m} +3 -3
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTTextLayoutManager.h → react/renderer/textlayoutmanager/RCTTextLayoutManager.h} +10 -4
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTTextLayoutManager.mm → react/renderer/textlayoutmanager/RCTTextLayoutManager.mm} +38 -23
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{TextLayoutManager.h → react/renderer/textlayoutmanager/TextLayoutManager.h} +7 -1
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{TextLayoutManager.mm → react/renderer/textlayoutmanager/TextLayoutManager.mm} +24 -3
- package/ReactCommon/react/renderer/timeline/TimelineController.h +1 -1
- package/ReactCommon/react/renderer/uimanager/BUCK +2 -0
- package/ReactCommon/react/renderer/uimanager/SurfaceRegistryBinding.cpp +4 -4
- package/ReactCommon/react/renderer/uimanager/SurfaceRegistryBinding.h +2 -2
- package/ReactCommon/react/renderer/uimanager/UIManager.cpp +158 -41
- package/ReactCommon/react/renderer/uimanager/UIManager.h +16 -3
- package/ReactCommon/react/renderer/uimanager/UIManagerAnimationDelegate.h +8 -0
- package/ReactCommon/react/renderer/uimanager/UIManagerBinding.cpp +86 -4
- package/ReactCommon/react/renderer/uimanager/UIManagerDelegate.h +2 -1
- package/ReactCommon/react/renderer/uimanager/primitives.h +48 -24
- package/ReactCommon/react/utils/.clang-tidy +1 -0
- package/ReactCommon/react/utils/BUCK +6 -2
- package/ReactCommon/react/utils/ContextContainer.h +8 -8
- package/ReactCommon/react/utils/SharedFunction.h +4 -6
- package/ReactCommon/reactperflogger/.clang-tidy +1 -0
- package/ReactCommon/reactperflogger/React-perflogger.podspec +1 -1
- package/ReactCommon/runtimeexecutor/.clang-tidy +1 -0
- package/ReactCommon/runtimeexecutor/React-runtimeexecutor.podspec +1 -1
- package/ReactCommon/yoga/yoga/CMakeLists.txt +41 -0
- package/ReactCommon/yoga/yoga/CompactValue.h +8 -0
- package/ReactCommon/yoga/yoga/Utils.cpp +1 -1
- package/ReactCommon/yoga/yoga/Utils.h +2 -4
- package/ReactCommon/yoga/yoga/YGEnums.cpp +4 -0
- package/ReactCommon/yoga/yoga/YGEnums.h +3 -1
- package/ReactCommon/yoga/yoga/YGLayout.h +1 -26
- package/ReactCommon/yoga/yoga/YGNode.cpp +0 -47
- package/ReactCommon/yoga/yoga/YGNode.h +0 -4
- package/ReactCommon/yoga/yoga/YGNodePrint.cpp +3 -1
- package/ReactCommon/yoga/yoga/Yoga-internal.h +6 -3
- package/ReactCommon/yoga/yoga/Yoga.cpp +55 -127
- package/ReactCommon/yoga/yoga/Yoga.h +0 -5
- package/ReactCommon/yoga/yoga/event/event.h +0 -5
- package/build.gradle.kts +1 -0
- package/flow/global.js +29 -4
- package/flow/jest.js +258 -164
- package/flow/use-sync-external-store.js +1 -0
- package/gradle.properties +0 -0
- package/index.js +56 -42
- package/interface.js +1 -1
- package/jest/local-setup.js +33 -0
- package/jest/mockComponent.js +4 -2
- package/jest/mockNativeComponent.js +1 -1
- package/jest/mockScrollView.js +2 -1
- package/jest/react-native-env.js +1 -3
- package/jest/setup.js +11 -8
- package/local-cli/cli.js +0 -0
- package/package.json +26 -101
- package/react-native.config.js +2 -2
- package/rn-get-polyfills.js +1 -1
- package/scripts/cocoapods/__tests__/codegen-test.rb +242 -0
- package/scripts/cocoapods/__tests__/codegen_utils-test.rb +589 -0
- package/scripts/cocoapods/__tests__/fabric-test.rb +68 -0
- package/scripts/cocoapods/__tests__/flipper-test.rb +153 -0
- package/scripts/cocoapods/__tests__/jsengine-test.rb +126 -0
- package/scripts/cocoapods/__tests__/local_podspec_patch-test.rb +167 -0
- package/scripts/cocoapods/__tests__/new_architecture-test.rb +297 -0
- package/scripts/cocoapods/__tests__/test_utils/CodegenScriptPhaseExtractorMock.rb +21 -0
- package/scripts/cocoapods/__tests__/test_utils/CodegenUtilsMock.rb +108 -0
- package/scripts/cocoapods/__tests__/test_utils/DirMock.rb +72 -0
- package/scripts/cocoapods/__tests__/test_utils/EnvironmentMock.rb +21 -0
- package/scripts/cocoapods/__tests__/test_utils/FileMock.rb +113 -0
- package/scripts/cocoapods/__tests__/test_utils/FileUtilsMock.rb +40 -0
- package/scripts/cocoapods/__tests__/test_utils/FinderMock.rb +28 -0
- package/scripts/cocoapods/__tests__/test_utils/InstallerMock.rb +222 -0
- package/scripts/cocoapods/__tests__/test_utils/LocalPodspecPatchMock.rb +14 -0
- package/scripts/cocoapods/__tests__/test_utils/Open3Mock.rb +43 -0
- package/scripts/cocoapods/__tests__/test_utils/PathnameMock.rb +42 -0
- package/scripts/cocoapods/__tests__/test_utils/PodMock.rb +144 -0
- package/scripts/cocoapods/__tests__/test_utils/SpecMock.rb +30 -0
- package/scripts/cocoapods/__tests__/test_utils/SysctlCheckerMock.rb +21 -0
- package/scripts/cocoapods/__tests__/test_utils/TargetDefinitionMock.rb +12 -0
- package/scripts/cocoapods/__tests__/test_utils/podSpy.rb +38 -0
- package/scripts/cocoapods/__tests__/test_utils/systemUtils.rb +14 -0
- package/scripts/cocoapods/__tests__/utils-test.rb +780 -0
- package/scripts/cocoapods/codegen.rb +23 -19
- package/scripts/cocoapods/codegen_utils.rb +73 -37
- package/scripts/cocoapods/fabric.rb +2 -2
- package/scripts/cocoapods/flipper.rb +1 -4
- package/scripts/cocoapods/jsengine.rb +1 -46
- package/scripts/cocoapods/local_podspec_patch.rb +6 -6
- package/scripts/cocoapods/new_architecture.rb +32 -4
- package/scripts/cocoapods/utils.rb +253 -19
- package/scripts/codegen/__test_fixtures__/fixtures.js +132 -0
- package/scripts/codegen/__tests__/generate-artifacts-executor-test.js +500 -0
- package/scripts/codegen/__tests__/generate-specs-cli-executor-test.js +88 -0
- package/scripts/codegen/codegen-utils.js +2 -2
- package/scripts/codegen/generate-artifacts-executor.js +45 -18
- package/scripts/codegen/generate-legacy-interop-components.js +123 -0
- package/scripts/find-node-for-xcode.sh +4 -1
- package/scripts/generate-provider-cli.js +1 -1
- package/scripts/hermes/prepare-hermes-for-build.js +1 -1
- package/scripts/packager.sh +3 -3
- package/scripts/react-native-xcode.sh +2 -3
- package/scripts/react_native_pods.rb +42 -21
- package/scripts/react_native_pods_utils/script_phases.rb +1 -1
- package/scripts/react_native_pods_utils/script_phases.sh +4 -4
- package/scripts/xcode/with-environment.sh +6 -6
- package/sdks/.hermesversion +1 -1
- package/sdks/hermes-engine/hermes-engine.podspec +21 -50
- package/sdks/hermes-engine/hermes-utils.rb +122 -4
- package/sdks/hermes-engine/utils/build-apple-framework.sh +12 -2
- package/sdks/hermes-engine/utils/build-hermes-xcode.sh +7 -0
- package/sdks/hermes-engine/utils/build-hermesc-xcode.sh +9 -2
- package/sdks/hermes-engine/utils/copy-hermes-xcode.sh +1 -16
- package/sdks/hermes-engine/utils/create-dummy-hermes-xcframework.sh +30 -0
- package/sdks/hermesc/linux64-bin/hermesc +0 -0
- package/sdks/hermesc/osx-bin/hermesc +0 -0
- package/sdks/hermesc/win64-bin/hermesc.exe +0 -0
- package/settings.gradle.kts +1 -0
- package/template/Gemfile +2 -2
- package/template/__tests__/{App-test.tsx → App.test.tsx} +3 -0
- package/template/_eslintrc.js +1 -1
- package/template/_gitignore +3 -0
- package/template/_watchmanconfig +1 -1
- package/template/android/app/build.gradle +2 -47
- package/template/android/app/src/main/java/com/helloworld/MainActivity.java +1 -4
- package/template/android/app/src/main/res/drawable/rn_edit_text_material.xml +1 -1
- package/template/android/build.gradle +1 -1
- package/template/android/gradle/wrapper/gradle-wrapper.jar +0 -0
- package/template/android/gradle/wrapper/gradle-wrapper.properties +2 -1
- package/template/android/gradle.properties +1 -1
- package/template/android/gradlew +14 -4
- package/template/android/gradlew.bat +9 -6
- package/template/android/settings.gradle +1 -1
- package/template/app.json +1 -1
- package/template/ios/HelloWorld/AppDelegate.mm +0 -10
- package/template/ios/Podfile +8 -6
- package/template/jest.config.js +3 -0
- package/template/package.json +6 -7
- package/types/index.d.ts +2 -6
- package/types/modules/Codegen.d.ts +4 -4
- package/types/modules/globals.d.ts +27 -25
- package/types/public/DeprecatedPropertiesAlias.d.ts +0 -20
- package/types/public/ReactNativeRenderer.d.ts +2 -7
- package/types/tslint.json +2 -1
- package/CHANGELOG.md +0 -4860
- package/Libraries/.npmignore +0 -1
- package/Libraries/Animated/createAnimatedComponentInjection.js +0 -48
- package/Libraries/Animated/createAnimatedComponent_EXPERIMENTAL.js +0 -48
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.flow.js +0 -208
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.flow.js +0 -58
- package/Libraries/Components/DatePicker/DatePickerIOS.android.js +0 -47
- package/Libraries/Components/DatePicker/DatePickerIOS.d.ts +0 -92
- package/Libraries/Components/DatePicker/DatePickerIOS.flow.android.js +0 -14
- package/Libraries/Components/DatePicker/DatePickerIOS.flow.ios.js +0 -113
- package/Libraries/Components/DatePicker/DatePickerIOS.ios.js +0 -242
- package/Libraries/Components/DatePicker/RCTDatePickerNativeComponent.js +0 -60
- package/Libraries/Components/DatePickerAndroid/NativeDatePickerAndroid.js +0 -26
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.android.js +0 -45
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.d.ts +0 -62
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.ios.js +0 -75
- package/Libraries/Components/ProgressViewIOS/RCTProgressViewNativeComponent.js +0 -33
- package/Libraries/Components/SafeAreaView/SafeAreaView.flow.js +0 -19
- package/Libraries/Components/Slider/Slider.d.ts +0 -132
- package/Libraries/Components/Slider/Slider.js +0 -282
- package/Libraries/Components/Slider/SliderNativeComponent.js +0 -56
- package/Libraries/Interaction/Batchinator.js +0 -76
- package/Libraries/Interaction/BridgeSpyStallHandler.js +0 -63
- package/Libraries/Interaction/InteractionStallDebugger.js +0 -23
- package/Libraries/Interaction/PanResponder.flow.js +0 -257
- package/Libraries/Lists/CellRenderMask.js +0 -155
- package/Libraries/Lists/ChildListCollection.js +0 -72
- package/Libraries/Lists/StateSafePureComponent.js +0 -85
- package/Libraries/Lists/VirtualizedList.d.ts +0 -347
- package/Libraries/Lists/VirtualizedListCellRenderer.js +0 -259
- package/Libraries/Lists/VirtualizedListProps.js +0 -279
- package/Libraries/Performance/PureComponentDebug.js +0 -74
- package/Libraries/Reliability/UserFlow.js +0 -158
- package/Libraries/Renderer/implementations/ReactNativeRenderer.d.ts +0 -149
- package/Libraries/Renderer/shims/ReactNativeTypes.d.ts +0 -141
- package/Libraries/Utilities/MatrixMath.js +0 -748
- package/Libraries/Utilities/PixelRatio.js.flow +0 -21
- package/Libraries/Utilities/buildStyleInterpolator.js +0 -209
- package/Libraries/Utilities/clamp.js +0 -23
- package/Libraries/Utilities/deprecatedPropType.js +0 -36
- package/Libraries/Utilities/groupByEveryN.js +0 -51
- package/Libraries/Utilities/mergeIntoFast.js +0 -26
- package/Libraries/Utilities/setAndForwardRef.js +0 -71
- package/Libraries/Utilities/truncate.js +0 -51
- package/Libraries/WebSocket/RCTSRWebSocket.h +0 -136
- package/Libraries/WebSocket/RCTSRWebSocket.m +0 -1746
- package/React/Base/RCTWeakProxy.m +0 -30
- package/React/Fabric/Mounting/ComponentViews/Slider/RCTSliderComponentView.h +0 -21
- package/React/Fabric/Mounting/ComponentViews/Slider/RCTSliderComponentView.mm +0 -352
- package/React/Views/RCTDatePicker.m +0 -70
- package/React/Views/RCTDatePickerManager.h +0 -19
- package/React/Views/RCTDatePickerManager.m +0 -105
- package/React/Views/RCTProgressViewManager.h +0 -12
- package/React/Views/RCTProgressViewManager.m +0 -45
- package/React/Views/RCTSlider.h +0 -26
- package/React/Views/RCTSlider.m +0 -104
- package/React/Views/RCTSliderManager.m +0 -91
- package/ReactAndroid/.npmignore +0 -10
- package/ReactAndroid/Android-prebuilt.mk +0 -211
- package/ReactAndroid/external-artifacts/.npmignore +0 -3
- package/ReactAndroid/hermes-engine/.npmignore +0 -3
- package/ReactAndroid/src/main/AndroidManifest.xml +0 -5
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/CppViewMutationsWrapper.java +0 -47
- package/ReactAndroid/src/main/java/com/facebook/react/views/slider/ReactSlider.java +0 -116
- package/ReactAndroid/src/main/java/com/facebook/react/views/slider/ReactSliderEvent.java +0 -54
- package/ReactAndroid/src/main/java/com/facebook/react/views/slider/ReactSliderManager.java +0 -336
- package/ReactAndroid/src/main/java/com/facebook/react/views/slider/ReactSlidingCompleteEvent.java +0 -54
- package/ReactAndroid/src/main/jni/react/cxxcomponents/BUCK +0 -44
- package/ReactAndroid/src/main/jni/react/cxxcomponents/CMakeLists.txt +0 -22
- package/ReactAndroid/src/main/jni/react/cxxcomponents/Component.h +0 -66
- package/ReactAndroid/src/main/jni/react/cxxcomponents/ComponentManager.h +0 -26
- package/ReactAndroid/src/main/jni/react/fabric/ComponentRegistryResolver.cpp +0 -51
- package/ReactAndroid/src/main/jni/react/fabric/ComponentRegistryResolver.h +0 -47
- package/ReactAndroid/src/main/jni/react/fabric/CppComponentRegistry.cpp +0 -73
- package/ReactAndroid/src/main/jni/react/fabric/CppComponentRegistry.h +0 -64
- package/ReactAndroid/src/main/jni/react/fabric/CppViewMutationsWrapper.cpp +0 -100
- package/ReactAndroid/src/main/jni/react/fabric/CppViewMutationsWrapper.h +0 -39
- package/ReactAndroid/src/main/jni/react/jni/NativeTime.cpp +0 -26
- package/ReactCommon/react/renderer/components/slider/BUCK +0 -117
- package/ReactCommon/react/renderer/components/slider/CMakeLists.txt +0 -45
- package/ReactCommon/react/renderer/components/slider/SliderComponentDescriptor.h +0 -58
- package/ReactCommon/react/renderer/components/slider/SliderShadowNode.cpp +0 -100
- package/ReactCommon/react/renderer/components/slider/SliderShadowNode.h +0 -77
- package/ReactCommon/react/renderer/components/slider/SliderState.cpp +0 -44
- package/ReactCommon/react/renderer/components/slider/SliderState.h +0 -89
- package/ReactCommon/react/renderer/components/slider/platform/android/react/renderer/components/slider/SliderMeasurementsManager.cpp +0 -72
- package/ReactCommon/react/renderer/components/slider/platform/android/react/renderer/components/slider/SliderMeasurementsManager.h +0 -40
- package/ReactCommon/react/renderer/components/slider/platform/ios/SliderMeasurementsManager.cpp +0 -23
- package/ReactCommon/react/renderer/components/slider/platform/ios/SliderMeasurementsManager.h +0 -33
- package/ReactCommon/react/renderer/components/slider/tests/SliderTest.cpp +0 -14
- package/ReactCommon/react/renderer/graphics/platform/cxx/react/renderer/graphics/Color.h +0 -80
- package/ReactCommon/react/renderer/graphics/platform/ios/Color.cpp +0 -63
- package/ReactCommon/yoga/yoga/internal/experiments-inl.h +0 -32
- package/ReactCommon/yoga/yoga/internal/experiments.cpp +0 -38
- package/flow/JSITimerInternalType.js +0 -30
- package/react.gradle +0 -486
- package/template/_node-version +0 -1
- package/template/_ruby-version +0 -1
- package/types/.npmignore +0 -1
- /package/ReactCommon/react/nativemodule/core/platform/ios/{RCTBlockGuard.mm → ReactCommon/RCTBlockGuard.mm} +0 -0
- /package/ReactCommon/react/nativemodule/samples/platform/ios/{RCTSampleTurboCxxModule.h → ReactCommon/RCTSampleTurboCxxModule.h} +0 -0
- /package/ReactCommon/react/nativemodule/samples/platform/ios/{RCTSampleTurboCxxModule.mm → ReactCommon/RCTSampleTurboCxxModule.mm} +0 -0
- /package/ReactCommon/react/nativemodule/samples/platform/ios/{RCTSampleTurboModule.h → ReactCommon/RCTSampleTurboModule.h} +0 -0
- /package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputComponentDescriptor.h → react/renderer/components/iostextinput/TextInputComponentDescriptor.h} +0 -0
- /package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputProps.h → react/renderer/components/iostextinput/TextInputProps.h} +0 -0
- /package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputShadowNode.h → react/renderer/components/iostextinput/TextInputShadowNode.h} +0 -0
- /package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputState.cpp → react/renderer/components/iostextinput/TextInputState.cpp} +0 -0
- /package/ReactCommon/react/renderer/components/textinput/iostextinput/{TextInputState.h → react/renderer/components/iostextinput/TextInputState.h} +0 -0
- /package/ReactCommon/react/renderer/components/textinput/iostextinput/{conversions.h → react/renderer/components/iostextinput/conversions.h} +0 -0
- /package/ReactCommon/react/renderer/components/textinput/iostextinput/{primitives.h → react/renderer/components/iostextinput/primitives.h} +0 -0
- /package/ReactCommon/react/renderer/graphics/platform/ios/{Float.h → react/renderer/graphics/Float.h} +0 -0
- /package/ReactCommon/react/renderer/graphics/platform/ios/{PlatformColorParser.h → react/renderer/graphics/PlatformColorParser.h} +0 -0
- /package/ReactCommon/react/renderer/graphics/platform/ios/{RCTPlatformColorUtils.h → react/renderer/graphics/RCTPlatformColorUtils.h} +0 -0
- /package/ReactCommon/react/renderer/imagemanager/platform/ios/{RCTImageManager.mm → react/renderer/imagemanager/RCTImageManager.mm} +0 -0
- /package/ReactCommon/react/renderer/imagemanager/platform/ios/{RCTImageManagerProtocol.h → react/renderer/imagemanager/RCTImageManagerProtocol.h} +0 -0
- /package/ReactCommon/react/renderer/imagemanager/platform/ios/{RCTImagePrimitivesConversions.h → react/renderer/imagemanager/RCTImagePrimitivesConversions.h} +0 -0
- /package/ReactCommon/react/renderer/imagemanager/platform/ios/{RCTSyncImageManager.mm → react/renderer/imagemanager/RCTSyncImageManager.mm} +0 -0
- /package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{NSTextStorage+FontScaling.h → react/renderer/textlayoutmanager/NSTextStorage+FontScaling.h} +0 -0
- /package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTAttributedTextUtils.h → react/renderer/textlayoutmanager/RCTAttributedTextUtils.h} +0 -0
- /package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTAttributedTextUtils.mm → react/renderer/textlayoutmanager/RCTAttributedTextUtils.mm} +0 -0
- /package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTFontProperties.h → react/renderer/textlayoutmanager/RCTFontProperties.h} +0 -0
- /package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTFontUtils.h → react/renderer/textlayoutmanager/RCTFontUtils.h} +0 -0
- /package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTFontUtils.mm → react/renderer/textlayoutmanager/RCTFontUtils.mm} +0 -0
- /package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/{RCTTextPrimitivesConversions.h → react/renderer/textlayoutmanager/RCTTextPrimitivesConversions.h} +0 -0
|
@@ -7,46 +7,16 @@
|
|
|
7
7
|
|
|
8
8
|
#import "RCTSurfaceTouchHandler.h"
|
|
9
9
|
|
|
10
|
-
#import <React/
|
|
10
|
+
#import <React/RCTIdentifierPool.h>
|
|
11
11
|
#import <React/RCTUtils.h>
|
|
12
12
|
#import <React/RCTViewComponentView.h>
|
|
13
13
|
|
|
14
14
|
#import "RCTConversions.h"
|
|
15
|
+
#import "RCTSurfacePointerHandler.h"
|
|
15
16
|
#import "RCTTouchableComponentViewProtocol.h"
|
|
16
17
|
|
|
17
18
|
using namespace facebook::react;
|
|
18
19
|
|
|
19
|
-
template <size_t size>
|
|
20
|
-
class IdentifierPool {
|
|
21
|
-
public:
|
|
22
|
-
void enqueue(int index)
|
|
23
|
-
{
|
|
24
|
-
usage[index] = false;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
int dequeue()
|
|
28
|
-
{
|
|
29
|
-
while (true) {
|
|
30
|
-
if (!usage[lastIndex]) {
|
|
31
|
-
usage[lastIndex] = true;
|
|
32
|
-
return lastIndex;
|
|
33
|
-
}
|
|
34
|
-
lastIndex = (lastIndex + 1) % size;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
void reset()
|
|
39
|
-
{
|
|
40
|
-
for (int i = 0; i < size; i++) {
|
|
41
|
-
usage[i] = false;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
private:
|
|
46
|
-
bool usage[size];
|
|
47
|
-
int lastIndex;
|
|
48
|
-
};
|
|
49
|
-
|
|
50
20
|
typedef NS_ENUM(NSInteger, RCTTouchEventType) {
|
|
51
21
|
RCTTouchEventTypeTouchStart,
|
|
52
22
|
RCTTouchEventTypeTouchMove,
|
|
@@ -58,52 +28,6 @@ struct ActiveTouch {
|
|
|
58
28
|
Touch touch;
|
|
59
29
|
SharedTouchEventEmitter eventEmitter;
|
|
60
30
|
|
|
61
|
-
/*
|
|
62
|
-
* The type of touch received.
|
|
63
|
-
*/
|
|
64
|
-
UITouchType touchType;
|
|
65
|
-
|
|
66
|
-
/*
|
|
67
|
-
* The radius (in points) of the touch.
|
|
68
|
-
*/
|
|
69
|
-
CGFloat majorRadius;
|
|
70
|
-
|
|
71
|
-
/*
|
|
72
|
-
* The altitude (in radians) of the stylus.
|
|
73
|
-
*/
|
|
74
|
-
CGFloat altitudeAngle;
|
|
75
|
-
|
|
76
|
-
/*
|
|
77
|
-
* The azimuth angle (in radians) of the stylus.
|
|
78
|
-
*/
|
|
79
|
-
CGFloat azimuthAngle;
|
|
80
|
-
|
|
81
|
-
/*
|
|
82
|
-
* The button mask of the touch
|
|
83
|
-
*/
|
|
84
|
-
UIEventButtonMask buttonMask;
|
|
85
|
-
|
|
86
|
-
/*
|
|
87
|
-
* The bit mask of modifier flags in the gesture represented by the receiver.
|
|
88
|
-
*/
|
|
89
|
-
UIKeyModifierFlags modifierFlags;
|
|
90
|
-
|
|
91
|
-
/*
|
|
92
|
-
* Indicates if the active touch represents the primary pointer of this pointer type.
|
|
93
|
-
*/
|
|
94
|
-
bool isPrimary;
|
|
95
|
-
|
|
96
|
-
/*
|
|
97
|
-
* The button number that was pressed (if applicable) when the event was fired.
|
|
98
|
-
*/
|
|
99
|
-
int button;
|
|
100
|
-
|
|
101
|
-
/*
|
|
102
|
-
* Informs the event system that when the touch is released it should be treated as the
|
|
103
|
-
* pointer leaving the screen entirely.
|
|
104
|
-
*/
|
|
105
|
-
bool shouldLeaveWhenReleased;
|
|
106
|
-
|
|
107
31
|
/*
|
|
108
32
|
* A component view on which the touch was begun.
|
|
109
33
|
*/
|
|
@@ -124,89 +48,9 @@ struct ActiveTouch {
|
|
|
124
48
|
};
|
|
125
49
|
};
|
|
126
50
|
|
|
127
|
-
// Mouse and Pen pointers get reserved IDs so they stay consistent no matter the order
|
|
128
|
-
// at which events come in
|
|
129
|
-
static int const kMousePointerId = 0;
|
|
130
|
-
static int const kPencilPointerId = 1;
|
|
131
|
-
|
|
132
|
-
// If a new reserved ID is added above this should be incremented to ensure touch events
|
|
133
|
-
// do not conflict
|
|
134
|
-
static int const kTouchIdentifierPoolOffset = 2;
|
|
135
|
-
|
|
136
|
-
// Returns a CGPoint which represents the tiltX/Y values (in RADIANS)
|
|
137
|
-
// Adapted from https://gist.github.com/k3a/2903719bb42b48c9198d20c2d6f73ac1
|
|
138
|
-
static CGPoint SphericalToTilt(CGFloat altitudeAngleRad, CGFloat azimuthAngleRad)
|
|
139
|
-
{
|
|
140
|
-
if (altitudeAngleRad == M_PI / 2.0) {
|
|
141
|
-
return CGPointMake(0.0, 0.0);
|
|
142
|
-
} else if (altitudeAngleRad == 0.0) {
|
|
143
|
-
// when pen is laying on the pad it is impossible to precisely encode but at least approximate for 4 cases
|
|
144
|
-
if (azimuthAngleRad > 7.0 * M_PI / 4.0 || azimuthAngleRad <= M_PI / 4.0) {
|
|
145
|
-
// for azimuthRad == 0, the pen is on the positive Y axis
|
|
146
|
-
return CGPointMake(0.0, M_PI / 2.0);
|
|
147
|
-
} else if (azimuthAngleRad > M_PI / 4.0 && azimuthAngleRad <= 3 * M_PI / 4.0) {
|
|
148
|
-
// for azimuthRad == math.pi/2 the pen is on the positive X axis
|
|
149
|
-
return CGPointMake(M_PI / 2.0, 0.0);
|
|
150
|
-
} else if (azimuthAngleRad > 3.0 * M_PI / 4.0 && azimuthAngleRad <= 5.0 * M_PI / 4.0) {
|
|
151
|
-
// for azimuthRad == math.pi, the pen is on the negative Y axis
|
|
152
|
-
return CGPointMake(0.0, -M_PI / 2.0);
|
|
153
|
-
} else if (azimuthAngleRad > 5.0 * M_PI / 4.0 && azimuthAngleRad <= 7.0 * M_PI / 4.0) {
|
|
154
|
-
// for azimuthRad == math.pi + math.pi/2 pen on negative X axis
|
|
155
|
-
return CGPointMake(-M_PI / 2.0, 0.0);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
CGFloat tanAlt = tan(altitudeAngleRad); // tan(x) = sin(x)/cos(x)
|
|
160
|
-
|
|
161
|
-
CGFloat tiltXrad = atan(sin(azimuthAngleRad) / tanAlt);
|
|
162
|
-
CGFloat tiltYrad = atan(cos(azimuthAngleRad) / tanAlt);
|
|
163
|
-
|
|
164
|
-
return CGPointMake(tiltXrad, tiltYrad);
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
static CGFloat RadsToDegrees(CGFloat rads)
|
|
168
|
-
{
|
|
169
|
-
return rads * 180 / M_PI;
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
static int ButtonMaskToButtons(UIEventButtonMask buttonMask)
|
|
173
|
-
{
|
|
174
|
-
int buttonsMaskResult = 0;
|
|
175
|
-
if (@available(iOS 13.4, *)) {
|
|
176
|
-
if ((buttonMask & UIEventButtonMaskPrimary) != 0) {
|
|
177
|
-
buttonsMaskResult |= 1;
|
|
178
|
-
}
|
|
179
|
-
if ((buttonMask & UIEventButtonMaskSecondary) != 0) {
|
|
180
|
-
buttonsMaskResult |= 2;
|
|
181
|
-
}
|
|
182
|
-
// undocumented mask value which represents the "auxiliary button" (i.e. middle mouse button)
|
|
183
|
-
if ((buttonMask & 0x4) != 0) {
|
|
184
|
-
buttonsMaskResult |= 4;
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
return buttonsMaskResult;
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
static int ButtonMaskDiffToButton(UIEventButtonMask prevButtonMask, UIEventButtonMask curButtonMask)
|
|
191
|
-
{
|
|
192
|
-
if (@available(iOS 13.4, *)) {
|
|
193
|
-
if ((prevButtonMask & UIEventButtonMaskPrimary) != (curButtonMask & UIEventButtonMaskPrimary)) {
|
|
194
|
-
return 0;
|
|
195
|
-
}
|
|
196
|
-
if ((prevButtonMask & 0x4) != (curButtonMask & 0x4)) {
|
|
197
|
-
return 1;
|
|
198
|
-
}
|
|
199
|
-
if ((prevButtonMask & UIEventButtonMaskSecondary) != (curButtonMask & UIEventButtonMaskSecondary)) {
|
|
200
|
-
return 2;
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
return -1;
|
|
204
|
-
}
|
|
205
|
-
|
|
206
51
|
static void UpdateActiveTouchWithUITouch(
|
|
207
52
|
ActiveTouch &activeTouch,
|
|
208
53
|
UITouch *uiTouch,
|
|
209
|
-
UIEvent *uiEvent,
|
|
210
54
|
UIView *rootComponentView,
|
|
211
55
|
CGPoint rootViewOriginOffset)
|
|
212
56
|
{
|
|
@@ -214,7 +58,6 @@ static void UpdateActiveTouchWithUITouch(
|
|
|
214
58
|
CGPoint pagePoint = [uiTouch locationInView:rootComponentView];
|
|
215
59
|
CGPoint screenPoint = [rootComponentView convertPoint:pagePoint
|
|
216
60
|
toCoordinateSpace:rootComponentView.window.screen.coordinateSpace];
|
|
217
|
-
|
|
218
61
|
pagePoint = CGPointMake(pagePoint.x + rootViewOriginOffset.x, pagePoint.y + rootViewOriginOffset.y);
|
|
219
62
|
|
|
220
63
|
activeTouch.touch.offsetPoint = RCTPointFromCGPoint(offsetPoint);
|
|
@@ -226,28 +69,9 @@ static void UpdateActiveTouchWithUITouch(
|
|
|
226
69
|
if (RCTForceTouchAvailable()) {
|
|
227
70
|
activeTouch.touch.force = RCTZeroIfNaN(uiTouch.force / uiTouch.maximumPossibleForce);
|
|
228
71
|
}
|
|
229
|
-
|
|
230
|
-
activeTouch.touchType = uiTouch.type;
|
|
231
|
-
activeTouch.majorRadius = uiTouch.majorRadius;
|
|
232
|
-
activeTouch.altitudeAngle = uiTouch.altitudeAngle;
|
|
233
|
-
activeTouch.azimuthAngle = [uiTouch azimuthAngleInView:nil];
|
|
234
|
-
if (@available(iOS 13.4, *)) {
|
|
235
|
-
UIEventButtonMask nextButtonMask = 0;
|
|
236
|
-
if (uiTouch.phase != UITouchPhaseEnded) {
|
|
237
|
-
nextButtonMask = uiTouch.type == UITouchTypeIndirectPointer ? uiEvent.buttonMask : 1;
|
|
238
|
-
}
|
|
239
|
-
activeTouch.button = ButtonMaskDiffToButton(activeTouch.buttonMask, nextButtonMask);
|
|
240
|
-
activeTouch.buttonMask = nextButtonMask;
|
|
241
|
-
activeTouch.modifierFlags = uiEvent.modifierFlags;
|
|
242
|
-
} else {
|
|
243
|
-
activeTouch.button = 0;
|
|
244
|
-
activeTouch.buttonMask = 0;
|
|
245
|
-
activeTouch.modifierFlags = 0;
|
|
246
|
-
}
|
|
247
72
|
}
|
|
248
73
|
|
|
249
|
-
static ActiveTouch
|
|
250
|
-
CreateTouchWithUITouch(UITouch *uiTouch, UIEvent *uiEvent, UIView *rootComponentView, CGPoint rootViewOriginOffset)
|
|
74
|
+
static ActiveTouch CreateTouchWithUITouch(UITouch *uiTouch, UIView *rootComponentView, CGPoint rootViewOriginOffset)
|
|
251
75
|
{
|
|
252
76
|
ActiveTouch activeTouch = {};
|
|
253
77
|
|
|
@@ -263,145 +87,9 @@ CreateTouchWithUITouch(UITouch *uiTouch, UIEvent *uiEvent, UIView *rootComponent
|
|
|
263
87
|
}
|
|
264
88
|
componentView = componentView.superview;
|
|
265
89
|
}
|
|
266
|
-
UpdateActiveTouchWithUITouch(activeTouch, uiTouch, uiEvent, rootComponentView, rootViewOriginOffset);
|
|
267
|
-
return activeTouch;
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
static UIView *FindClosestFabricManagedTouchableView(UIView *componentView)
|
|
271
|
-
{
|
|
272
|
-
while (componentView) {
|
|
273
|
-
if ([componentView respondsToSelector:@selector(touchEventEmitterAtPoint:)]) {
|
|
274
|
-
return componentView;
|
|
275
|
-
}
|
|
276
|
-
componentView = componentView.superview;
|
|
277
|
-
}
|
|
278
|
-
return nil;
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
static NSOrderedSet<RCTReactTaggedView *> *GetTouchableViewsInPathToRoot(UIView *componentView)
|
|
282
|
-
{
|
|
283
|
-
NSMutableOrderedSet *results = [NSMutableOrderedSet orderedSet];
|
|
284
|
-
do {
|
|
285
|
-
if ([componentView respondsToSelector:@selector(touchEventEmitterAtPoint:)]) {
|
|
286
|
-
[results addObject:[RCTReactTaggedView wrap:componentView]];
|
|
287
|
-
}
|
|
288
|
-
componentView = componentView.superview;
|
|
289
|
-
} while (componentView);
|
|
290
|
-
return results;
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
static SharedTouchEventEmitter GetTouchEmitterFromView(UIView *componentView, CGPoint point)
|
|
294
|
-
{
|
|
295
|
-
return [(id<RCTTouchableComponentViewProtocol>)componentView touchEventEmitterAtPoint:point];
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
static const char *PointerTypeCStringFromUITouchType(UITouchType type)
|
|
299
|
-
{
|
|
300
|
-
switch (type) {
|
|
301
|
-
case UITouchTypeDirect:
|
|
302
|
-
return "touch";
|
|
303
|
-
case UITouchTypePencil:
|
|
304
|
-
return "pen";
|
|
305
|
-
case UITouchTypeIndirectPointer:
|
|
306
|
-
return "mouse";
|
|
307
|
-
case UITouchTypeIndirect:
|
|
308
|
-
default:
|
|
309
|
-
return "";
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
|
|
313
|
-
static void UpdatePointerEventModifierFlags(PointerEvent &event, UIKeyModifierFlags flags)
|
|
314
|
-
{
|
|
315
|
-
if (@available(iOS 13.4, *)) {
|
|
316
|
-
event.ctrlKey = (flags & UIKeyModifierControl) != 0;
|
|
317
|
-
event.shiftKey = (flags & UIKeyModifierShift) != 0;
|
|
318
|
-
event.altKey = (flags & UIKeyModifierAlternate) != 0;
|
|
319
|
-
event.metaKey = (flags & UIKeyModifierCommand) != 0;
|
|
320
|
-
} else {
|
|
321
|
-
event.ctrlKey = false;
|
|
322
|
-
event.shiftKey = false;
|
|
323
|
-
event.altKey = false;
|
|
324
|
-
event.metaKey = false;
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
static PointerEvent CreatePointerEventFromActiveTouch(ActiveTouch activeTouch, RCTTouchEventType eventType)
|
|
329
|
-
{
|
|
330
|
-
Touch touch = activeTouch.touch;
|
|
331
|
-
|
|
332
|
-
PointerEvent event = {};
|
|
333
|
-
event.pointerId = touch.identifier;
|
|
334
|
-
event.pointerType = PointerTypeCStringFromUITouchType(activeTouch.touchType);
|
|
335
|
-
event.clientPoint = touch.pagePoint;
|
|
336
|
-
event.screenPoint = touch.screenPoint;
|
|
337
|
-
event.offsetPoint = touch.offsetPoint;
|
|
338
|
-
|
|
339
|
-
event.pressure = touch.force;
|
|
340
|
-
if (@available(iOS 13.4, *)) {
|
|
341
|
-
if (activeTouch.touchType == UITouchTypeIndirectPointer) {
|
|
342
|
-
// pointer events with a mouse button pressed should report a pressure of 0.5
|
|
343
|
-
// when the touch is down and 0.0 when it is lifted regardless of how it is reported by the OS
|
|
344
|
-
event.pressure = eventType != RCTTouchEventTypeTouchEnd ? 0.5 : 0.0;
|
|
345
|
-
}
|
|
346
|
-
}
|
|
347
|
-
|
|
348
|
-
CGFloat pointerSize = activeTouch.majorRadius * 2.0;
|
|
349
|
-
if (@available(iOS 13.4, *)) {
|
|
350
|
-
if (activeTouch.touchType == UITouchTypeIndirectPointer) {
|
|
351
|
-
// mouse type pointers should always report a size of 1
|
|
352
|
-
pointerSize = 1.0;
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
event.width = pointerSize;
|
|
356
|
-
event.height = pointerSize;
|
|
357
|
-
|
|
358
|
-
CGPoint tilt = SphericalToTilt(activeTouch.altitudeAngle, activeTouch.azimuthAngle);
|
|
359
|
-
event.tiltX = RadsToDegrees(tilt.x);
|
|
360
|
-
event.tiltY = RadsToDegrees(tilt.y);
|
|
361
|
-
|
|
362
|
-
event.detail = 0;
|
|
363
90
|
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
UpdatePointerEventModifierFlags(event, activeTouch.modifierFlags);
|
|
368
|
-
|
|
369
|
-
event.tangentialPressure = 0.0;
|
|
370
|
-
event.twist = 0;
|
|
371
|
-
event.isPrimary = activeTouch.isPrimary;
|
|
372
|
-
|
|
373
|
-
return event;
|
|
374
|
-
}
|
|
375
|
-
|
|
376
|
-
static PointerEvent CreatePointerEventFromIncompleteHoverData(
|
|
377
|
-
CGPoint clientLocation,
|
|
378
|
-
CGPoint screenLocation,
|
|
379
|
-
CGPoint offsetLocation,
|
|
380
|
-
UIKeyModifierFlags modifierFlags)
|
|
381
|
-
{
|
|
382
|
-
PointerEvent event = {};
|
|
383
|
-
// "touch" events produced from a mouse cursor on iOS always have the ID 0 so
|
|
384
|
-
// we can just assume that here since these sort of hover events only ever come
|
|
385
|
-
// from the mouse
|
|
386
|
-
event.pointerId = kMousePointerId;
|
|
387
|
-
event.pressure = 0.0;
|
|
388
|
-
event.pointerType = "mouse";
|
|
389
|
-
event.clientPoint = RCTPointFromCGPoint(clientLocation);
|
|
390
|
-
event.screenPoint = RCTPointFromCGPoint(screenLocation);
|
|
391
|
-
event.offsetPoint = RCTPointFromCGPoint(offsetLocation);
|
|
392
|
-
event.width = 1.0;
|
|
393
|
-
event.height = 1.0;
|
|
394
|
-
event.tiltX = 0;
|
|
395
|
-
event.tiltY = 0;
|
|
396
|
-
event.detail = 0;
|
|
397
|
-
event.button = -1;
|
|
398
|
-
event.buttons = 0;
|
|
399
|
-
UpdatePointerEventModifierFlags(event, modifierFlags);
|
|
400
|
-
event.tangentialPressure = 0.0;
|
|
401
|
-
event.twist = 0;
|
|
402
|
-
event.isPrimary = true;
|
|
403
|
-
|
|
404
|
-
return event;
|
|
91
|
+
UpdateActiveTouchWithUITouch(activeTouch, uiTouch, rootComponentView, rootViewOriginOffset);
|
|
92
|
+
return activeTouch;
|
|
405
93
|
}
|
|
406
94
|
|
|
407
95
|
static BOOL AllTouchesAreCancelledOrEnded(NSSet<UITouch *> *touches)
|
|
@@ -424,28 +112,6 @@ static BOOL AnyTouchesChanged(NSSet<UITouch *> *touches)
|
|
|
424
112
|
return NO;
|
|
425
113
|
}
|
|
426
114
|
|
|
427
|
-
static BOOL IsViewListeningToEvent(RCTReactTaggedView *taggedView, ViewEvents::Offset eventType)
|
|
428
|
-
{
|
|
429
|
-
UIView *view = taggedView.view;
|
|
430
|
-
if (view && [view.class conformsToProtocol:@protocol(RCTComponentViewProtocol)]) {
|
|
431
|
-
auto props = ((id<RCTComponentViewProtocol>)view).props;
|
|
432
|
-
if (SharedViewProps viewProps = std::dynamic_pointer_cast<ViewProps const>(props)) {
|
|
433
|
-
return viewProps->events[eventType];
|
|
434
|
-
}
|
|
435
|
-
}
|
|
436
|
-
return NO;
|
|
437
|
-
}
|
|
438
|
-
|
|
439
|
-
static BOOL IsAnyViewInPathListeningToEvent(NSOrderedSet<RCTReactTaggedView *> *viewPath, ViewEvents::Offset eventType)
|
|
440
|
-
{
|
|
441
|
-
for (RCTReactTaggedView *taggedView in viewPath) {
|
|
442
|
-
if (IsViewListeningToEvent(taggedView, eventType)) {
|
|
443
|
-
return YES;
|
|
444
|
-
}
|
|
445
|
-
}
|
|
446
|
-
return NO;
|
|
447
|
-
}
|
|
448
|
-
|
|
449
115
|
/**
|
|
450
116
|
* Surprisingly, `__unsafe_unretained id` pointers are not regular pointers
|
|
451
117
|
* and `std::hash<>` cannot hash them.
|
|
@@ -471,12 +137,9 @@ struct PointerHasher {
|
|
|
471
137
|
* We hold the view weakly to prevent a retain cycle.
|
|
472
138
|
*/
|
|
473
139
|
__weak UIView *_rootComponentView;
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
UIHoverGestureRecognizer *_hoverRecognizer API_AVAILABLE(ios(13.0));
|
|
477
|
-
NSMutableDictionary<NSNumber *, NSOrderedSet<RCTReactTaggedView *> *> *_currentlyHoveredViewsPerPointer;
|
|
140
|
+
RCTIdentifierPool<11> _identifierPool;
|
|
478
141
|
|
|
479
|
-
|
|
142
|
+
RCTSurfacePointerHandler *_pointerHandler;
|
|
480
143
|
}
|
|
481
144
|
|
|
482
145
|
- (instancetype)init
|
|
@@ -492,9 +155,9 @@ struct PointerHasher {
|
|
|
492
155
|
|
|
493
156
|
self.delegate = self;
|
|
494
157
|
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
158
|
+
if (RCTGetDispatchW3CPointerEvents()) {
|
|
159
|
+
_pointerHandler = [[RCTSurfacePointerHandler alloc] init];
|
|
160
|
+
}
|
|
498
161
|
}
|
|
499
162
|
|
|
500
163
|
return self;
|
|
@@ -509,11 +172,8 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
509
172
|
[view addGestureRecognizer:self];
|
|
510
173
|
_rootComponentView = view;
|
|
511
174
|
|
|
512
|
-
if (
|
|
513
|
-
|
|
514
|
-
_hoverRecognizer = [[UIHoverGestureRecognizer alloc] initWithTarget:self action:@selector(hovering:)];
|
|
515
|
-
[view addGestureRecognizer:_hoverRecognizer];
|
|
516
|
-
}
|
|
175
|
+
if (_pointerHandler != nil) {
|
|
176
|
+
[_pointerHandler attachToView:view];
|
|
517
177
|
}
|
|
518
178
|
}
|
|
519
179
|
|
|
@@ -525,66 +185,30 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
525
185
|
[view removeGestureRecognizer:self];
|
|
526
186
|
_rootComponentView = nil;
|
|
527
187
|
|
|
528
|
-
if (
|
|
529
|
-
[
|
|
530
|
-
_hoverRecognizer = nil;
|
|
188
|
+
if (_pointerHandler != nil) {
|
|
189
|
+
[_pointerHandler detachFromView:view];
|
|
531
190
|
}
|
|
532
191
|
}
|
|
533
192
|
|
|
534
|
-
- (void)_registerTouches:(NSSet<UITouch *> *)touches
|
|
193
|
+
- (void)_registerTouches:(NSSet<UITouch *> *)touches
|
|
535
194
|
{
|
|
536
195
|
for (UITouch *touch in touches) {
|
|
537
|
-
auto activeTouch = CreateTouchWithUITouch(touch,
|
|
538
|
-
|
|
539
|
-
if (@available(iOS 13.4, *)) {
|
|
540
|
-
switch (touch.type) {
|
|
541
|
-
case UITouchTypeIndirectPointer:
|
|
542
|
-
activeTouch.touch.identifier = kMousePointerId;
|
|
543
|
-
activeTouch.isPrimary = true;
|
|
544
|
-
break;
|
|
545
|
-
case UITouchTypePencil:
|
|
546
|
-
activeTouch.touch.identifier = kPencilPointerId;
|
|
547
|
-
activeTouch.isPrimary = true;
|
|
548
|
-
break;
|
|
549
|
-
default:
|
|
550
|
-
// use the identifier pool offset to ensure no conflicts between the reserved IDs and the
|
|
551
|
-
// touch IDs
|
|
552
|
-
activeTouch.touch.identifier = _identifierPool.dequeue() + kTouchIdentifierPoolOffset;
|
|
553
|
-
if (_primaryTouchPointerId == -1) {
|
|
554
|
-
_primaryTouchPointerId = activeTouch.touch.identifier;
|
|
555
|
-
activeTouch.isPrimary = true;
|
|
556
|
-
}
|
|
557
|
-
break;
|
|
558
|
-
}
|
|
559
|
-
} else {
|
|
560
|
-
activeTouch.touch.identifier = _identifierPool.dequeue();
|
|
561
|
-
if (_primaryTouchPointerId == -1) {
|
|
562
|
-
_primaryTouchPointerId = activeTouch.touch.identifier;
|
|
563
|
-
activeTouch.isPrimary = true;
|
|
564
|
-
}
|
|
565
|
-
}
|
|
566
|
-
|
|
567
|
-
// If the pointer has not been marked as hovering over views before the touch started, we register
|
|
568
|
-
// that the activeTouch should not maintain its hovered state once the pointer has been lifted.
|
|
569
|
-
auto currentlyHoveredViews = [_currentlyHoveredViewsPerPointer objectForKey:@(activeTouch.touch.identifier)];
|
|
570
|
-
if (currentlyHoveredViews == nil || [currentlyHoveredViews count] == 0) {
|
|
571
|
-
activeTouch.shouldLeaveWhenReleased = YES;
|
|
572
|
-
}
|
|
573
|
-
|
|
196
|
+
auto activeTouch = CreateTouchWithUITouch(touch, _rootComponentView, _viewOriginOffset);
|
|
197
|
+
activeTouch.touch.identifier = _identifierPool.dequeue();
|
|
574
198
|
_activeTouches.emplace(touch, activeTouch);
|
|
575
199
|
}
|
|
576
200
|
}
|
|
577
201
|
|
|
578
|
-
- (void)_updateTouches:(NSSet<UITouch *> *)touches
|
|
202
|
+
- (void)_updateTouches:(NSSet<UITouch *> *)touches
|
|
579
203
|
{
|
|
580
204
|
for (UITouch *touch in touches) {
|
|
581
205
|
auto iterator = _activeTouches.find(touch);
|
|
582
|
-
|
|
206
|
+
RCTAssert(iterator != _activeTouches.end(), @"Inconsistency between local and UIKit touch registries");
|
|
583
207
|
if (iterator == _activeTouches.end()) {
|
|
584
208
|
continue;
|
|
585
209
|
}
|
|
586
210
|
|
|
587
|
-
UpdateActiveTouchWithUITouch(iterator->second, touch,
|
|
211
|
+
UpdateActiveTouchWithUITouch(iterator->second, touch, _rootComponentView, _viewOriginOffset);
|
|
588
212
|
}
|
|
589
213
|
}
|
|
590
214
|
|
|
@@ -592,30 +216,12 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
592
216
|
{
|
|
593
217
|
for (UITouch *touch in touches) {
|
|
594
218
|
auto iterator = _activeTouches.find(touch);
|
|
595
|
-
|
|
219
|
+
RCTAssert(iterator != _activeTouches.end(), @"Inconsistency between local and UIKit touch registries");
|
|
596
220
|
if (iterator == _activeTouches.end()) {
|
|
597
221
|
continue;
|
|
598
222
|
}
|
|
599
223
|
auto &activeTouch = iterator->second;
|
|
600
|
-
|
|
601
|
-
if (activeTouch.touch.identifier == _primaryTouchPointerId) {
|
|
602
|
-
_primaryTouchPointerId = -1;
|
|
603
|
-
}
|
|
604
|
-
|
|
605
|
-
if (@available(iOS 13.4, *)) {
|
|
606
|
-
// only need to enqueue if the touch type isn't one with a reserved identifier
|
|
607
|
-
switch (touch.type) {
|
|
608
|
-
case UITouchTypeIndirectPointer:
|
|
609
|
-
case UITouchTypePencil:
|
|
610
|
-
break;
|
|
611
|
-
default:
|
|
612
|
-
// since the touch's identifier has been offset we need to re-normalize it to 0-based
|
|
613
|
-
// which is what the identifier pool expects
|
|
614
|
-
_identifierPool.enqueue(activeTouch.touch.identifier - kTouchIdentifierPoolOffset);
|
|
615
|
-
}
|
|
616
|
-
} else {
|
|
617
|
-
_identifierPool.enqueue(activeTouch.touch.identifier);
|
|
618
|
-
}
|
|
224
|
+
_identifierPool.enqueue(activeTouch.touch.identifier);
|
|
619
225
|
_activeTouches.erase(touch);
|
|
620
226
|
}
|
|
621
227
|
}
|
|
@@ -627,7 +233,7 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
627
233
|
|
|
628
234
|
for (UITouch *touch in touches) {
|
|
629
235
|
auto iterator = _activeTouches.find(touch);
|
|
630
|
-
|
|
236
|
+
RCTAssert(iterator != _activeTouches.end(), @"Inconsistency between local and UIKit touch registries");
|
|
631
237
|
if (iterator == _activeTouches.end()) {
|
|
632
238
|
continue;
|
|
633
239
|
}
|
|
@@ -652,44 +258,6 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
652
258
|
changedActiveTouches.insert(activeTouch);
|
|
653
259
|
event.changedTouches.insert(activeTouch.touch);
|
|
654
260
|
uniqueEventEmitters.insert(activeTouch.eventEmitter);
|
|
655
|
-
|
|
656
|
-
// emit w3c pointer events
|
|
657
|
-
if (RCTGetDispatchW3CPointerEvents()) {
|
|
658
|
-
PointerEvent pointerEvent = CreatePointerEventFromActiveTouch(activeTouch, eventType);
|
|
659
|
-
|
|
660
|
-
if ((eventType == RCTTouchEventTypeTouchEnd && activeTouch.shouldLeaveWhenReleased)) {
|
|
661
|
-
activeTouch.eventEmitter->onPointerUp(pointerEvent);
|
|
662
|
-
[self handleIncomingPointerEvent:pointerEvent onView:nil];
|
|
663
|
-
} else {
|
|
664
|
-
CGPoint clientLocation = CGPointMake(pointerEvent.clientPoint.x, pointerEvent.clientPoint.y);
|
|
665
|
-
UIView *targetView = FindClosestFabricManagedTouchableView([_rootComponentView hitTest:clientLocation
|
|
666
|
-
withEvent:nil]);
|
|
667
|
-
|
|
668
|
-
NSOrderedSet<RCTReactTaggedView *> *eventPathViews = [self handleIncomingPointerEvent:pointerEvent
|
|
669
|
-
onView:targetView];
|
|
670
|
-
|
|
671
|
-
switch (eventType) {
|
|
672
|
-
case RCTTouchEventTypeTouchStart:
|
|
673
|
-
activeTouch.eventEmitter->onPointerDown(pointerEvent);
|
|
674
|
-
break;
|
|
675
|
-
case RCTTouchEventTypeTouchMove: {
|
|
676
|
-
bool hasMoveEventListeners =
|
|
677
|
-
IsAnyViewInPathListeningToEvent(eventPathViews, ViewEvents::Offset::PointerMove) ||
|
|
678
|
-
IsAnyViewInPathListeningToEvent(eventPathViews, ViewEvents::Offset::PointerMoveCapture);
|
|
679
|
-
if (hasMoveEventListeners) {
|
|
680
|
-
activeTouch.eventEmitter->onPointerMove(pointerEvent);
|
|
681
|
-
}
|
|
682
|
-
break;
|
|
683
|
-
}
|
|
684
|
-
case RCTTouchEventTypeTouchEnd:
|
|
685
|
-
activeTouch.eventEmitter->onPointerUp(pointerEvent);
|
|
686
|
-
break;
|
|
687
|
-
case RCTTouchEventTypeTouchCancel:
|
|
688
|
-
activeTouch.eventEmitter->onPointerCancel(pointerEvent);
|
|
689
|
-
break;
|
|
690
|
-
}
|
|
691
|
-
}
|
|
692
|
-
}
|
|
693
261
|
}
|
|
694
262
|
|
|
695
263
|
for (const auto &pair : _activeTouches) {
|
|
@@ -736,7 +304,7 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
736
304
|
{
|
|
737
305
|
[super touchesBegan:touches withEvent:event];
|
|
738
306
|
|
|
739
|
-
[self _registerTouches:touches
|
|
307
|
+
[self _registerTouches:touches];
|
|
740
308
|
[self _dispatchActiveTouches:[self _activeTouchesFromTouches:touches] eventType:RCTTouchEventTypeTouchStart];
|
|
741
309
|
|
|
742
310
|
if (self.state == UIGestureRecognizerStatePossible) {
|
|
@@ -750,7 +318,7 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
750
318
|
{
|
|
751
319
|
[super touchesMoved:touches withEvent:event];
|
|
752
320
|
|
|
753
|
-
[self _updateTouches:touches
|
|
321
|
+
[self _updateTouches:touches];
|
|
754
322
|
[self _dispatchActiveTouches:[self _activeTouchesFromTouches:touches] eventType:RCTTouchEventTypeTouchMove];
|
|
755
323
|
|
|
756
324
|
self.state = UIGestureRecognizerStateChanged;
|
|
@@ -760,7 +328,7 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
760
328
|
{
|
|
761
329
|
[super touchesEnded:touches withEvent:event];
|
|
762
330
|
|
|
763
|
-
[self _updateTouches:touches
|
|
331
|
+
[self _updateTouches:touches];
|
|
764
332
|
[self _dispatchActiveTouches:[self _activeTouchesFromTouches:touches] eventType:RCTTouchEventTypeTouchEnd];
|
|
765
333
|
[self _unregisterTouches:touches];
|
|
766
334
|
|
|
@@ -775,7 +343,7 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
775
343
|
{
|
|
776
344
|
[super touchesCancelled:touches withEvent:event];
|
|
777
345
|
|
|
778
|
-
[self _updateTouches:touches
|
|
346
|
+
[self _updateTouches:touches];
|
|
779
347
|
[self _dispatchActiveTouches:[self _activeTouchesFromTouches:touches] eventType:RCTTouchEventTypeTouchCancel];
|
|
780
348
|
[self _unregisterTouches:touches];
|
|
781
349
|
|
|
@@ -845,145 +413,4 @@ RCT_NOT_IMPLEMENTED(-(instancetype)initWithTarget : (id)target action : (SEL)act
|
|
|
845
413
|
[self setEnabled:YES];
|
|
846
414
|
}
|
|
847
415
|
|
|
848
|
-
- (void)hovering:(UIHoverGestureRecognizer *)recognizer API_AVAILABLE(ios(13.0))
|
|
849
|
-
{
|
|
850
|
-
UIView *listenerView = recognizer.view;
|
|
851
|
-
CGPoint clientLocation = [recognizer locationInView:listenerView];
|
|
852
|
-
CGPoint screenLocation = [listenerView convertPoint:clientLocation
|
|
853
|
-
toCoordinateSpace:listenerView.window.screen.coordinateSpace];
|
|
854
|
-
|
|
855
|
-
UIView *targetView = [listenerView hitTest:clientLocation withEvent:nil];
|
|
856
|
-
targetView = FindClosestFabricManagedTouchableView(targetView);
|
|
857
|
-
|
|
858
|
-
CGPoint offsetLocation = [recognizer locationInView:targetView];
|
|
859
|
-
|
|
860
|
-
UIKeyModifierFlags modifierFlags;
|
|
861
|
-
if (@available(iOS 13.4, *)) {
|
|
862
|
-
modifierFlags = recognizer.modifierFlags;
|
|
863
|
-
} else {
|
|
864
|
-
modifierFlags = 0;
|
|
865
|
-
}
|
|
866
|
-
|
|
867
|
-
PointerEvent event =
|
|
868
|
-
CreatePointerEventFromIncompleteHoverData(clientLocation, screenLocation, offsetLocation, modifierFlags);
|
|
869
|
-
|
|
870
|
-
NSOrderedSet<RCTReactTaggedView *> *eventPathViews = [self handleIncomingPointerEvent:event onView:targetView];
|
|
871
|
-
SharedTouchEventEmitter eventEmitter = GetTouchEmitterFromView(targetView, offsetLocation);
|
|
872
|
-
bool hasMoveEventListeners = IsAnyViewInPathListeningToEvent(eventPathViews, ViewEvents::Offset::PointerMove) ||
|
|
873
|
-
IsAnyViewInPathListeningToEvent(eventPathViews, ViewEvents::Offset::PointerMoveCapture);
|
|
874
|
-
if (eventEmitter != nil && hasMoveEventListeners) {
|
|
875
|
-
eventEmitter->onPointerMove(event);
|
|
876
|
-
}
|
|
877
|
-
}
|
|
878
|
-
|
|
879
|
-
/**
|
|
880
|
-
* Private method which is used for tracking the location of pointer events to manage the entering/leaving events.
|
|
881
|
-
* The primary idea is that a pointer's presence & movement is dicated by a variety of underlying events such as down,
|
|
882
|
-
* move, and up — and they should all be treated the same when it comes to tracking the entering & leaving of pointers
|
|
883
|
-
* to views. This method accomplishes that by recieving the pointer event, the target view (can be null in cases when
|
|
884
|
-
* the event indicates that the pointer has left the screen entirely), and a block/callback where the underlying event
|
|
885
|
-
* should be fired.
|
|
886
|
-
*/
|
|
887
|
-
- (NSOrderedSet<RCTReactTaggedView *> *)handleIncomingPointerEvent:(PointerEvent)event
|
|
888
|
-
onView:(nullable UIView *)targetView
|
|
889
|
-
{
|
|
890
|
-
int pointerId = event.pointerId;
|
|
891
|
-
CGPoint clientLocation = CGPointMake(event.clientPoint.x, event.clientPoint.y);
|
|
892
|
-
|
|
893
|
-
NSOrderedSet<RCTReactTaggedView *> *currentlyHoveredViews =
|
|
894
|
-
[_currentlyHoveredViewsPerPointer objectForKey:@(pointerId)];
|
|
895
|
-
if (currentlyHoveredViews == nil) {
|
|
896
|
-
currentlyHoveredViews = [NSOrderedSet orderedSet];
|
|
897
|
-
}
|
|
898
|
-
|
|
899
|
-
RCTReactTaggedView *targetTaggedView = [RCTReactTaggedView wrap:targetView];
|
|
900
|
-
RCTReactTaggedView *prevTargetTaggedView = [currentlyHoveredViews firstObject];
|
|
901
|
-
UIView *prevTargetView = prevTargetTaggedView.view;
|
|
902
|
-
|
|
903
|
-
NSOrderedSet<RCTReactTaggedView *> *eventPathViews = GetTouchableViewsInPathToRoot(targetView);
|
|
904
|
-
|
|
905
|
-
// Out
|
|
906
|
-
if (prevTargetView != nil && prevTargetTaggedView.tag != targetTaggedView.tag) {
|
|
907
|
-
BOOL shouldEmitOutEvent = IsAnyViewInPathListeningToEvent(currentlyHoveredViews, ViewEvents::Offset::PointerOut);
|
|
908
|
-
SharedTouchEventEmitter eventEmitter =
|
|
909
|
-
GetTouchEmitterFromView(prevTargetView, [_rootComponentView convertPoint:clientLocation toView:prevTargetView]);
|
|
910
|
-
if (shouldEmitOutEvent && eventEmitter != nil) {
|
|
911
|
-
eventEmitter->onPointerOut(event);
|
|
912
|
-
}
|
|
913
|
-
}
|
|
914
|
-
|
|
915
|
-
// Leaving
|
|
916
|
-
|
|
917
|
-
// pointerleave events need to be emited from the deepest target to the root but
|
|
918
|
-
// we also need to efficiently keep track of if a view has a parent which is listening to the leave events,
|
|
919
|
-
// so we first iterate from the root to the target, collecting the views which need events fired for, of which
|
|
920
|
-
// we reverse iterate (now from target to root), actually emitting the events.
|
|
921
|
-
NSMutableOrderedSet<UIView *> *viewsToEmitLeaveEventsTo = [NSMutableOrderedSet orderedSet];
|
|
922
|
-
|
|
923
|
-
BOOL hasParentLeaveListener = NO;
|
|
924
|
-
for (RCTReactTaggedView *taggedView in [currentlyHoveredViews reverseObjectEnumerator]) {
|
|
925
|
-
UIView *componentView = taggedView.view;
|
|
926
|
-
|
|
927
|
-
BOOL shouldEmitEvent = componentView != nil &&
|
|
928
|
-
(hasParentLeaveListener || IsViewListeningToEvent(taggedView, ViewEvents::Offset::PointerLeave));
|
|
929
|
-
|
|
930
|
-
if (shouldEmitEvent && ![eventPathViews containsObject:taggedView]) {
|
|
931
|
-
[viewsToEmitLeaveEventsTo addObject:componentView];
|
|
932
|
-
}
|
|
933
|
-
|
|
934
|
-
if (shouldEmitEvent && !hasParentLeaveListener) {
|
|
935
|
-
hasParentLeaveListener = YES;
|
|
936
|
-
}
|
|
937
|
-
}
|
|
938
|
-
|
|
939
|
-
for (UIView *componentView in [viewsToEmitLeaveEventsTo reverseObjectEnumerator]) {
|
|
940
|
-
SharedTouchEventEmitter eventEmitter =
|
|
941
|
-
GetTouchEmitterFromView(componentView, [_rootComponentView convertPoint:clientLocation toView:componentView]);
|
|
942
|
-
if (eventEmitter != nil) {
|
|
943
|
-
eventEmitter->onPointerLeave(event);
|
|
944
|
-
}
|
|
945
|
-
}
|
|
946
|
-
|
|
947
|
-
// Over
|
|
948
|
-
if (targetView != nil && prevTargetTaggedView.tag != targetTaggedView.tag) {
|
|
949
|
-
BOOL shouldEmitOverEvent = IsAnyViewInPathListeningToEvent(eventPathViews, ViewEvents::Offset::PointerOver);
|
|
950
|
-
SharedTouchEventEmitter eventEmitter =
|
|
951
|
-
GetTouchEmitterFromView(targetView, [_rootComponentView convertPoint:clientLocation toView:targetView]);
|
|
952
|
-
if (shouldEmitOverEvent && eventEmitter != nil) {
|
|
953
|
-
eventEmitter->onPointerOver(event);
|
|
954
|
-
}
|
|
955
|
-
}
|
|
956
|
-
|
|
957
|
-
// Entering
|
|
958
|
-
|
|
959
|
-
// We only want to emit events to JS if there is a view that is currently listening to said event
|
|
960
|
-
// so we only send those event to the JS side if the element which has been entered is itself listening,
|
|
961
|
-
// or if one of its parents is listening in case those listeners care about the capturing phase. Adding the ability
|
|
962
|
-
// for native to distingusih between capturing listeners and not could be an optimization to futher reduce the number
|
|
963
|
-
// of events we send to JS
|
|
964
|
-
BOOL hasParentEnterListener = NO;
|
|
965
|
-
for (RCTReactTaggedView *taggedView in [eventPathViews reverseObjectEnumerator]) {
|
|
966
|
-
UIView *componentView = taggedView.view;
|
|
967
|
-
|
|
968
|
-
BOOL shouldEmitEvent = componentView != nil &&
|
|
969
|
-
(hasParentEnterListener || IsViewListeningToEvent(taggedView, ViewEvents::Offset::PointerEnter));
|
|
970
|
-
|
|
971
|
-
if (shouldEmitEvent && ![currentlyHoveredViews containsObject:taggedView]) {
|
|
972
|
-
SharedTouchEventEmitter eventEmitter =
|
|
973
|
-
GetTouchEmitterFromView(componentView, [_rootComponentView convertPoint:clientLocation toView:componentView]);
|
|
974
|
-
if (eventEmitter != nil) {
|
|
975
|
-
eventEmitter->onPointerEnter(event);
|
|
976
|
-
}
|
|
977
|
-
}
|
|
978
|
-
|
|
979
|
-
if (shouldEmitEvent && !hasParentEnterListener) {
|
|
980
|
-
hasParentEnterListener = YES;
|
|
981
|
-
}
|
|
982
|
-
}
|
|
983
|
-
|
|
984
|
-
[_currentlyHoveredViewsPerPointer setObject:eventPathViews forKey:@(pointerId)];
|
|
985
|
-
|
|
986
|
-
return eventPathViews;
|
|
987
|
-
}
|
|
988
|
-
|
|
989
416
|
@end
|