react-native-windows 0.76.3 → 0.77.0-preview.1

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.
Files changed (369) hide show
  1. package/.flowconfig +5 -1
  2. package/Libraries/ActionSheetIOS/ActionSheetIOS.d.ts +1 -0
  3. package/Libraries/ActionSheetIOS/ActionSheetIOS.js +13 -0
  4. package/Libraries/Animated/AnimatedEvent.js +1 -1
  5. package/Libraries/Animated/AnimatedImplementation.js +2 -2
  6. package/Libraries/Animated/NativeAnimatedAllowlist.js +20 -9
  7. package/Libraries/Animated/NativeAnimatedAllowlist.windows.js +122 -0
  8. package/Libraries/Animated/animations/Animation.js +60 -25
  9. package/Libraries/Animated/animations/DecayAnimation.js +26 -38
  10. package/Libraries/Animated/animations/SpringAnimation.js +33 -39
  11. package/Libraries/Animated/animations/TimingAnimation.js +34 -42
  12. package/Libraries/Animated/components/AnimatedFlatList.js +1 -1
  13. package/Libraries/Animated/components/AnimatedSectionList.js +3 -1
  14. package/Libraries/Animated/createAnimatedComponent.js +60 -33
  15. package/Libraries/Animated/nodes/AnimatedColor.js +1 -1
  16. package/Libraries/Animated/nodes/AnimatedInterpolation.js +1 -1
  17. package/Libraries/Animated/nodes/AnimatedNode.js +39 -45
  18. package/Libraries/Animated/nodes/AnimatedObject.js +13 -3
  19. package/Libraries/Animated/nodes/AnimatedProps.js +96 -46
  20. package/Libraries/Animated/nodes/AnimatedProps.windows.js +281 -0
  21. package/Libraries/Animated/nodes/AnimatedStyle.js +108 -39
  22. package/Libraries/Animated/nodes/AnimatedStyle.windows.js +251 -0
  23. package/Libraries/Animated/nodes/AnimatedTransform.js +56 -23
  24. package/Libraries/Animated/nodes/AnimatedValue.js +1 -1
  25. package/Libraries/Animated/nodes/AnimatedWithChildren.js +1 -3
  26. package/Libraries/Animated/useAnimatedProps.js +41 -35
  27. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +19 -3
  28. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +77 -5
  29. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.windows.js +82 -5
  30. package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +4 -4
  31. package/Libraries/Components/Button.js +9 -4
  32. package/Libraries/Components/Button.windows.js +19 -5
  33. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.js +3 -1
  34. package/Libraries/Components/Glyph/Glyph.js +2 -1
  35. package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +7 -0
  36. package/Libraries/Components/Popup/PopupNativeComponent.js +0 -1
  37. package/Libraries/Components/Pressable/Pressable.js +4 -4
  38. package/Libraries/Components/Pressable/Pressable.windows.js +10 -4
  39. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.android.js +13 -7
  40. package/Libraries/Components/RefreshControl/__mocks__/RefreshControlMock.js +3 -2
  41. package/Libraries/Components/SafeAreaView/SafeAreaView.js +4 -4
  42. package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +0 -1
  43. package/Libraries/Components/ScrollView/ScrollView.js +49 -88
  44. package/Libraries/Components/ScrollView/ScrollViewCommands.js +1 -1
  45. package/Libraries/Components/ScrollView/ScrollViewContext.js +2 -0
  46. package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +0 -2
  47. package/Libraries/Components/ScrollView/ScrollViewNativeComponent.windows.js +0 -5
  48. package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +8 -9
  49. package/Libraries/Components/Switch/Switch.js +8 -6
  50. package/Libraries/Components/Switch/Switch.windows.js +8 -6
  51. package/Libraries/Components/TextInput/InputAccessoryView.js +1 -1
  52. package/Libraries/Components/TextInput/RCTMultilineTextInputNativeComponent.js +4 -4
  53. package/Libraries/Components/TextInput/RCTSingelineTextInputNativeComponent.js +6 -4
  54. package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +2 -1
  55. package/Libraries/Components/TextInput/TextInput.d.ts +27 -4
  56. package/Libraries/Components/TextInput/TextInput.flow.js +36 -19
  57. package/Libraries/Components/TextInput/TextInput.js +37 -13
  58. package/Libraries/Components/TextInput/TextInput.windows.js +47 -16
  59. package/Libraries/Components/TextInput/TextInputState.js +11 -13
  60. package/Libraries/Components/TextInput/TextInputState.windows.js +11 -13
  61. package/Libraries/Components/Touchable/BoundingDimensions.js +11 -3
  62. package/Libraries/Components/Touchable/Position.js +7 -2
  63. package/Libraries/Components/Touchable/Touchable.js +4 -0
  64. package/Libraries/Components/Touchable/Touchable.windows.js +4 -0
  65. package/Libraries/Components/Touchable/TouchableBounce.js +6 -2
  66. package/Libraries/Components/Touchable/TouchableBounce.windows.js +227 -0
  67. package/Libraries/Components/Touchable/TouchableHighlight.js +5 -5
  68. package/Libraries/Components/Touchable/TouchableHighlight.windows.js +5 -5
  69. package/Libraries/Components/Touchable/TouchableNativeFeedback.windows.js +371 -0
  70. package/Libraries/Components/Touchable/TouchableOpacity.js +6 -5
  71. package/Libraries/Components/Touchable/TouchableOpacity.windows.js +11 -5
  72. package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +1 -2
  73. package/Libraries/Components/Touchable/TouchableWithoutFeedback.windows.js +9 -3
  74. package/Libraries/Components/View/ReactNativeStyleAttributes.js +6 -1
  75. package/Libraries/Components/View/View.js +4 -4
  76. package/Libraries/Components/View/View.windows.js +12 -5
  77. package/Libraries/Components/View/ViewAccessibility.d.ts +10 -0
  78. package/Libraries/Components/View/ViewAccessibility.windows.js +2 -0
  79. package/Libraries/Components/View/ViewNativeComponent.js +6 -98
  80. package/Libraries/Components/View/ViewPropTypes.d.ts +7 -0
  81. package/Libraries/Components/View/ViewPropTypes.js +0 -3
  82. package/Libraries/Components/View/ViewPropTypes.windows.js +2 -3
  83. package/Libraries/Core/ExceptionsManager.js +50 -29
  84. package/Libraries/Core/ReactNativeVersion.js +3 -3
  85. package/Libraries/Core/__mocks__/NativeExceptionsManager.js +0 -1
  86. package/Libraries/Core/setUpBatchedBridge.js +1 -10
  87. package/Libraries/Core/setUpDeveloperTools.js +1 -5
  88. package/Libraries/Core/setUpErrorHandling.js +20 -18
  89. package/Libraries/Core/setUpReactDevTools.js +107 -8
  90. package/Libraries/Core/setUpSegmentFetcher.js +1 -0
  91. package/Libraries/Core/setUpTimers.js +21 -18
  92. package/Libraries/Debugging/DebuggingOverlay.js +4 -5
  93. package/Libraries/Image/AssetSourceResolver.js +12 -1
  94. package/Libraries/Image/AssetSourceResolver.windows.js +12 -1
  95. package/Libraries/Image/Image.android.js +1 -5
  96. package/Libraries/Image/Image.d.ts +20 -29
  97. package/Libraries/Image/Image.ios.js +0 -2
  98. package/Libraries/Image/Image.windows.js +5 -1
  99. package/Libraries/Image/ImageBackground.js +2 -5
  100. package/Libraries/Image/ImageProps.js +7 -6
  101. package/Libraries/Image/ImageResizeMode.d.ts +8 -1
  102. package/Libraries/Image/ImageResizeMode.js +4 -1
  103. package/Libraries/Image/ImageSource.d.ts +0 -2
  104. package/Libraries/Image/ImageSource.js +0 -2
  105. package/Libraries/Image/ImageTypes.flow.js +11 -9
  106. package/Libraries/Image/ImageUtils.js +6 -3
  107. package/Libraries/Image/ImageViewNativeComponent.js +5 -3
  108. package/Libraries/Inspector/Inspector.js +1 -0
  109. package/Libraries/Inspector/NetworkOverlay.js +4 -0
  110. package/Libraries/Inspector/ReactDevToolsOverlay.js +8 -14
  111. package/Libraries/Inspector/getInspectorDataForViewAtPoint.js +3 -5
  112. package/Libraries/Interaction/InteractionManager.js +6 -1
  113. package/Libraries/Interaction/InteractionManagerStub.js +176 -0
  114. package/Libraries/Interaction/TouchHistoryMath.js +22 -19
  115. package/Libraries/JSInspector/NetworkAgent.js +1 -1
  116. package/Libraries/Lists/FlatList.d.ts +1 -2
  117. package/Libraries/Lists/FlatList.js +2 -2
  118. package/Libraries/Lists/SectionListModern.js +7 -7
  119. package/Libraries/Lists/__flowtests__/FlatList-flowtest.js +2 -2
  120. package/Libraries/Lists/__flowtests__/SectionList-flowtest.js +1 -1
  121. package/Libraries/LogBox/Data/LogBoxData.js +3 -3
  122. package/Libraries/LogBox/LogBox.js +18 -5
  123. package/Libraries/LogBox/LogBoxInspectorContainer.js +1 -1
  124. package/Libraries/LogBox/LogBoxNotificationContainer.js +2 -2
  125. package/Libraries/LogBox/UI/AnsiHighlight.js +26 -17
  126. package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.js +6 -1
  127. package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.windows.js +6 -1
  128. package/Libraries/LogBox/UI/LogBoxInspectorHeader.js +1 -1
  129. package/Libraries/LogBox/UI/LogBoxInspectorHeader.windows.js +1 -1
  130. package/Libraries/LogBox/UI/LogBoxInspectorStackFrames.js +1 -1
  131. package/Libraries/LogBox/UI/LogBoxMessage.js +2 -2
  132. package/Libraries/Modal/Modal.d.ts +12 -0
  133. package/Libraries/Modal/Modal.js +31 -4
  134. package/Libraries/Modal/Modal.windows.js +18 -0
  135. package/Libraries/NativeComponent/BaseViewConfig.android.js +72 -1
  136. package/Libraries/NativeComponent/BaseViewConfig.ios.js +2 -1
  137. package/Libraries/NativeComponent/BaseViewConfig.windows.js +3 -11
  138. package/Libraries/NativeComponent/NativeComponentRegistry.js +3 -3
  139. package/Libraries/NativeComponent/StaticViewConfigValidator.js +0 -1
  140. package/Libraries/Network/XHRInterceptor.js +63 -14
  141. package/Libraries/Network/XMLHttpRequest.js +26 -1
  142. package/Libraries/NewAppScreen/components/HermesBadge.js +1 -1
  143. package/Libraries/PermissionsAndroid/PermissionsAndroid.d.ts +49 -2
  144. package/Libraries/PermissionsAndroid/PermissionsAndroid.js +4 -4
  145. package/Libraries/Pressability/HoverState.js +2 -0
  146. package/Libraries/Pressability/Pressability.js +2 -3
  147. package/Libraries/Pressability/Pressability.windows.js +2 -3
  148. package/Libraries/Pressability/usePressability.js +4 -1
  149. package/Libraries/ReactNative/AppContainer.js +1 -1
  150. package/Libraries/ReactNative/AppRegistry.js +1 -11
  151. package/Libraries/ReactNative/DisplayMode.js +1 -1
  152. package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricHostComponent.js +2 -3
  153. package/Libraries/ReactNative/RendererImplementation.js +18 -17
  154. package/Libraries/ReactNative/getCachedComponentWithDebugName.js +1 -3
  155. package/Libraries/ReactNative/renderApplication.js +9 -8
  156. package/Libraries/ReactNative/requireNativeComponent.js +5 -2
  157. package/Libraries/Renderer/shims/ReactFabric.js +3 -3
  158. package/Libraries/Renderer/shims/ReactFeatureFlags.js +2 -2
  159. package/Libraries/Renderer/shims/ReactNative.js +3 -3
  160. package/Libraries/Renderer/shims/ReactNativeTypes.js +22 -35
  161. package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +5 -6
  162. package/Libraries/Renderer/shims/createReactNativeComponentClass.js +2 -2
  163. package/Libraries/StyleSheet/StyleSheet.js +7 -1
  164. package/Libraries/StyleSheet/StyleSheetTypes.d.ts +13 -2
  165. package/Libraries/StyleSheet/StyleSheetTypes.js +24 -6
  166. package/Libraries/StyleSheet/processBackgroundImage.js +87 -110
  167. package/Libraries/StyleSheet/processTransform.js +3 -34
  168. package/Libraries/Text/Text.js +248 -249
  169. package/Libraries/Text/Text.windows.js +298 -292
  170. package/Libraries/Text/TextNativeComponent.js +0 -1
  171. package/Libraries/Text/TextProps.windows.js +2 -0
  172. package/Libraries/TurboModule/TurboModuleRegistry.js +5 -5
  173. package/Libraries/Types/CoreEventTypes.d.ts +3 -10
  174. package/Libraries/Types/CoreEventTypes.js +4 -6
  175. package/Libraries/Types/CoreEventTypes.windows.js +4 -6
  176. package/Libraries/Utilities/Appearance.js +3 -1
  177. package/Libraries/Utilities/BackHandler.android.js +6 -18
  178. package/Libraries/Utilities/BackHandler.d.ts +0 -4
  179. package/Libraries/Utilities/BackHandler.ios.js +0 -7
  180. package/Libraries/Utilities/BackHandler.windows.js +6 -18
  181. package/Libraries/Utilities/HMRClient.js +3 -4
  182. package/Libraries/Utilities/Platform.flow.js +2 -2
  183. package/Libraries/Utilities/Platform.flow.windows.js +3 -2
  184. package/Libraries/Utilities/__mocks__/BackHandler.js +3 -8
  185. package/Libraries/Utilities/codegenNativeComponent.js +1 -1
  186. package/Libraries/Utilities/useMergeRefs.js +26 -7
  187. package/Libraries/WebSocket/WebSocketEvent.js +4 -1
  188. package/Libraries/WebSocket/WebSocketInterceptor.js +31 -13
  189. package/Libraries/__flowtests__/ReactNativeTypes-flowtest.js +6 -5
  190. package/Libraries/promiseRejectionTrackingOptions.js +1 -1
  191. package/Microsoft.ReactNative/AsynchronousEventBeat.cpp +9 -8
  192. package/Microsoft.ReactNative/AsynchronousEventBeat.h +5 -5
  193. package/Microsoft.ReactNative/FBReactNativeSpec/FBReactNativeSpecJSI.h +5 -0
  194. package/Microsoft.ReactNative/Fabric/AbiComponentDescriptor.cpp +2 -2
  195. package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.cpp +197 -18
  196. package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.h +19 -1
  197. package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.cpp +13 -0
  198. package/Microsoft.ReactNative/Fabric/Composition/ReactNativeIsland.cpp +1 -1
  199. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentDescriptor.h +6 -8
  200. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.cpp +2 -2
  201. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputShadowNode.cpp +3 -2
  202. package/Microsoft.ReactNative/Fabric/Composition/TooltipService.cpp +1 -1
  203. package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.cpp +24 -0
  204. package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.h +5 -0
  205. package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.cpp +12 -12
  206. package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.h +4 -4
  207. package/Microsoft.ReactNative/Fabric/ImageRequest.cpp +4 -8
  208. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/HostPlatformViewProps.cpp +16 -15
  209. package/Microsoft.ReactNative/Modules/AccessibilityInfoModule.cpp +15 -0
  210. package/Microsoft.ReactNative/Modules/AccessibilityInfoModule.h +9 -0
  211. package/Microsoft.ReactNative/ReactHost/ReactHost.cpp +20 -1
  212. package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.cpp +11 -6
  213. package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.h +1 -1
  214. package/Microsoft.ReactNative/SynchronousEventBeat.cpp +14 -4
  215. package/Microsoft.ReactNative/SynchronousEventBeat.h +4 -2
  216. package/Microsoft.ReactNative.Cxx/ApiLoaders/JSRuntimeApi.cpp +78 -0
  217. package/Microsoft.ReactNative.Cxx/ApiLoaders/JSRuntimeApi.h +51 -0
  218. package/Microsoft.ReactNative.Cxx/ApiLoaders/JSRuntimeApi.inc +48 -0
  219. package/Microsoft.ReactNative.Cxx/ApiLoaders/NodeApi.cpp +41 -0
  220. package/Microsoft.ReactNative.Cxx/ApiLoaders/NodeApi.h +127 -0
  221. package/Microsoft.ReactNative.Cxx/ApiLoaders/NodeApi.inc +125 -0
  222. package/Microsoft.ReactNative.Cxx/ApiLoaders/NodeApi_posix.cpp +16 -0
  223. package/Microsoft.ReactNative.Cxx/ApiLoaders/NodeApi_win.cpp +23 -0
  224. package/Microsoft.ReactNative.Cxx/JSI/decorator.h +834 -0
  225. package/Microsoft.ReactNative.Cxx/JSI/instrumentation.h +117 -0
  226. package/Microsoft.ReactNative.Cxx/JSI/jsi-inl.h +366 -0
  227. package/Microsoft.ReactNative.Cxx/JSI/jsi.cpp +560 -0
  228. package/Microsoft.ReactNative.Cxx/JSI/jsi.h +1611 -0
  229. package/Microsoft.ReactNative.Cxx/JSI/threadsafe.h +79 -0
  230. package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems +7 -11
  231. package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems.filters +1 -1
  232. package/Microsoft.ReactNative.Cxx/NodeApiJsiRuntime.cpp +2878 -0
  233. package/Microsoft.ReactNative.Cxx/NodeApiJsiRuntime.h +36 -0
  234. package/Microsoft.ReactNative.Cxx/ReactCommon/CallInvoker.h +64 -0
  235. package/Microsoft.ReactNative.Cxx/ReactCommon/SchedulerPriority.h +22 -0
  236. package/{ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core → Microsoft.ReactNative.Cxx}/ReactCommon/TurboModule.cpp +63 -63
  237. package/Microsoft.ReactNative.Cxx/ReactCommon/TurboModule.h +165 -0
  238. package/Microsoft.ReactNative.Cxx/ReactCommon/TurboModuleUtils.cpp +105 -0
  239. package/{ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core → Microsoft.ReactNative.Cxx}/ReactCommon/TurboModuleUtils.h +57 -58
  240. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/AString.h +42 -0
  241. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Array.h +151 -0
  242. package/{ReactCommon/TEMP_UntilReactCommonUpdate → Microsoft.ReactNative.Cxx/ReactCommon}/react/bridging/Base.h +177 -154
  243. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Bool.h +25 -0
  244. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Bridging.h +21 -0
  245. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/CallbackWrapper.h +67 -0
  246. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Class.h +90 -0
  247. package/{ReactCommon/TEMP_UntilReactCommonUpdate → Microsoft.ReactNative.Cxx/ReactCommon}/react/bridging/Convert.h +170 -172
  248. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Error.h +51 -0
  249. package/{ReactCommon/TEMP_UntilReactCommonUpdate → Microsoft.ReactNative.Cxx/ReactCommon}/react/bridging/EventEmitter.h +134 -136
  250. package/{ReactCommon/TEMP_UntilReactCommonUpdate → Microsoft.ReactNative.Cxx/ReactCommon}/react/bridging/Function.h +283 -283
  251. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/LongLivedObject.cpp +63 -0
  252. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/LongLivedObject.h +61 -0
  253. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Object.h +93 -0
  254. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Promise.h +104 -0
  255. package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Value.h +107 -0
  256. package/Microsoft.ReactNative.Cxx/ReactCommon/react/debug/flags.h +22 -0
  257. package/Microsoft.ReactNative.Cxx/ReactCommon/react/debug/react_native_assert.h +72 -0
  258. package/Microsoft.ReactNative.Cxx/node-api/js_native_api.h +553 -0
  259. package/Microsoft.ReactNative.Cxx/node-api/js_native_api_types.h +167 -0
  260. package/Microsoft.ReactNative.Cxx/node-api/js_runtime_api.h +186 -0
  261. package/Microsoft.ReactNative.Cxx/stubs/glog/logging.h +82 -0
  262. package/PropertySheets/Bundle.Common.targets +1 -1
  263. package/PropertySheets/Bundle.props +3 -0
  264. package/PropertySheets/Generated/PackageVersion.g.props +4 -4
  265. package/PropertySheets/ManagedCodeGen/Microsoft.ReactNative.Managed.CodeGen.targets +1 -1
  266. package/PropertySheets/OutputMSBuildProperties.targets +3 -1
  267. package/ReactCommon/ReactCommon.vcxproj +5 -0
  268. package/ReactCommon/TEMP_UntilReactCommonUpdate/cxxreact/JSExecutor.cpp +2 -3
  269. package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/jsi/test/testlib.cpp +61 -0
  270. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModule.h +26 -23
  271. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/componentregistry/ComponentDescriptorRegistry.cpp +150 -0
  272. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/AccessibilityPrimitives.h +252 -0
  273. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/accessibilityPropsConversions.h +795 -0
  274. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/runtimescheduler/SchedulerPriorityUtils.h +59 -0
  275. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/runtime/ReactInstance.cpp +188 -39
  276. package/Scripts/Microsoft.ReactNative.Managed.CodeGen.targets +1 -1
  277. package/Scripts/Tfs/Layout-MSRN-Headers.ps1 +97 -62
  278. package/Shared/InspectorPackagerConnection.cpp +3 -6
  279. package/Shared/InspectorPackagerConnection.h +2 -2
  280. package/Shared/InstanceManager.h +1 -1
  281. package/Shared/OInstance.h +1 -1
  282. package/Shared/Shared.vcxitems +17 -2
  283. package/Shared/Shared.vcxitems.filters +3 -1
  284. package/Shared/TurboModuleManager.cpp +29 -4
  285. package/codegen/NativeAccessibilityInfoSpec.g.h +27 -9
  286. package/codegen/NativeAccessibilityManagerSpec.g.h +19 -13
  287. package/codegen/NativeActionSheetManagerSpec.g.h +4 -0
  288. package/codegen/NativeExceptionsManagerSpec.g.h +1 -7
  289. package/codegen/NativeIntersectionObserverSpec.g.h +2 -0
  290. package/codegen/NativePerformanceSpec.g.h +127 -3
  291. package/codegen/NativeReactDevToolsRuntimeSettingsModuleSpec.g.h +67 -0
  292. package/codegen/NativeReactDevToolsSettingsManagerSpec.g.h +41 -0
  293. package/codegen/NativeReactNativeFeatureFlagsSpec.g.h +125 -137
  294. package/codegen/react/components/rnwcore/ComponentDescriptors.h +0 -1
  295. package/codegen/react/components/rnwcore/Props.cpp +1 -0
  296. package/codegen/react/components/rnwcore/Props.h +1 -0
  297. package/codegen/react/components/rnwcore/ShadowNodes.cpp +0 -1
  298. package/codegen/react/components/rnwcore/ShadowNodes.h +0 -11
  299. package/codegen/react/components/rnwcore/States.h +0 -12
  300. package/codegen/rnwcoreJSI-generated.cpp +219 -186
  301. package/codegen/rnwcoreJSI.h +942 -511
  302. package/index.js +10 -3
  303. package/index.windows.js +10 -3
  304. package/jest/setup.js +36 -1
  305. package/just-task.js +15 -0
  306. package/package.json +22 -22
  307. package/src/private/animated/NativeAnimatedHelper.js +18 -16
  308. package/src/private/animated/useAnimatedPropsMemo.js +348 -0
  309. package/src/private/animated/useAnimatedPropsMemo.windows.js +356 -0
  310. package/src/private/components/HScrollViewNativeComponents.js +1 -27
  311. package/src/private/components/SafeAreaView_INTERNAL_DO_NOT_USE.js +11 -8
  312. package/src/private/components/VScrollViewNativeComponents.js +2 -25
  313. package/src/private/debugging/ReactDevToolsSettingsManager.android.js +20 -0
  314. package/src/private/debugging/ReactDevToolsSettingsManager.ios.js +30 -0
  315. package/src/private/debugging/ReactDevToolsSettingsManager.windows.js +20 -0
  316. package/src/private/{fusebox → debugging}/setUpFuseboxReactDevToolsDispatcher.js +6 -0
  317. package/src/private/devmenu/DevMenu.d.ts +20 -0
  318. package/src/private/devmenu/DevMenu.js +31 -0
  319. package/src/private/featureflags/ReactNativeFeatureFlags.js +95 -86
  320. package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +8 -2
  321. package/src/private/featureflags/specs/NativeReactNativeFeatureFlags.js +17 -19
  322. package/src/private/fusebox/specs/NativeReactDevToolsRuntimeSettingsModule.js +34 -0
  323. package/src/private/setup/setUpDOM.js +14 -6
  324. package/src/private/setup/setUpMutationObserver.js +5 -0
  325. package/src/private/specs/components/AndroidHorizontalScrollContentViewNativeComponent.js +1 -0
  326. package/src/private/specs/components/RCTModalHostViewNativeComponent.js +8 -0
  327. package/src/private/specs/modules/NativeAccessibilityInfo.js +9 -0
  328. package/src/private/specs/modules/NativeAccessibilityManager.js +4 -0
  329. package/src/private/specs/modules/NativeActionSheetManager.js +2 -0
  330. package/src/private/specs/modules/NativeAppearance.js +4 -10
  331. package/src/private/specs/modules/NativeExceptionsManager.js +0 -12
  332. package/src/private/specs/modules/{NativeDevToolsSettingsManager.js → NativeReactDevToolsSettingsManager.js} +3 -5
  333. package/src/private/webapis/dom/geometry/DOMRect.js +2 -2
  334. package/src/private/webapis/dom/geometry/DOMRectReadOnly.js +2 -2
  335. package/src/private/webapis/dom/nodes/ReactNativeElement.js +2 -3
  336. package/src/private/webapis/intersectionobserver/IntersectionObserver.js +102 -11
  337. package/src/private/webapis/intersectionobserver/IntersectionObserverEntry.js +26 -0
  338. package/src/private/webapis/intersectionobserver/IntersectionObserverManager.js +1 -0
  339. package/src/private/webapis/intersectionobserver/specs/NativeIntersectionObserver.js +1 -0
  340. package/src/private/webapis/intersectionobserver/specs/__mocks__/NativeIntersectionObserver.js +9 -0
  341. package/src/private/webapis/performance/EventTiming.js +13 -8
  342. package/src/private/webapis/performance/Performance.js +66 -73
  343. package/src/private/webapis/performance/PerformanceEntry.js +2 -5
  344. package/src/private/webapis/performance/PerformanceObserver.js +65 -164
  345. package/src/private/webapis/performance/RawPerformanceEntry.js +1 -1
  346. package/src/private/webapis/performance/UserTiming.js +11 -7
  347. package/src/private/webapis/performance/Utilities.js +18 -0
  348. package/src/private/webapis/performance/specs/NativePerformance.js +71 -2
  349. package/src/private/webapis/performance/specs/__mocks__/NativePerformanceMock.js +267 -0
  350. package/templates/cpp-lib/template.config.js +13 -7
  351. package/templates/templateUtils.js +10 -0
  352. package/types/index.d.ts +1 -1
  353. package/types/public/ReactNativeTypes.d.ts +4 -8
  354. package/Libraries/DevToolsSettings/DevToolsSettingsManager.android.js +0 -35
  355. package/Libraries/DevToolsSettings/DevToolsSettingsManager.d.ts +0 -20
  356. package/Libraries/DevToolsSettings/DevToolsSettingsManager.ios.js +0 -49
  357. package/Libraries/DevToolsSettings/DevToolsSettingsManager.windows.js +0 -35
  358. package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +0 -13
  359. package/Libraries/ReactNative/ReactFabricInternals.js +0 -17
  360. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/CallbackWrapper.h +0 -101
  361. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/scrollview/ScrollViewProps.cpp +0 -569
  362. package/codegen/NativeDevToolsSettingsManagerSpec.g.h +0 -53
  363. package/codegen/NativePerformanceObserverSpec.g.h +0 -131
  364. package/src/private/components/useSyncOnScroll.js +0 -48
  365. package/src/private/webapis/performance/specs/NativePerformanceObserver.js +0 -61
  366. package/src/private/webapis/performance/specs/__mocks__/NativePerformance.js +0 -67
  367. package/src/private/webapis/performance/specs/__mocks__/NativePerformanceObserver.js +0 -127
  368. package/types/experimental.d.ts +0 -59
  369. /package/src/private/{fusebox → debugging}/FuseboxSessionObserver.js +0 -0
@@ -5,9 +5,11 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  *
7
7
  * @format
8
+ * @flow strict-local
8
9
  */
9
10
 
10
11
  'use strict';
12
+
11
13
  import PooledClass from './PooledClass';
12
14
 
13
15
  const twoArgumentPooler = PooledClass.twoArgumentPooler;
@@ -19,11 +21,14 @@ const twoArgumentPooler = PooledClass.twoArgumentPooler;
19
21
  * @param {number} height Height of bounding rectangle.
20
22
  * @constructor BoundingDimensions
21
23
  */
22
- function BoundingDimensions(width, height) {
24
+ // $FlowFixMe[missing-this-annot]
25
+ function BoundingDimensions(width: number, height: number) {
23
26
  this.width = width;
24
27
  this.height = height;
25
28
  }
26
29
 
30
+ // $FlowFixMe[prop-missing]
31
+ // $FlowFixMe[missing-this-annot]
27
32
  BoundingDimensions.prototype.destructor = function () {
28
33
  this.width = null;
29
34
  this.height = null;
@@ -33,13 +38,16 @@ BoundingDimensions.prototype.destructor = function () {
33
38
  * @param {HTMLElement} element Element to return `BoundingDimensions` for.
34
39
  * @return {BoundingDimensions} Bounding dimensions of `element`.
35
40
  */
36
- BoundingDimensions.getPooledFromElement = function (element) {
41
+ BoundingDimensions.getPooledFromElement = function (
42
+ element: HTMLElement,
43
+ ): typeof BoundingDimensions {
44
+ // $FlowFixMe[prop-missing]
37
45
  return BoundingDimensions.getPooled(
38
46
  element.offsetWidth,
39
47
  element.offsetHeight,
40
48
  );
41
49
  };
42
50
 
43
- PooledClass.addPoolingTo(BoundingDimensions, twoArgumentPooler);
51
+ PooledClass.addPoolingTo(BoundingDimensions as $FlowFixMe, twoArgumentPooler);
44
52
 
45
53
  module.exports = BoundingDimensions;
@@ -5,9 +5,11 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  *
7
7
  * @format
8
+ * @flow strict-local
8
9
  */
9
10
 
10
11
  'use strict';
12
+
11
13
  import PooledClass from './PooledClass';
12
14
 
13
15
  const twoArgumentPooler = PooledClass.twoArgumentPooler;
@@ -20,16 +22,19 @@ const twoArgumentPooler = PooledClass.twoArgumentPooler;
20
22
  * @param {number} windowStartKey Key that window starts at.
21
23
  * @param {number} windowEndKey Key that window ends at.
22
24
  */
23
- function Position(left, top) {
25
+ // $FlowFixMe[missing-this-annot]
26
+ function Position(left: number, top: number) {
24
27
  this.left = left;
25
28
  this.top = top;
26
29
  }
27
30
 
31
+ // $FlowFixMe[prop-missing]
32
+ // $FlowFixMe[missing-this-annot]
28
33
  Position.prototype.destructor = function () {
29
34
  this.left = null;
30
35
  this.top = null;
31
36
  };
32
37
 
33
- PooledClass.addPoolingTo(Position, twoArgumentPooler);
38
+ PooledClass.addPoolingTo(Position as $FlowFixMe, twoArgumentPooler);
34
39
 
35
40
  module.exports = Position;
@@ -713,13 +713,17 @@ const TouchableMixin = {
713
713
  return;
714
714
  }
715
715
  this.state.touchable.positionOnActivate &&
716
+ // $FlowFixMe[prop-missing]
716
717
  Position.release(this.state.touchable.positionOnActivate);
717
718
  this.state.touchable.dimensionsOnActivate &&
719
+ // $FlowFixMe[prop-missing]
718
720
  BoundingDimensions.release(this.state.touchable.dimensionsOnActivate);
721
+ // $FlowFixMe[prop-missing]
719
722
  this.state.touchable.positionOnActivate = Position.getPooled(
720
723
  globalX,
721
724
  globalY,
722
725
  );
726
+ // $FlowFixMe[prop-missing]
723
727
  this.state.touchable.dimensionsOnActivate = BoundingDimensions.getPooled(
724
728
  w,
725
729
  h,
@@ -718,13 +718,17 @@ const TouchableMixin = {
718
718
  return;
719
719
  }
720
720
  this.state.touchable.positionOnActivate &&
721
+ // $FlowFixMe[prop-missing]
721
722
  Position.release(this.state.touchable.positionOnActivate);
722
723
  this.state.touchable.dimensionsOnActivate &&
724
+ // $FlowFixMe[prop-missing]
723
725
  BoundingDimensions.release(this.state.touchable.dimensionsOnActivate);
726
+ // $FlowFixMe[prop-missing]
724
727
  this.state.touchable.positionOnActivate = Position.getPooled(
725
728
  globalX,
726
729
  globalY,
727
730
  );
731
+ // $FlowFixMe[prop-missing]
728
732
  this.state.touchable.dimensionsOnActivate = BoundingDimensions.getPooled(
729
733
  w,
730
734
  h,
@@ -28,7 +28,7 @@ type Props = $ReadOnly<{|
28
28
  releaseVelocity?: ?number,
29
29
  style?: ?ViewStyleProp,
30
30
 
31
- hostRef: React.Ref<typeof Animated.View>,
31
+ hostRef: React.RefSetter<React.ElementRef<typeof Animated.View>>,
32
32
  |}>;
33
33
 
34
34
  type State = $ReadOnly<{|
@@ -189,6 +189,7 @@ class TouchableBounce extends React.Component<Props, State> {
189
189
  this.props.onPress !== undefined &&
190
190
  !this.props.disabled
191
191
  }
192
+ // $FlowFixMe[prop-missing]
192
193
  ref={this.props.hostRef}
193
194
  {...eventHandlersWithoutBlurAndFocus}>
194
195
  {this.props.children}
@@ -215,4 +216,7 @@ class TouchableBounce extends React.Component<Props, State> {
215
216
 
216
217
  module.exports = (React.forwardRef((props, hostRef) => (
217
218
  <TouchableBounce {...props} hostRef={hostRef} />
218
- )): React.AbstractComponent<$ReadOnly<$Diff<Props, {|hostRef: mixed|}>>>);
219
+ )): component(
220
+ ref: React.RefSetter<mixed>,
221
+ ...props: $ReadOnly<$Diff<Props, {|hostRef: mixed|}>>
222
+ ));
@@ -0,0 +1,227 @@
1
+ /**
2
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ * @flow strict-local
8
+ * @format
9
+ */
10
+
11
+ import type {ViewStyleProp} from '../../StyleSheet/StyleSheet';
12
+ import typeof TouchableWithoutFeedback from './TouchableWithoutFeedback';
13
+
14
+ import Animated from '../../Animated/Animated';
15
+ import Pressability, {
16
+ type PressabilityConfig,
17
+ } from '../../Pressability/Pressability';
18
+ import {PressabilityDebugView} from '../../Pressability/PressabilityDebug';
19
+ import Platform from '../../Utilities/Platform';
20
+ import * as React from 'react';
21
+
22
+ type Props = $ReadOnly<{|
23
+ ...React.ElementConfig<TouchableWithoutFeedback>,
24
+
25
+ onPressAnimationComplete?: ?() => void,
26
+ onPressWithCompletion?: ?(callback: () => void) => void,
27
+ releaseBounciness?: ?number,
28
+ releaseVelocity?: ?number,
29
+ style?: ?ViewStyleProp,
30
+
31
+ hostRef: React.RefSetter<React.ElementRef<typeof Animated.View>>,
32
+ |}>;
33
+
34
+ type State = $ReadOnly<{|
35
+ pressability: Pressability,
36
+ scale: Animated.Value,
37
+ |}>;
38
+
39
+ class TouchableBounce extends React.Component<Props, State> {
40
+ state: State = {
41
+ pressability: new Pressability(this._createPressabilityConfig()),
42
+ scale: new Animated.Value(1),
43
+ };
44
+
45
+ _createPressabilityConfig(): PressabilityConfig {
46
+ return {
47
+ cancelable: !this.props.rejectResponderTermination,
48
+ disabled: this.props.disabled,
49
+ hitSlop: this.props.hitSlop,
50
+ delayLongPress: this.props.delayLongPress,
51
+ delayPressIn: this.props.delayPressIn,
52
+ delayPressOut: this.props.delayPressOut,
53
+ minPressDuration: 0,
54
+ pressRectOffset: this.props.pressRetentionOffset,
55
+ android_disableSound: this.props.touchSoundDisabled,
56
+ onBlur: event => {
57
+ if (Platform.isTV) {
58
+ this._bounceTo(1, 0.4, 0);
59
+ }
60
+ if (this.props.onBlur != null) {
61
+ this.props.onBlur(event);
62
+ }
63
+ },
64
+ onFocus: event => {
65
+ if (Platform.isTV) {
66
+ this._bounceTo(0.93, 0.1, 0);
67
+ }
68
+ if (this.props.onFocus != null) {
69
+ this.props.onFocus(event);
70
+ }
71
+ },
72
+ onLongPress: this.props.onLongPress,
73
+ onPress: event => {
74
+ const {onPressAnimationComplete, onPressWithCompletion} = this.props;
75
+ const releaseBounciness = this.props.releaseBounciness ?? 10;
76
+ const releaseVelocity = this.props.releaseVelocity ?? 10;
77
+
78
+ if (onPressWithCompletion != null) {
79
+ onPressWithCompletion(() => {
80
+ this.state.scale.setValue(0.93);
81
+ this._bounceTo(
82
+ 1,
83
+ releaseVelocity,
84
+ releaseBounciness,
85
+ onPressAnimationComplete,
86
+ );
87
+ });
88
+ return;
89
+ }
90
+
91
+ this._bounceTo(
92
+ 1,
93
+ releaseVelocity,
94
+ releaseBounciness,
95
+ onPressAnimationComplete,
96
+ );
97
+ if (this.props.onPress != null) {
98
+ this.props.onPress(event);
99
+ }
100
+ },
101
+ onPressIn: event => {
102
+ this._bounceTo(0.93, 0.1, 0);
103
+ if (this.props.onPressIn != null) {
104
+ this.props.onPressIn(event);
105
+ }
106
+ },
107
+ onPressOut: event => {
108
+ this._bounceTo(1, 0.4, 0);
109
+ if (this.props.onPressOut != null) {
110
+ this.props.onPressOut(event);
111
+ }
112
+ },
113
+ };
114
+ }
115
+
116
+ _bounceTo(
117
+ toValue: number,
118
+ velocity: number,
119
+ bounciness: number,
120
+ callback?: ?() => void,
121
+ ) {
122
+ Animated.spring(this.state.scale, {
123
+ toValue,
124
+ velocity,
125
+ bounciness,
126
+ useNativeDriver: true,
127
+ }).start(callback);
128
+ }
129
+
130
+ render(): React.Node {
131
+ // BACKWARD-COMPATIBILITY: Focus and blur events were never supported before
132
+ // adopting `Pressability`, so preserve that behavior.
133
+ const {onBlur, onFocus, ...eventHandlersWithoutBlurAndFocus} =
134
+ this.state.pressability.getEventHandlers();
135
+ const accessibilityLiveRegion =
136
+ this.props['aria-live'] === 'off'
137
+ ? 'none'
138
+ : this.props['aria-live'] ?? this.props.accessibilityLiveRegion;
139
+ const _accessibilityState = {
140
+ busy: this.props['aria-busy'] ?? this.props.accessibilityState?.busy,
141
+ checked:
142
+ this.props['aria-checked'] ?? this.props.accessibilityState?.checked,
143
+ disabled:
144
+ this.props['aria-disabled'] ?? this.props.accessibilityState?.disabled,
145
+ expanded:
146
+ this.props['aria-expanded'] ?? this.props.accessibilityState?.expanded,
147
+ selected:
148
+ this.props['aria-selected'] ?? this.props.accessibilityState?.selected,
149
+ multiselectable:
150
+ this.props['aria-multiselectable'] ??
151
+ this.props.accessibilityState?.multiselectable, // Windows
152
+ required:
153
+ this.props['aria-required'] ?? this.props.accessibilityState?.required, // Windows
154
+ };
155
+
156
+ const accessibilityValue = {
157
+ max: this.props['aria-valuemax'] ?? this.props.accessibilityValue?.max,
158
+ min: this.props['aria-valuemin'] ?? this.props.accessibilityValue?.min,
159
+ now: this.props['aria-valuenow'] ?? this.props.accessibilityValue?.now,
160
+ text: this.props['aria-valuetext'] ?? this.props.accessibilityValue?.text,
161
+ };
162
+
163
+ const accessibilityLabel =
164
+ this.props['aria-label'] ?? this.props.accessibilityLabel;
165
+ return (
166
+ <Animated.View
167
+ style={[{transform: [{scale: this.state.scale}]}, this.props.style]}
168
+ accessible={this.props.accessible !== false}
169
+ accessibilityLabel={accessibilityLabel}
170
+ accessibilityHint={this.props.accessibilityHint}
171
+ accessibilityLanguage={this.props.accessibilityLanguage}
172
+ accessibilityRole={this.props.accessibilityRole}
173
+ accessibilityState={_accessibilityState}
174
+ accessibilityActions={this.props.accessibilityActions}
175
+ onAccessibilityAction={this.props.onAccessibilityAction}
176
+ accessibilityValue={accessibilityValue}
177
+ accessibilityLiveRegion={accessibilityLiveRegion}
178
+ importantForAccessibility={
179
+ this.props['aria-hidden'] === true
180
+ ? 'no-hide-descendants'
181
+ : this.props.importantForAccessibility
182
+ }
183
+ accessibilityViewIsModal={
184
+ this.props['aria-modal'] ?? this.props.accessibilityViewIsModal
185
+ }
186
+ accessibilityElementsHidden={
187
+ this.props['aria-hidden'] ?? this.props.accessibilityElementsHidden
188
+ }
189
+ nativeID={this.props.id ?? this.props.nativeID}
190
+ testID={this.props.testID}
191
+ hitSlop={this.props.hitSlop}
192
+ focusable={
193
+ this.props.focusable !== false &&
194
+ this.props.onPress !== undefined &&
195
+ !this.props.disabled
196
+ }
197
+ // $FlowFixMe[prop-missing]
198
+ ref={this.props.hostRef}
199
+ {...eventHandlersWithoutBlurAndFocus}>
200
+ {this.props.children}
201
+ {__DEV__ ? (
202
+ <PressabilityDebugView color="orange" hitSlop={this.props.hitSlop} />
203
+ ) : null}
204
+ </Animated.View>
205
+ );
206
+ }
207
+
208
+ componentDidUpdate(prevProps: Props, prevState: State) {
209
+ this.state.pressability.configure(this._createPressabilityConfig());
210
+ }
211
+
212
+ componentDidMount(): mixed {
213
+ this.state.pressability.configure(this._createPressabilityConfig());
214
+ }
215
+
216
+ componentWillUnmount(): void {
217
+ this.state.pressability.reset();
218
+ this.state.scale.resetAnimation();
219
+ }
220
+ }
221
+
222
+ module.exports = (React.forwardRef((props, hostRef) => (
223
+ <TouchableBounce {...props} hostRef={hostRef} />
224
+ )): component(
225
+ ref: React.RefSetter<mixed>,
226
+ ...props: $ReadOnly<$Diff<Props, {|hostRef: mixed|}>>
227
+ ));
@@ -44,7 +44,7 @@ type Props = $ReadOnly<{|
44
44
  onHideUnderlay?: ?() => void,
45
45
  testOnly_pressed?: ?boolean,
46
46
 
47
- hostRef: React.Ref<typeof View>,
47
+ hostRef: React.RefSetter<React.ElementRef<typeof View>>,
48
48
  |}>;
49
49
 
50
50
  type ExtraStyles = $ReadOnly<{|
@@ -381,10 +381,10 @@ class TouchableHighlight extends React.Component<Props, State> {
381
381
  }
382
382
  }
383
383
 
384
- const Touchable: React.AbstractComponent<
385
- $ReadOnly<$Diff<Props, {|hostRef: React.Ref<typeof View>|}>>,
386
- React.ElementRef<typeof View>,
387
- > = React.forwardRef((props, hostRef) => (
384
+ const Touchable: component(
385
+ ref: React.RefSetter<React.ElementRef<typeof View>>,
386
+ ...props: $ReadOnly<$Diff<Props, {|+hostRef: mixed|}>>
387
+ ) = React.forwardRef((props, hostRef) => (
388
388
  <TouchableHighlight {...props} hostRef={hostRef} />
389
389
  ));
390
390
 
@@ -44,7 +44,7 @@ type Props = $ReadOnly<{|
44
44
  onHideUnderlay?: ?() => void,
45
45
  testOnly_pressed?: ?boolean,
46
46
 
47
- hostRef: React.Ref<typeof View>,
47
+ hostRef: React.RefSetter<React.ElementRef<typeof View>>,
48
48
  |}>;
49
49
 
50
50
  type ExtraStyles = $ReadOnly<{|
@@ -396,10 +396,10 @@ class TouchableHighlight extends React.Component<Props, State> {
396
396
  }
397
397
  }
398
398
 
399
- const Touchable: React.AbstractComponent<
400
- $ReadOnly<$Diff<Props, {|hostRef: React.Ref<typeof View>|}>>,
401
- React.ElementRef<typeof View>,
402
- > = React.forwardRef((props, hostRef) => (
399
+ const Touchable: component(
400
+ ref: React.RefSetter<React.ElementRef<typeof View>>,
401
+ ...props: $ReadOnly<$Diff<Props, {|+hostRef: mixed|}>>
402
+ ) = React.forwardRef((props, hostRef) => (
403
403
  <TouchableHighlight {...props} hostRef={hostRef} />
404
404
  ));
405
405