@office-iss/react-native-win32 0.70.2 → 0.71.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 (559) hide show
  1. package/.eslintignore +1 -0
  2. package/.eslintrc.js +2 -0
  3. package/.flowconfig +3 -6
  4. package/CHANGELOG.json +281 -43
  5. package/CHANGELOG.md +105 -24
  6. package/IntegrationTests/AccessibilityManagerTest.js +1 -1
  7. package/IntegrationTests/AppEventsTest.js +0 -1
  8. package/IntegrationTests/BUCK +0 -1
  9. package/IntegrationTests/GlobalEvalWithSourceUrlTest.js +1 -1
  10. package/IntegrationTests/ImageSnapshotTest.js +1 -1
  11. package/IntegrationTests/IntegrationTestsApp.js +2 -3
  12. package/IntegrationTests/SimpleSnapshotTest.js +1 -1
  13. package/IntegrationTests/SyncMethodTest.js +1 -1
  14. package/IntegrationTests/TimersTest.js +4 -4
  15. package/IntegrationTests/WebSocketTest.js +3 -3
  16. package/Libraries/ActionSheetIOS/ActionSheetIOS.d.ts +80 -0
  17. package/Libraries/ActionSheetIOS/ActionSheetIOS.js +4 -3
  18. package/Libraries/ActionSheetIOS/NativeActionSheetManager.js +1 -0
  19. package/Libraries/Alert/Alert.d.ts +90 -0
  20. package/Libraries/Alert/Alert.js +7 -1
  21. package/Libraries/Alert/Alert.win32.js +1 -0
  22. package/Libraries/Alert/NativeAlertManager.js +2 -0
  23. package/Libraries/Alert/RCTAlertManager.ios.js +2 -1
  24. package/Libraries/Animated/Animated.d.ts +587 -0
  25. package/Libraries/Animated/Animated.js +13 -11
  26. package/Libraries/Animated/AnimatedEvent.js +12 -17
  27. package/Libraries/Animated/AnimatedImplementation.js +21 -23
  28. package/Libraries/Animated/AnimatedMock.js +11 -13
  29. package/Libraries/Animated/AnimatedWeb.js +2 -2
  30. package/Libraries/Animated/Easing.d.ts +37 -0
  31. package/Libraries/Animated/Easing.js +2 -2
  32. package/Libraries/Animated/NativeAnimatedHelper.js +32 -22
  33. package/Libraries/Animated/NativeAnimatedModule.js +1 -0
  34. package/Libraries/Animated/NativeAnimatedTurboModule.js +1 -0
  35. package/Libraries/Animated/SpringConfig.js +2 -7
  36. package/Libraries/Animated/animations/Animation.js +3 -4
  37. package/Libraries/Animated/animations/DecayAnimation.js +5 -8
  38. package/Libraries/Animated/animations/SpringAnimation.js +9 -14
  39. package/Libraries/Animated/animations/TimingAnimation.js +9 -13
  40. package/Libraries/Animated/bezier.js +2 -2
  41. package/Libraries/Animated/components/AnimatedFlatList.js +5 -6
  42. package/Libraries/Animated/components/AnimatedImage.js +5 -6
  43. package/Libraries/Animated/components/AnimatedScrollView.js +110 -14
  44. package/Libraries/Animated/components/AnimatedSectionList.js +4 -5
  45. package/Libraries/Animated/components/AnimatedText.js +5 -6
  46. package/Libraries/Animated/components/AnimatedView.js +5 -6
  47. package/Libraries/Animated/createAnimatedComponent.js +13 -20
  48. package/Libraries/Animated/createAnimatedComponent_EXPERIMENTAL.js +2 -2
  49. package/Libraries/Animated/nodes/AnimatedAddition.js +6 -8
  50. package/Libraries/Animated/nodes/AnimatedColor.js +7 -7
  51. package/Libraries/Animated/nodes/AnimatedDiffClamp.js +6 -8
  52. package/Libraries/Animated/nodes/AnimatedDivision.js +7 -9
  53. package/Libraries/Animated/nodes/AnimatedInterpolation.js +7 -10
  54. package/Libraries/Animated/nodes/AnimatedModulo.js +6 -8
  55. package/Libraries/Animated/nodes/AnimatedMultiplication.js +7 -9
  56. package/Libraries/Animated/nodes/AnimatedNode.js +10 -8
  57. package/Libraries/Animated/nodes/AnimatedProps.js +12 -30
  58. package/Libraries/Animated/nodes/AnimatedStyle.js +12 -22
  59. package/Libraries/Animated/nodes/AnimatedSubtraction.js +7 -9
  60. package/Libraries/Animated/nodes/AnimatedTracking.js +8 -12
  61. package/Libraries/Animated/nodes/AnimatedTransform.js +38 -31
  62. package/Libraries/Animated/nodes/AnimatedValue.js +9 -10
  63. package/Libraries/Animated/nodes/AnimatedValueXY.js +4 -7
  64. package/Libraries/Animated/nodes/AnimatedWithChildren.js +4 -5
  65. package/Libraries/Animated/useAnimatedProps.js +8 -16
  66. package/Libraries/Animated/useAnimatedValue.d.ts +15 -0
  67. package/Libraries/Animated/useAnimatedValue.js +25 -0
  68. package/Libraries/AppState/AppState.d.ts +58 -0
  69. package/Libraries/AppState/AppState.js +3 -7
  70. package/Libraries/AppState/NativeAppState.js +1 -0
  71. package/Libraries/BatchedBridge/MessageQueue.js +9 -5
  72. package/Libraries/BatchedBridge/NativeModules.d.ts +25 -0
  73. package/Libraries/BatchedBridge/NativeModules.js +1 -0
  74. package/Libraries/Blob/BlobManager.js +5 -3
  75. package/Libraries/Blob/File.js +2 -3
  76. package/Libraries/Blob/FileReader.js +6 -5
  77. package/Libraries/Blob/NativeBlobModule.js +1 -0
  78. package/Libraries/Blob/NativeFileReaderModule.js +1 -0
  79. package/Libraries/Blob/URL.js +11 -9
  80. package/Libraries/BugReporting/NativeBugReporting.js +1 -0
  81. package/Libraries/BugReporting/getReactData.js +1 -1
  82. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +128 -0
  83. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.flow.js +208 -0
  84. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +40 -8
  85. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.win32.js +40 -8
  86. package/Libraries/Components/AccessibilityInfo/NativeAccessibilityInfo.js +1 -0
  87. package/Libraries/Components/AccessibilityInfo/NativeAccessibilityManager.js +5 -0
  88. package/Libraries/Components/ActivityIndicator/ActivityIndicator.d.ts +86 -0
  89. package/Libraries/Components/ActivityIndicator/ActivityIndicator.flow.js +58 -0
  90. package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +7 -8
  91. package/Libraries/Components/ActivityIndicator/ActivityIndicatorViewNativeComponent.js +2 -3
  92. package/Libraries/Components/Button.d.ts +42 -0
  93. package/Libraries/Components/Button.flow.js +265 -0
  94. package/Libraries/Components/Button.js +62 -18
  95. package/Libraries/Components/Clipboard/Clipboard.d.ts +28 -0
  96. package/Libraries/Components/Clipboard/NativeClipboard.js +1 -0
  97. package/Libraries/Components/DatePicker/DatePickerIOS.android.js +4 -2
  98. package/Libraries/Components/DatePicker/DatePickerIOS.d.ts +92 -0
  99. package/Libraries/Components/{MaskedView/MaskedViewIOS.android.js → DatePicker/DatePickerIOS.flow.android.js} +3 -2
  100. package/Libraries/Components/DatePicker/DatePickerIOS.flow.ios.js +113 -0
  101. package/Libraries/Components/DatePicker/DatePickerIOS.ios.js +8 -7
  102. package/Libraries/Components/DatePicker/DatePickerIOS.win32.js +4 -2
  103. package/Libraries/Components/DatePicker/RCTDatePickerNativeComponent.js +7 -6
  104. package/Libraries/Components/DatePickerAndroid/NativeDatePickerAndroid.js +1 -0
  105. package/Libraries/Components/DrawerAndroid/AndroidDrawerLayoutNativeComponent.js +9 -8
  106. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +13 -14
  107. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.d.ts +141 -0
  108. package/Libraries/Components/Keyboard/Keyboard.d.ts +109 -0
  109. package/Libraries/Components/Keyboard/Keyboard.js +35 -8
  110. package/Libraries/Components/Keyboard/KeyboardAvoidingView.d.ts +46 -0
  111. package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +35 -15
  112. package/Libraries/Components/Keyboard/NativeKeyboardObserver.js +1 -0
  113. package/Libraries/Components/Pressable/Pressable.d.ts +167 -0
  114. package/Libraries/Components/Pressable/Pressable.js +73 -15
  115. package/Libraries/Components/Pressable/Pressable.win32.js +77 -19
  116. package/Libraries/Components/Pressable/useAndroidRippleForView.js +6 -3
  117. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.android.js +3 -3
  118. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.d.ts +83 -0
  119. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroidNativeComponent.js +2 -2
  120. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.android.js +1 -1
  121. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.d.ts +62 -0
  122. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.ios.js +4 -4
  123. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.win32.js +1 -1
  124. package/Libraries/Components/ProgressViewIOS/RCTProgressViewNativeComponent.js +2 -2
  125. package/Libraries/Components/RefreshControl/AndroidSwipeRefreshLayoutNativeComponent.js +5 -6
  126. package/Libraries/Components/RefreshControl/PullToRefreshViewNativeComponent.js +4 -4
  127. package/Libraries/Components/RefreshControl/RefreshControl.d.ts +87 -0
  128. package/Libraries/Components/RefreshControl/RefreshControl.js +4 -3
  129. package/Libraries/Components/RefreshControl/__mocks__/RefreshControlMock.js +2 -3
  130. package/Libraries/Components/SafeAreaView/RCTSafeAreaViewNativeComponent.js +1 -1
  131. package/Libraries/Components/SafeAreaView/SafeAreaView.d.ts +24 -0
  132. package/Libraries/Components/SafeAreaView/SafeAreaView.flow.js +19 -0
  133. package/Libraries/Components/SafeAreaView/SafeAreaView.js +5 -4
  134. package/Libraries/Components/SafeAreaView/SafeAreaView.win32.js +5 -4
  135. package/Libraries/Components/ScrollView/AndroidHorizontalScrollContentViewNativeComponent.js +2 -1
  136. package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +2 -1
  137. package/Libraries/Components/ScrollView/ScrollContentViewNativeComponent.js +2 -1
  138. package/Libraries/Components/ScrollView/ScrollView.d.ts +911 -0
  139. package/Libraries/Components/ScrollView/ScrollView.js +87 -52
  140. package/Libraries/Components/ScrollView/ScrollViewCommands.js +3 -3
  141. package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +2 -1
  142. package/Libraries/Components/ScrollView/ScrollViewNativeComponentType.js +3 -3
  143. package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +243 -269
  144. package/Libraries/Components/Slider/Slider.d.ts +132 -0
  145. package/Libraries/Components/Slider/Slider.js +9 -9
  146. package/Libraries/Components/Slider/SliderNativeComponent.js +4 -5
  147. package/Libraries/Components/Sound/NativeSoundManager.js +1 -0
  148. package/Libraries/Components/StatusBar/NativeStatusBarManagerAndroid.js +1 -0
  149. package/Libraries/Components/StatusBar/NativeStatusBarManagerIOS.js +1 -0
  150. package/Libraries/Components/StatusBar/StatusBar.d.ts +138 -0
  151. package/Libraries/Components/StatusBar/StatusBar.js +7 -7
  152. package/Libraries/Components/Switch/AndroidSwitchNativeComponent.js +10 -10
  153. package/Libraries/Components/Switch/Switch.d.ts +115 -0
  154. package/Libraries/Components/Switch/Switch.js +7 -7
  155. package/Libraries/Components/Switch/SwitchNativeComponent.js +9 -4
  156. package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +40 -12
  157. package/Libraries/Components/TextInput/InputAccessoryView.d.ts +34 -0
  158. package/Libraries/Components/TextInput/InputAccessoryView.js +3 -4
  159. package/Libraries/Components/TextInput/RCTInputAccessoryViewNativeComponent.js +1 -1
  160. package/Libraries/Components/TextInput/RCTMultilineTextInputNativeComponent.js +3 -2
  161. package/Libraries/Components/TextInput/RCTSingelineTextInputNativeComponent.js +3 -2
  162. package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +3 -1
  163. package/Libraries/Components/TextInput/TextInput.d.ts +840 -0
  164. package/Libraries/Components/TextInput/TextInput.flow.js +1057 -0
  165. package/Libraries/Components/TextInput/TextInput.js +344 -38
  166. package/Libraries/Components/TextInput/TextInput.win32.d.ts +1 -1
  167. package/Libraries/Components/TextInput/TextInput.win32.js +1 -1
  168. package/Libraries/Components/TextInput/TextInput.win32.js.map +1 -1
  169. package/Libraries/Components/TextInput/TextInputNativeCommands.js +2 -2
  170. package/Libraries/Components/TextInput/TextInputState.js +22 -5
  171. package/Libraries/Components/TextInput/TextInputState.win32.js +24 -5
  172. package/Libraries/Components/ToastAndroid/NativeToastAndroid.js +1 -0
  173. package/Libraries/Components/ToastAndroid/ToastAndroid.d.ts +47 -0
  174. package/Libraries/Components/Touchable/Tests/TouchableWin32Test.js.map +1 -1
  175. package/Libraries/Components/Touchable/Touchable.d.ts +90 -0
  176. package/Libraries/Components/Touchable/Touchable.flow.js +258 -0
  177. package/Libraries/Components/Touchable/Touchable.js +12 -12
  178. package/Libraries/Components/Touchable/Touchable.win32.js +12 -12
  179. package/Libraries/Components/Touchable/TouchableBounce.js +44 -10
  180. package/Libraries/Components/Touchable/TouchableHighlight.d.ts +68 -0
  181. package/Libraries/Components/Touchable/TouchableHighlight.js +32 -9
  182. package/Libraries/Components/Touchable/TouchableNativeFeedback.d.ts +114 -0
  183. package/Libraries/Components/Touchable/TouchableNativeFeedback.js +54 -20
  184. package/Libraries/Components/Touchable/TouchableOpacity.d.ts +109 -0
  185. package/Libraries/Components/Touchable/TouchableOpacity.js +54 -16
  186. package/Libraries/Components/Touchable/TouchableWin32.Props.d.ts +2 -1
  187. package/Libraries/Components/Touchable/TouchableWin32.Props.js.map +1 -1
  188. package/Libraries/Components/Touchable/TouchableWin32.js +0 -1
  189. package/Libraries/Components/Touchable/TouchableWin32.js.map +1 -1
  190. package/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts +143 -0
  191. package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +64 -10
  192. package/Libraries/Components/UnimplementedViews/UnimplementedNativeViewNativeComponent.js +1 -1
  193. package/Libraries/Components/UnimplementedViews/UnimplementedView.js +1 -1
  194. package/Libraries/Components/View/ReactNativeStyleAttributes.js +13 -2
  195. package/Libraries/Components/View/ReactNativeViewAttributes.win32.js +1 -0
  196. package/Libraries/Components/View/View.d.ts +29 -0
  197. package/Libraries/Components/View/View.js +91 -8
  198. package/Libraries/Components/View/View.win32.js +176 -89
  199. package/Libraries/Components/View/ViewAccessibility.d.ts +360 -0
  200. package/Libraries/Components/View/ViewAccessibility.js +70 -1
  201. package/Libraries/Components/View/ViewNativeComponent.js +3 -3
  202. package/Libraries/Components/View/ViewPropTypes.d.ts +245 -0
  203. package/Libraries/Components/View/ViewPropTypes.js +105 -13
  204. package/Libraries/Components/View/ViewPropTypes.win32.js +105 -13
  205. package/Libraries/Components/View/ViewWin32.Props.d.ts +6 -1
  206. package/Libraries/Components/View/ViewWin32.Props.js.map +1 -1
  207. package/Libraries/Core/Devtools/openFileInEditor.js +3 -0
  208. package/Libraries/Core/Devtools/parseErrorStack.js +1 -1
  209. package/Libraries/Core/Devtools/symbolicateStackTrace.js +2 -2
  210. package/Libraries/Core/ExceptionsManager.js +8 -0
  211. package/Libraries/Core/ExtendedError.js +11 -8
  212. package/Libraries/Core/InitializeCore.js +2 -1
  213. package/Libraries/Core/NativeExceptionsManager.js +3 -4
  214. package/Libraries/Core/RawEventEmitter.js +2 -1
  215. package/Libraries/Core/ReactFiberErrorDialog.js +2 -2
  216. package/Libraries/Core/ReactNativeVersion.js +2 -2
  217. package/Libraries/Core/ReactNativeVersionCheck.js +1 -0
  218. package/Libraries/Core/ReactNativeVersionCheck.win32.js +1 -0
  219. package/Libraries/Core/SegmentFetcher/NativeSegmentFetcher.js +1 -0
  220. package/Libraries/Core/Timers/JSTimers.js +13 -11
  221. package/Libraries/Core/Timers/NativeTiming.js +1 -0
  222. package/Libraries/Core/setUpBatchedBridge.js +1 -5
  223. package/Libraries/Core/setUpDeveloperTools.js +4 -6
  224. package/Libraries/Core/setUpReactDevTools.js +4 -1
  225. package/Libraries/Core/setUpRegeneratorRuntime.js +1 -1
  226. package/Libraries/Core/setUpTimers.js +1 -1
  227. package/Libraries/EventEmitter/NativeEventEmitter.d.ts +70 -0
  228. package/Libraries/EventEmitter/NativeEventEmitter.js +1 -0
  229. package/Libraries/EventEmitter/RCTDeviceEventEmitter.d.ts +30 -0
  230. package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +2 -1
  231. package/Libraries/EventEmitter/RCTNativeAppEventEmitter.d.ts +32 -0
  232. package/Libraries/EventEmitter/__mocks__/NativeEventEmitter.js +1 -0
  233. package/Libraries/Events/EventPolyfill.js +1 -1
  234. package/Libraries/HeapCapture/NativeJSCHeapCapture.js +1 -0
  235. package/Libraries/Image/AssetSourceResolver.js +4 -6
  236. package/Libraries/Image/Image.android.js +63 -45
  237. package/Libraries/Image/Image.d.ts +322 -0
  238. package/Libraries/Image/Image.flow.js +64 -0
  239. package/Libraries/Image/Image.ios.js +55 -28
  240. package/Libraries/Image/Image.win32.js +54 -25
  241. package/Libraries/Image/ImageBackground.js +18 -7
  242. package/Libraries/Image/ImageInjection.js +2 -1
  243. package/Libraries/Image/ImageProps.js +88 -5
  244. package/Libraries/Image/ImageResizeMode.d.ts +49 -0
  245. package/Libraries/Image/ImageSource.d.ts +76 -0
  246. package/Libraries/Image/ImageSourceUtils.js +80 -0
  247. package/Libraries/Image/ImageUtils.js +21 -0
  248. package/Libraries/Image/ImageViewNativeComponent.js +8 -5
  249. package/Libraries/Image/NativeImageEditor.js +1 -0
  250. package/Libraries/Image/NativeImageLoaderAndroid.js +1 -0
  251. package/Libraries/Image/NativeImageLoaderIOS.js +1 -0
  252. package/Libraries/Image/NativeImageLoaderWin32.js +1 -0
  253. package/Libraries/Image/NativeImageStoreAndroid.js +1 -0
  254. package/Libraries/Image/NativeImageStoreIOS.js +1 -0
  255. package/Libraries/Image/TextInlineImageNativeComponent.js +4 -3
  256. package/Libraries/Image/nativeImageSource.js +2 -2
  257. package/Libraries/Image/resolveAssetSource.js +5 -5
  258. package/Libraries/Inspector/BorderBox.js +1 -1
  259. package/Libraries/Inspector/BoxInspector.js +3 -4
  260. package/Libraries/Inspector/DevtoolsOverlay.js +213 -0
  261. package/Libraries/Inspector/ElementBox.js +4 -5
  262. package/Libraries/Inspector/ElementProperties.js +10 -11
  263. package/Libraries/Inspector/Inspector.js +22 -108
  264. package/Libraries/Inspector/Inspector.win32.js +23 -109
  265. package/Libraries/Inspector/InspectorOverlay.js +5 -5
  266. package/Libraries/Inspector/InspectorOverlay.win32.js +5 -5
  267. package/Libraries/Inspector/InspectorPanel.js +12 -10
  268. package/Libraries/Inspector/NetworkOverlay.js +7 -3
  269. package/Libraries/Inspector/PerformanceOverlay.js +3 -3
  270. package/Libraries/Inspector/StyleInspector.js +2 -2
  271. package/Libraries/Inspector/getInspectorDataForViewAtPoint.js +71 -0
  272. package/Libraries/Interaction/BridgeSpyStallHandler.js +1 -1
  273. package/Libraries/Interaction/InteractionManager.d.ts +74 -0
  274. package/Libraries/Interaction/InteractionManager.js +8 -8
  275. package/Libraries/Interaction/NativeFrameRateLogger.js +1 -0
  276. package/Libraries/Interaction/PanResponder.d.ts +202 -0
  277. package/Libraries/Interaction/PanResponder.flow.js +257 -0
  278. package/Libraries/Interaction/PanResponder.js +4 -3
  279. package/Libraries/JSInspector/JSInspector.js +0 -3
  280. package/Libraries/JSInspector/NetworkAgent.js +3 -3
  281. package/Libraries/LayoutAnimation/LayoutAnimation.d.ts +84 -0
  282. package/Libraries/LayoutAnimation/LayoutAnimation.js +4 -3
  283. package/Libraries/Linking/Linking.d.ts +61 -0
  284. package/Libraries/Linking/Linking.js +3 -2
  285. package/Libraries/Linking/NativeIntentAndroid.js +1 -0
  286. package/Libraries/Linking/NativeLinkingManager.js +1 -0
  287. package/Libraries/Lists/CellRenderMask.js +13 -3
  288. package/Libraries/Lists/ChildListCollection.js +72 -0
  289. package/Libraries/Lists/FillRateHelper.js +28 -17
  290. package/Libraries/Lists/FlatList.d.ts +292 -0
  291. package/Libraries/Lists/FlatList.js +70 -70
  292. package/Libraries/Lists/SectionList.d.ts +300 -0
  293. package/Libraries/Lists/SectionList.js +5 -5
  294. package/Libraries/Lists/SectionListModern.js +6 -6
  295. package/Libraries/Lists/StateSafePureComponent.js +85 -0
  296. package/Libraries/Lists/ViewabilityHelper.js +33 -12
  297. package/Libraries/Lists/VirtualizeUtils.js +17 -13
  298. package/Libraries/Lists/VirtualizedList.d.ts +317 -0
  299. package/Libraries/Lists/VirtualizedList.js +548 -890
  300. package/Libraries/Lists/VirtualizedListCellRenderer.js +259 -0
  301. package/Libraries/Lists/VirtualizedListContext.js +7 -48
  302. package/Libraries/Lists/VirtualizedListProps.js +279 -0
  303. package/Libraries/Lists/VirtualizedSectionList.js +6 -3
  304. package/Libraries/Lists/__flowtests__/SectionList-flowtest.js +1 -1
  305. package/Libraries/LogBox/Data/LogBoxData.js +9 -8
  306. package/Libraries/LogBox/Data/LogBoxLog.js +5 -5
  307. package/Libraries/LogBox/Data/LogBoxSymbolication.js +4 -4
  308. package/Libraries/LogBox/Data/parseLogBoxLog.js +5 -3
  309. package/Libraries/LogBox/LogBox.d.ts +28 -0
  310. package/Libraries/LogBox/LogBox.js +11 -11
  311. package/Libraries/LogBox/LogBoxInspectorContainer.js +5 -3
  312. package/Libraries/LogBox/LogBoxNotificationContainer.js +2 -2
  313. package/Libraries/LogBox/UI/AnsiHighlight.js +5 -3
  314. package/Libraries/LogBox/UI/LogBoxButton.js +6 -5
  315. package/Libraries/LogBox/UI/LogBoxInspector.js +6 -6
  316. package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.js +9 -8
  317. package/Libraries/LogBox/UI/LogBoxInspectorFooter.js +3 -3
  318. package/Libraries/LogBox/UI/LogBoxInspectorHeader.js +7 -6
  319. package/Libraries/LogBox/UI/LogBoxInspectorHeader.win32.js +6 -5
  320. package/Libraries/LogBox/UI/LogBoxInspectorMessageHeader.js +6 -5
  321. package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.js +7 -6
  322. package/Libraries/LogBox/UI/LogBoxInspectorSection.js +2 -2
  323. package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +3 -3
  324. package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.js +5 -5
  325. package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.win32.js +5 -5
  326. package/Libraries/LogBox/UI/LogBoxInspectorStackFrames.js +5 -5
  327. package/Libraries/LogBox/UI/LogBoxMessage.js +3 -3
  328. package/Libraries/LogBox/UI/LogBoxNotification.js +6 -5
  329. package/Libraries/Modal/Modal.d.ts +104 -0
  330. package/Libraries/Modal/Modal.js +14 -14
  331. package/Libraries/Modal/NativeModalManager.js +1 -0
  332. package/Libraries/Modal/RCTModalHostViewNativeComponent.js +3 -3
  333. package/Libraries/NativeComponent/BaseViewConfig.android.js +27 -2
  334. package/Libraries/NativeComponent/BaseViewConfig.ios.js +8 -3
  335. package/Libraries/NativeComponent/BaseViewConfig.win32.js +8 -3
  336. package/Libraries/NativeComponent/NativeComponentRegistry.js +5 -4
  337. package/Libraries/NativeComponent/PlatformBaseViewConfig.js +1 -0
  338. package/Libraries/NativeComponent/StaticViewConfigValidator.js +1 -1
  339. package/Libraries/NativeComponent/ViewConfig.js +1 -0
  340. package/Libraries/NativeModules/specs/NativeAnimationsDebugModule.js +1 -0
  341. package/Libraries/NativeModules/specs/NativeDevMenu.js +1 -0
  342. package/Libraries/NativeModules/specs/NativeDevSettings.js +1 -0
  343. package/Libraries/NativeModules/specs/NativeDeviceEventManager.js +1 -0
  344. package/Libraries/NativeModules/specs/NativeDialogManagerAndroid.js +1 -0
  345. package/Libraries/NativeModules/specs/NativeLogBox.js +3 -2
  346. package/Libraries/NativeModules/specs/NativeRedBox.js +1 -0
  347. package/Libraries/NativeModules/specs/NativeSourceCode.js +1 -0
  348. package/Libraries/Network/NativeNetworkingAndroid.js +1 -0
  349. package/Libraries/Network/NativeNetworkingIOS.js +1 -0
  350. package/Libraries/Network/RCTNetworking.android.js +4 -3
  351. package/Libraries/Network/RCTNetworking.ios.js +3 -2
  352. package/Libraries/Network/RCTNetworking.win32.js +1 -0
  353. package/Libraries/Network/convertRequestBody.js +1 -2
  354. package/Libraries/NewAppScreen/components/DebugInstructions.js +4 -1
  355. package/Libraries/NewAppScreen/components/Header.js +6 -2
  356. package/Libraries/NewAppScreen/components/HermesBadge.js +6 -2
  357. package/Libraries/NewAppScreen/components/LearnMoreLinks.js +8 -9
  358. package/Libraries/NewAppScreen/components/ReloadInstructions.js +4 -1
  359. package/Libraries/NewAppScreen/index.js +1 -1
  360. package/Libraries/Performance/NativeJSCSamplingProfiler.js +1 -0
  361. package/Libraries/Performance/QuickPerformanceLogger.js +34 -10
  362. package/Libraries/Performance/Systrace.d.ts +66 -0
  363. package/Libraries/Performance/Systrace.js +110 -195
  364. package/Libraries/PermissionsAndroid/NativePermissionsAndroid.js +1 -0
  365. package/Libraries/PermissionsAndroid/PermissionsAndroid.d.ts +115 -0
  366. package/Libraries/PermissionsAndroid/PermissionsAndroid.js +5 -4
  367. package/Libraries/Pressability/Pressability.js +12 -10
  368. package/Libraries/Pressability/Pressability.win32.js +9 -7
  369. package/Libraries/Pressability/PressabilityDebug.js +2 -2
  370. package/Libraries/PushNotificationIOS/NativePushNotificationManagerIOS.js +1 -0
  371. package/Libraries/PushNotificationIOS/PushNotificationIOS.d.ts +275 -0
  372. package/Libraries/PushNotificationIOS/PushNotificationIOS.js +19 -14
  373. package/Libraries/ReactNative/AppContainer.js +17 -7
  374. package/Libraries/ReactNative/AppRegistry.d.ts +68 -0
  375. package/Libraries/ReactNative/AppRegistry.js +11 -14
  376. package/Libraries/ReactNative/BridgelessUIManager.js +4 -3
  377. package/Libraries/ReactNative/FabricUIManager.js +3 -3
  378. package/Libraries/ReactNative/I18nManager.d.ts +25 -0
  379. package/Libraries/ReactNative/NativeHeadlessJsTaskSupport.js +1 -0
  380. package/Libraries/ReactNative/NativeI18nManager.js +1 -0
  381. package/Libraries/ReactNative/NativeUIManager.js +1 -0
  382. package/Libraries/ReactNative/PaperUIManager.js +2 -2
  383. package/Libraries/ReactNative/PaperUIManager.win32.js +1 -1
  384. package/Libraries/ReactNative/ReactNativeFeatureFlags.js +9 -0
  385. package/Libraries/ReactNative/RendererImplementation.js +112 -0
  386. package/Libraries/ReactNative/RendererProxy.d.ts +20 -0
  387. package/Libraries/ReactNative/RendererProxy.js +26 -0
  388. package/Libraries/ReactNative/RootTag.js +0 -1
  389. package/Libraries/ReactNative/UIManager.d.ts +157 -0
  390. package/Libraries/ReactNative/UIManager.js +1 -1
  391. package/Libraries/ReactNative/getCachedComponentWithDebugName.js +1 -0
  392. package/Libraries/ReactNative/renderApplication.js +38 -20
  393. package/Libraries/ReactNative/requireNativeComponent.d.ts +23 -0
  394. package/Libraries/ReactNative/requireNativeComponent.js +2 -2
  395. package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +10 -9
  396. package/Libraries/Renderer/implementations/ReactFabric-dev.js +312 -217
  397. package/Libraries/Renderer/implementations/ReactFabric-prod.js +212 -177
  398. package/Libraries/Renderer/implementations/ReactFabric-profiling.js +248 -213
  399. package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +311 -218
  400. package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +226 -196
  401. package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +262 -232
  402. package/Libraries/Renderer/implementations/ReactNativeRenderer.d.ts +149 -0
  403. package/Libraries/Renderer/shims/ReactFabric.js +2 -2
  404. package/Libraries/Renderer/shims/ReactFeatureFlags.js +2 -2
  405. package/Libraries/Renderer/shims/ReactNative.js +2 -2
  406. package/Libraries/Renderer/shims/ReactNativeTypes.d.ts +141 -0
  407. package/Libraries/Renderer/shims/ReactNativeTypes.js +23 -22
  408. package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +8 -8
  409. package/Libraries/Renderer/shims/createReactNativeComponentClass.js +2 -2
  410. package/Libraries/Settings/NativeSettingsManager.js +1 -0
  411. package/Libraries/Settings/Settings.d.ts +18 -0
  412. package/Libraries/Share/NativeShareModule.js +1 -0
  413. package/Libraries/Share/Share.d.ts +80 -0
  414. package/Libraries/Share/Share.js +7 -5
  415. package/Libraries/StyleSheet/PlatformColorValueTypes.android.js +1 -1
  416. package/Libraries/StyleSheet/PlatformColorValueTypes.d.ts +18 -0
  417. package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +1 -1
  418. package/Libraries/StyleSheet/PlatformColorValueTypesIOS.d.ts +25 -0
  419. package/Libraries/StyleSheet/PlatformColorValueTypesIOS.ios.js +1 -0
  420. package/Libraries/StyleSheet/StyleSheet.d.ts +156 -0
  421. package/Libraries/StyleSheet/StyleSheet.js +15 -11
  422. package/Libraries/StyleSheet/StyleSheet.win32.js +16 -12
  423. package/Libraries/StyleSheet/StyleSheetTypes.d.ts +332 -0
  424. package/Libraries/StyleSheet/StyleSheetTypes.js +101 -24
  425. package/Libraries/StyleSheet/__flowtests__/StyleSheet-flowtest.js +2 -2
  426. package/Libraries/StyleSheet/normalizeColor.js +3 -3
  427. package/Libraries/StyleSheet/private/_TransformStyle.js +26 -24
  428. package/Libraries/StyleSheet/processAspectRatio.js +53 -0
  429. package/Libraries/StyleSheet/processColor.d.ts +16 -0
  430. package/Libraries/StyleSheet/processColor.js +3 -4
  431. package/Libraries/StyleSheet/processColorArray.js +1 -0
  432. package/Libraries/StyleSheet/processFontVariant.js +30 -0
  433. package/Libraries/StyleSheet/processTransform.js +114 -105
  434. package/Libraries/StyleSheet/splitLayoutProps.js +5 -0
  435. package/Libraries/Text/Text.d.ts +209 -0
  436. package/Libraries/Text/Text.js +94 -12
  437. package/Libraries/Text/TextNativeComponent.js +49 -41
  438. package/Libraries/Text/TextNativeComponent.win32.js +67 -48
  439. package/Libraries/Text/TextProps.js +64 -7
  440. package/Libraries/{Components/MaskedView/MaskedViewIOS.win32.js → TurboModule/RCTExport.d.ts} +3 -4
  441. package/Libraries/TurboModule/TurboModuleRegistry.d.ts +15 -0
  442. package/Libraries/TurboModule/TurboModuleRegistry.js +3 -1
  443. package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +1 -0
  444. package/Libraries/Types/CoreEventTypes.d.ts +263 -0
  445. package/Libraries/Types/CoreEventTypes.js +2 -1
  446. package/Libraries/Types/CoreEventTypes.win32.js +2 -1
  447. package/Libraries/Utilities/AcessibilityMapping.js +154 -0
  448. package/Libraries/Utilities/Appearance.d.ts +43 -0
  449. package/Libraries/Utilities/Appearance.js +3 -3
  450. package/Libraries/Utilities/BackHandler.android.js +3 -5
  451. package/Libraries/Utilities/BackHandler.d.ts +38 -0
  452. package/Libraries/Utilities/BackHandler.win32.js +3 -5
  453. package/Libraries/Utilities/DevSettings.d.ts +32 -0
  454. package/Libraries/Utilities/DevSettings.js +4 -2
  455. package/Libraries/Utilities/Dimensions.d.ts +79 -0
  456. package/Libraries/Utilities/Dimensions.js +2 -2
  457. package/Libraries/Utilities/Dimensions.win32.js +2 -2
  458. package/Libraries/Utilities/GlobalPerformanceLogger.js +2 -1
  459. package/Libraries/Utilities/HMRClient.js +23 -8
  460. package/Libraries/Utilities/LoadingView.ios.js +1 -1
  461. package/Libraries/Utilities/NativeAppearance.js +1 -0
  462. package/Libraries/Utilities/NativeDevLoadingView.js +1 -0
  463. package/Libraries/Utilities/NativeDevSplitBundleLoader.js +1 -0
  464. package/Libraries/Utilities/NativeDeviceInfo.js +1 -0
  465. package/Libraries/Utilities/NativePlatformConstantsAndroid.js +1 -0
  466. package/Libraries/Utilities/NativePlatformConstantsIOS.js +1 -0
  467. package/Libraries/Utilities/NativePlatformConstantsWin.js +1 -0
  468. package/Libraries/Utilities/PerformanceLoggerContext.js +3 -2
  469. package/Libraries/Utilities/PixelRatio.d.ts +64 -0
  470. package/Libraries/Utilities/Platform.android.js +11 -5
  471. package/Libraries/Utilities/Platform.d.ts +102 -0
  472. package/Libraries/Utilities/Platform.ios.js +12 -5
  473. package/Libraries/Utilities/Platform.win32.js +11 -5
  474. package/Libraries/Utilities/PolyfillFunctions.js +1 -1
  475. package/Libraries/Utilities/ReactNativeTestTools.js +9 -15
  476. package/Libraries/Utilities/codegenNativeCommands.js +1 -10
  477. package/Libraries/Utilities/codegenNativeComponent.js +4 -1
  478. package/Libraries/Utilities/createPerformanceLogger.js +7 -8
  479. package/Libraries/Utilities/differ/deepDiffer.js +1 -1
  480. package/Libraries/Utilities/groupByEveryN.js +1 -1
  481. package/Libraries/Utilities/stringifySafe.js +3 -1
  482. package/Libraries/Utilities/useColorScheme.js +3 -2
  483. package/Libraries/Utilities/useRefEffect.js +1 -1
  484. package/Libraries/Vibration/NativeVibration.js +1 -0
  485. package/Libraries/Vibration/Vibration.d.ts +43 -0
  486. package/Libraries/Vibration/Vibration.js +1 -0
  487. package/Libraries/WebPerformance/NativePerformanceObserver.js +41 -0
  488. package/Libraries/WebPerformance/PerformanceObserver.js +223 -0
  489. package/Libraries/WebSocket/NativeWebSocketModule.js +1 -0
  490. package/Libraries/WebSocket/WebSocket.js +11 -3
  491. package/Libraries/WebSocket/WebSocketInterceptor.js +1 -1
  492. package/Libraries/YellowBox/YellowBoxDeprecated.d.ts +19 -0
  493. package/Libraries/YellowBox/YellowBoxDeprecated.js +2 -3
  494. package/Libraries/__flowtests__/ReactNativeTypes-flowtest.js +2 -1
  495. package/Libraries/__tests__/ButtonWin32-test.js +16 -0
  496. package/Libraries/platform-types.d.ts +25 -0
  497. package/Libraries/vendor/core/ErrorUtils.d.ts +15 -0
  498. package/Libraries/vendor/emitter/EventEmitter.d.ts +164 -0
  499. package/babel.config.js +3 -0
  500. package/flow/jest.js +2 -2
  501. package/flow-typed/npm/{react-dom_v16.x.x.js → react-dom_v17.x.x.js} +58 -31
  502. package/flow-typed/npm/yargs_v17.x.x.js +341 -0
  503. package/index.js +89 -55
  504. package/index.win32.js +89 -55
  505. package/interface.js +8 -0
  506. package/jest/react-native-env.js +18 -0
  507. package/jest/renderer.js +2 -2
  508. package/jest/setup.js +7 -9
  509. package/jest.config.js +9 -2
  510. package/overrides.json +40 -101
  511. package/package.json +34 -33
  512. package/src/Libraries/Components/TextInput/TextInput.win32.tsx +2 -1
  513. package/src/Libraries/Components/Touchable/Tests/TouchableWin32Test.tsx +2 -2
  514. package/src/Libraries/Components/Touchable/TouchableWin32.Props.tsx +2 -1
  515. package/src/Libraries/Components/Touchable/TouchableWin32.tsx +1 -1
  516. package/src/Libraries/Components/View/ViewWin32.Props.ts +10 -1
  517. package/src/Libraries/__tests__/__snapshots__/ButtonWin32-test.js.snap +22 -0
  518. package/src/Libraries/platform-types.d.ts +25 -0
  519. package/types/index.d.ts +215 -0
  520. package/IntegrationTests/AsyncStorageTest.js +0 -261
  521. package/Libraries/Components/MaskedView/MaskedViewIOS.ios.js +0 -93
  522. package/Libraries/Components/MaskedView/RCTMaskedViewNativeComponent.js +0 -21
  523. package/Libraries/Core/setUpSystrace.js +0 -21
  524. package/Libraries/Image/ImagePickerIOS.js +0 -103
  525. package/Libraries/Image/NativeImagePickerIOS.js +0 -38
  526. package/Libraries/Lists/VirtualizedList.win32.js +0 -9
  527. package/Libraries/Lists/__tests__/CellRenderMask-test.js +0 -179
  528. package/Libraries/Lists/__tests__/FillRateHelper-test.js +0 -120
  529. package/Libraries/Lists/__tests__/FlatList-test.js +0 -155
  530. package/Libraries/Lists/__tests__/SectionList-test.js +0 -109
  531. package/Libraries/Lists/__tests__/ViewabilityHelper-test.js +0 -440
  532. package/Libraries/Lists/__tests__/VirtualizeUtils-test.js +0 -91
  533. package/Libraries/Lists/__tests__/VirtualizedList-test.js +0 -1587
  534. package/Libraries/Lists/__tests__/VirtualizedSectionList-test.js +0 -269
  535. package/Libraries/Storage/AsyncStorage.js +0 -385
  536. package/Libraries/Storage/NativeAsyncLocalStorage.js +0 -44
  537. package/Libraries/Storage/NativeAsyncSQLiteDBStorage.js +0 -44
  538. package/Libraries/Utilities/JSDevSupportModule.js +0 -37
  539. package/Libraries/Utilities/NativeJSDevSupport.js +0 -23
  540. package/rntypes/BatchedBridge.d.ts +0 -23
  541. package/rntypes/Devtools.d.ts +0 -20
  542. package/rntypes/LaunchScreen.d.ts +0 -9
  543. package/rntypes/globals.d.ts +0 -497
  544. package/rntypes/index.d.ts +0 -9754
  545. package/rntypes/legacy-properties.d.ts +0 -238
  546. package/src/Libraries/Lists/__tests__/__snapshots__/FlatList-test.js.snap +0 -427
  547. package/src/Libraries/Lists/__tests__/__snapshots__/SectionList-test.js.snap +0 -391
  548. package/src/Libraries/Lists/__tests__/__snapshots__/VirtualizedList-test.js.snap +0 -4565
  549. package/src/Libraries/Lists/__tests__/__snapshots__/VirtualizedSectionList-test.js.snap +0 -1153
  550. package/src/rntypes/BatchedBridge.d.ts +0 -23
  551. package/src/rntypes/Devtools.d.ts +0 -20
  552. package/src/rntypes/LaunchScreen.d.ts +0 -9
  553. package/src/rntypes/globals.d.ts +0 -497
  554. package/src/rntypes/index.d.ts +0 -9754
  555. package/src/rntypes/legacy-properties.d.ts +0 -238
  556. package/src/typings-index.ts +0 -37
  557. package/typings-index.d.ts +0 -23
  558. package/typings-index.js +0 -47
  559. package/typings-index.js.map +0 -1
@@ -9,7 +9,10 @@
9
9
  */
10
10
 
11
11
  import type {AnyAttributeType} from '../../Renderer/shims/ReactNativeTypes';
12
+
13
+ import processAspectRatio from '../../StyleSheet/processAspectRatio';
12
14
  import processColor from '../../StyleSheet/processColor';
15
+ import processFontVariant from '../../StyleSheet/processFontVariant';
13
16
  import processTransform from '../../StyleSheet/processTransform';
14
17
  import sizesDiffer from '../../Utilities/differ/sizesDiffer';
15
18
 
@@ -22,13 +25,14 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
22
25
  alignContent: true,
23
26
  alignItems: true,
24
27
  alignSelf: true,
25
- aspectRatio: true,
28
+ aspectRatio: {process: processAspectRatio},
26
29
  borderBottomWidth: true,
27
30
  borderEndWidth: true,
28
31
  borderLeftWidth: true,
29
32
  borderRightWidth: true,
30
33
  borderStartWidth: true,
31
34
  borderTopWidth: true,
35
+ columnGap: true,
32
36
  borderWidth: true,
33
37
  bottom: true,
34
38
  direction: true,
@@ -40,6 +44,7 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
40
44
  flexGrow: true,
41
45
  flexShrink: true,
42
46
  flexWrap: true,
47
+ gap: true,
43
48
  height: true,
44
49
  justifyContent: true,
45
50
  left: true,
@@ -68,6 +73,7 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
68
73
  paddingVertical: true,
69
74
  position: true,
70
75
  right: true,
76
+ rowGap: true,
71
77
  start: true,
72
78
  top: true,
73
79
  width: true,
@@ -98,6 +104,7 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
98
104
  borderBottomRightRadius: true,
99
105
  borderBottomStartRadius: true,
100
106
  borderColor: colorAttributes,
107
+ borderCurve: true,
101
108
  borderEndColor: colorAttributes,
102
109
  borderLeftColor: colorAttributes,
103
110
  borderRadius: true,
@@ -110,6 +117,7 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
110
117
  borderTopRightRadius: true,
111
118
  borderTopStartRadius: true,
112
119
  opacity: true,
120
+ pointerEvents: true,
113
121
 
114
122
  /**
115
123
  * Text
@@ -118,7 +126,7 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
118
126
  fontFamily: true,
119
127
  fontSize: true,
120
128
  fontStyle: true,
121
- fontVariant: true,
129
+ fontVariant: {process: processFontVariant},
122
130
  fontWeight: true,
123
131
  includeFontPadding: true,
124
132
  letterSpacing: true,
@@ -132,6 +140,8 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
132
140
  textShadowOffset: true,
133
141
  textShadowRadius: true,
134
142
  textTransform: true,
143
+ userSelect: true,
144
+ verticalAlign: true,
135
145
  writingDirection: true,
136
146
 
137
147
  /**
@@ -140,6 +150,7 @@ const ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {
140
150
  overlayColor: colorAttributes,
141
151
  resizeMode: true,
142
152
  tintColor: colorAttributes,
153
+ objectFit: true,
143
154
  };
144
155
 
145
156
  module.exports = ReactNativeStyleAttributes;
@@ -37,6 +37,7 @@ const UIView = {
37
37
  style: ReactNativeStyleAttributes,
38
38
  // [Windows
39
39
  accessibilityAccessKey: true,
40
+ alwaysShowToolTip: true,
40
41
  enableFocusRing: true,
41
42
  cursor: true,
42
43
  textStyle: true, // Once we flush out our JS theming story this property will no longer be needed
@@ -0,0 +1,29 @@
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
+ * @format
8
+ */
9
+
10
+ import type * as React from 'react';
11
+ import {Constructor} from '../../../types/private/Utilities';
12
+ import {ViewProps} from './ViewPropTypes';
13
+ import {NativeMethods} from '../../../types/public/ReactNativeTypes';
14
+
15
+ /**
16
+ * The most fundamental component for building UI, View is a container that supports layout with flexbox, style, some touch handling,
17
+ * and accessibility controls, and is designed to be nested inside other views and to have 0 to many children of any type.
18
+ * View maps directly to the native view equivalent on whatever platform React is running on,
19
+ * whether that is a UIView, <div>, android.view, etc.
20
+ */
21
+ declare class ViewComponent extends React.Component<ViewProps> {}
22
+ declare const ViewBase: Constructor<NativeMethods> & typeof ViewComponent;
23
+ export class View extends ViewBase {
24
+ /**
25
+ * Is 3D Touch / Force Touch available (i.e. will touch events include `force`)
26
+ * @platform ios
27
+ */
28
+ static forceTouchAvailable: boolean;
29
+ }
@@ -10,8 +10,10 @@
10
10
 
11
11
  import type {ViewProps} from './ViewPropTypes';
12
12
 
13
- import ViewNativeComponent from './ViewNativeComponent';
13
+ import flattenStyle from '../../StyleSheet/flattenStyle';
14
14
  import TextAncestor from '../../Text/TextAncestor';
15
+ import {getAccessibilityRoleFromRole} from '../../Utilities/AcessibilityMapping';
16
+ import ViewNativeComponent from './ViewNativeComponent';
15
17
  import * as React from 'react';
16
18
 
17
19
  export type Props = ViewProps;
@@ -26,13 +28,94 @@ export type Props = ViewProps;
26
28
  const View: React.AbstractComponent<
27
29
  ViewProps,
28
30
  React.ElementRef<typeof ViewNativeComponent>,
29
- > = React.forwardRef((props: ViewProps, forwardedRef) => {
30
- return (
31
- <TextAncestor.Provider value={false}>
32
- <ViewNativeComponent {...props} ref={forwardedRef} />
33
- </TextAncestor.Provider>
34
- );
35
- });
31
+ > = React.forwardRef(
32
+ (
33
+ {
34
+ accessibilityElementsHidden,
35
+ accessibilityLabel,
36
+ accessibilityLabelledBy,
37
+ accessibilityLiveRegion,
38
+ accessibilityRole,
39
+ accessibilityState,
40
+ accessibilityValue,
41
+ 'aria-busy': ariaBusy,
42
+ 'aria-checked': ariaChecked,
43
+ 'aria-disabled': ariaDisabled,
44
+ 'aria-expanded': ariaExpanded,
45
+ 'aria-hidden': ariaHidden,
46
+ 'aria-label': ariaLabel,
47
+ 'aria-labelledby': ariaLabelledBy,
48
+ 'aria-live': ariaLive,
49
+ 'aria-selected': ariaSelected,
50
+ 'aria-valuemax': ariaValueMax,
51
+ 'aria-valuemin': ariaValueMin,
52
+ 'aria-valuenow': ariaValueNow,
53
+ 'aria-valuetext': ariaValueText,
54
+ focusable,
55
+ id,
56
+ importantForAccessibility,
57
+ nativeID,
58
+ pointerEvents,
59
+ role,
60
+ style,
61
+ tabIndex,
62
+ ...otherProps
63
+ }: ViewProps,
64
+ forwardedRef,
65
+ ) => {
66
+ const _accessibilityLabelledBy =
67
+ ariaLabelledBy?.split(/\s*,\s*/g) ?? accessibilityLabelledBy;
68
+
69
+ const _accessibilityState = {
70
+ busy: ariaBusy ?? accessibilityState?.busy,
71
+ checked: ariaChecked ?? accessibilityState?.checked,
72
+ disabled: ariaDisabled ?? accessibilityState?.disabled,
73
+ expanded: ariaExpanded ?? accessibilityState?.expanded,
74
+ selected: ariaSelected ?? accessibilityState?.selected,
75
+ };
76
+
77
+ const _accessibilityValue = {
78
+ max: ariaValueMax ?? accessibilityValue?.max,
79
+ min: ariaValueMin ?? accessibilityValue?.min,
80
+ now: ariaValueNow ?? accessibilityValue?.now,
81
+ text: ariaValueText ?? accessibilityValue?.text,
82
+ };
83
+
84
+ const flattenedStyle = flattenStyle(style);
85
+ const newPointerEvents = flattenedStyle?.pointerEvents || pointerEvents;
86
+
87
+ return (
88
+ <TextAncestor.Provider value={false}>
89
+ <ViewNativeComponent
90
+ {...otherProps}
91
+ accessibilityLiveRegion={
92
+ ariaLive === 'off' ? 'none' : ariaLive ?? accessibilityLiveRegion
93
+ }
94
+ accessibilityLabel={ariaLabel ?? accessibilityLabel}
95
+ focusable={tabIndex !== undefined ? !tabIndex : focusable}
96
+ accessibilityState={_accessibilityState}
97
+ accessibilityRole={
98
+ role ? getAccessibilityRoleFromRole(role) : accessibilityRole
99
+ }
100
+ accessibilityElementsHidden={
101
+ ariaHidden ?? accessibilityElementsHidden
102
+ }
103
+ accessibilityLabelledBy={_accessibilityLabelledBy}
104
+ accessibilityValue={_accessibilityValue}
105
+ importantForAccessibility={
106
+ ariaHidden === true
107
+ ? 'no-hide-descendants'
108
+ : importantForAccessibility
109
+ }
110
+ nativeID={id ?? nativeID}
111
+ style={style}
112
+ pointerEvents={newPointerEvents}
113
+ ref={forwardedRef}
114
+ />
115
+ </TextAncestor.Provider>
116
+ );
117
+ },
118
+ );
36
119
 
37
120
  View.displayName = 'View';
38
121
 
@@ -10,8 +10,10 @@
10
10
 
11
11
  import type {ViewProps} from './ViewPropTypes';
12
12
 
13
- import ViewNativeComponent from './ViewNativeComponent';
13
+ import flattenStyle from '../../StyleSheet/flattenStyle';
14
14
  import TextAncestor from '../../Text/TextAncestor';
15
+ import {getAccessibilityRoleFromRole} from '../../Utilities/AcessibilityMapping';
16
+ import ViewNativeComponent from './ViewNativeComponent';
15
17
  import * as React from 'react';
16
18
  import invariant from 'invariant'; // [Windows]
17
19
  // [Windows
@@ -30,109 +32,194 @@ export type Props = ViewProps;
30
32
  const View: React.AbstractComponent<
31
33
  ViewProps,
32
34
  React.ElementRef<typeof ViewNativeComponent>,
33
- > = React.forwardRef((props: ViewProps, forwardedRef) => {
34
- const _keyDown = (event: KeyEvent) => {
35
- if (props.keyDownEvents && event.isPropagationStopped() !== true) {
36
- for (const el of props.keyDownEvents) {
37
- if (event.nativeEvent.code == el.code && el.handledEventPhase == 3) {
38
- event.stopPropagation();
39
- }
40
- }
41
- }
42
- props.onKeyDown && props.onKeyDown(event);
43
- };
35
+ > = React.forwardRef(
36
+ (
37
+ {
38
+ accessibilityElementsHidden,
39
+ accessibilityLabel,
40
+ accessibilityLabelledBy,
41
+ accessibilityLiveRegion,
42
+ accessibilityRole,
43
+ accessibilityState,
44
+ accessibilityValue,
45
+ 'aria-busy': ariaBusy,
46
+ 'aria-checked': ariaChecked,
47
+ 'aria-disabled': ariaDisabled,
48
+ 'aria-expanded': ariaExpanded,
49
+ 'aria-hidden': ariaHidden,
50
+ 'aria-label': ariaLabel,
51
+ 'aria-labelledby': ariaLabelledBy,
52
+ 'aria-live': ariaLive,
53
+ 'aria-selected': ariaSelected,
54
+ 'aria-valuemax': ariaValueMax,
55
+ 'aria-valuemin': ariaValueMin,
56
+ 'aria-valuenow': ariaValueNow,
57
+ 'aria-valuetext': ariaValueText,
58
+ focusable,
59
+ id,
60
+ importantForAccessibility,
61
+ nativeID,
62
+ pointerEvents,
63
+ role,
64
+ style,
65
+ tabIndex,
66
+ ...otherProps
67
+ }: ViewProps,
68
+ forwardedRef,
69
+ ) => {
70
+ const _accessibilityLabelledBy =
71
+ ariaLabelledBy?.split(/\s*,\s*/g) ?? accessibilityLabelledBy;
72
+
73
+ const _accessibilityState = {
74
+ busy: ariaBusy ?? accessibilityState?.busy,
75
+ checked: ariaChecked ?? accessibilityState?.checked,
76
+ disabled: ariaDisabled ?? accessibilityState?.disabled,
77
+ expanded: ariaExpanded ?? accessibilityState?.expanded,
78
+ selected: ariaSelected ?? accessibilityState?.selected,
79
+ };
44
80
 
45
- const _keyUp = (event: KeyEvent) => {
46
- if (props.keyUpEvents && event.isPropagationStopped() !== true) {
47
- for (const el of props.keyUpEvents) {
48
- if (event.nativeEvent.code == el.code && el.handledEventPhase == 3) {
49
- event.stopPropagation();
81
+ const _accessibilityValue = {
82
+ max: ariaValueMax ?? accessibilityValue?.max,
83
+ min: ariaValueMin ?? accessibilityValue?.min,
84
+ now: ariaValueNow ?? accessibilityValue?.now,
85
+ text: ariaValueText ?? accessibilityValue?.text,
86
+ };
87
+
88
+ const flattenedStyle = flattenStyle(style);
89
+ const newPointerEvents = flattenedStyle?.pointerEvents || pointerEvents;
90
+
91
+ const _keyDown = (event: KeyEvent) => {
92
+ if (otherProps.keyDownEvents && event.isPropagationStopped() !== true) {
93
+ // $FlowFixMe - keyDownEvents was already checked to not be undefined
94
+ for (const el of otherProps.keyDownEvents) {
95
+ if (event.nativeEvent.code == el.code && el.handledEventPhase == 3) {
96
+ event.stopPropagation();
97
+ }
50
98
  }
51
99
  }
52
- }
53
- props.onKeyUp && props.onKeyUp(event);
54
- };
100
+ otherProps.onKeyDown && otherProps.onKeyDown(event);
101
+ };
55
102
 
56
- const _keyDownCapture = (event: KeyEvent) => {
57
- if (props.keyDownEvents && event.isPropagationStopped() !== true) {
58
- for (const el of props.keyDownEvents) {
59
- if (event.nativeEvent.code == el.code && el.handledEventPhase == 1) {
60
- event.stopPropagation();
103
+ const _keyUp = (event: KeyEvent) => {
104
+ if (otherProps.keyUpEvents && event.isPropagationStopped() !== true) {
105
+ // $FlowFixMe - keyDownEvents was already checked to not be undefined
106
+ for (const el of otherProps.keyUpEvents) {
107
+ if (event.nativeEvent.code == el.code && el.handledEventPhase == 3) {
108
+ event.stopPropagation();
109
+ }
61
110
  }
62
111
  }
63
- }
64
- props.onKeyDownCapture && props.onKeyDownCapture(event);
65
- };
112
+ otherProps.onKeyUp && otherProps.onKeyUp(event);
113
+ };
66
114
 
67
- const _keyUpCapture = (event: KeyEvent) => {
68
- if (props.keyUpEvents && event.isPropagationStopped() !== true) {
69
- for (const el of props.keyUpEvents) {
70
- if (event.nativeEvent.code == el.code && el.handledEventPhase == 1) {
71
- event.stopPropagation();
115
+ const _keyDownCapture = (event: KeyEvent) => {
116
+ if (otherProps.keyDownEvents && event.isPropagationStopped() !== true) {
117
+ // $FlowFixMe - keyDownEvents was already checked to not be undefined
118
+ for (const el of otherProps.keyDownEvents) {
119
+ if (event.nativeEvent.code == el.code && el.handledEventPhase == 1) {
120
+ event.stopPropagation();
121
+ }
72
122
  }
73
123
  }
74
- }
75
- props.onKeyUpCapture && props.onKeyUpCapture(event);
76
- };
124
+ otherProps.onKeyDownCapture && otherProps.onKeyDownCapture(event);
125
+ };
77
126
 
78
- // [Windows
79
- const childrenWithImportantForAccessibility = children => {
80
- return React.Children.map(children, child => {
81
- if (React.isValidElement(child)) {
82
- if (child.props.children) {
83
- return React.cloneElement(child, {
84
- accessible: false,
85
- children: childrenWithImportantForAccessibility(
86
- child.props.children,
87
- ),
88
- });
89
- } else {
90
- return React.cloneElement(child, {accessible: false});
127
+ const _keyUpCapture = (event: KeyEvent) => {
128
+ if (otherProps.keyUpEvents && event.isPropagationStopped() !== true) {
129
+ // $FlowFixMe - keyDownEvents was already checked to not be undefined
130
+ for (const el of otherProps.keyUpEvents) {
131
+ if (event.nativeEvent.code == el.code && el.handledEventPhase == 1) {
132
+ event.stopPropagation();
133
+ }
91
134
  }
92
135
  }
93
- return child;
94
- });
95
- };
96
- // Windows]
136
+ otherProps.onKeyUpCapture && otherProps.onKeyUpCapture(event);
137
+ };
97
138
 
98
- return (
99
139
  // [Windows
100
- // In core this is a TextAncestor.Provider value={false} See
101
- // https://github.com/facebook/react-native/commit/66601e755fcad10698e61d20878d52194ad0e90c
102
- // But since Views are not currently supported in Text, we do not need the extra provider
103
- <TextAncestor.Consumer>
104
- {hasTextAncestor => {
105
- invariant(
106
- !hasTextAncestor,
107
- 'Nesting of <View> within <Text> is not currently supported.',
108
- );
109
- return (
110
- <ViewNativeComponent
111
- {...props}
112
- ref={forwardedRef}
113
- onKeyDown={_keyDown}
114
- onKeyDownCapture={_keyDownCapture}
115
- onKeyUp={_keyUp}
116
- onKeyUpCapture={_keyUpCapture}
117
- // [Windows
118
- accessible={
119
- props.importantForAccessibility === 'no-hide-descendants'
120
- ? false
121
- : props.accessible
122
- }
123
- children={
124
- props.importantForAccessibility === 'no-hide-descendants'
125
- ? childrenWithImportantForAccessibility(props.children)
126
- : props.children
127
- }
128
- // Windows]
129
- />
130
- );
131
- }}
132
- </TextAncestor.Consumer>
140
+ // $FlowFixMe - children typing
141
+ const childrenWithImportantForAccessibility = children => {
142
+ return React.Children.map(children, child => {
143
+ if (React.isValidElement(child)) {
144
+ if (child.props.children) {
145
+ return React.cloneElement(child, {
146
+ accessible: false,
147
+ children: childrenWithImportantForAccessibility(
148
+ child.props.children,
149
+ ),
150
+ });
151
+ } else {
152
+ return React.cloneElement(child, {accessible: false});
153
+ }
154
+ }
155
+ return child;
156
+ });
157
+ };
133
158
  // Windows]
134
- );
135
- });
159
+
160
+ return (
161
+ // [Windows
162
+ // In core this is a TextAncestor.Provider value={false} See
163
+ // https://github.com/facebook/react-native/commit/66601e755fcad10698e61d20878d52194ad0e90c
164
+ // But since Views are not currently supported in Text, we do not need the extra provider
165
+ <TextAncestor.Consumer>
166
+ {hasTextAncestor => {
167
+ invariant(
168
+ !hasTextAncestor,
169
+ 'Nesting of <View> within <Text> is not currently supported.',
170
+ );
171
+ return (
172
+ <ViewNativeComponent
173
+ {...otherProps}
174
+ accessibilityLiveRegion={
175
+ ariaLive === 'off'
176
+ ? 'none'
177
+ : ariaLive ?? accessibilityLiveRegion
178
+ }
179
+ accessibilityLabel={ariaLabel ?? accessibilityLabel}
180
+ focusable={tabIndex !== undefined ? !tabIndex : focusable}
181
+ accessibilityState={_accessibilityState}
182
+ accessibilityRole={
183
+ role ? getAccessibilityRoleFromRole(role) : accessibilityRole
184
+ }
185
+ accessibilityElementsHidden={
186
+ ariaHidden ?? accessibilityElementsHidden
187
+ }
188
+ accessibilityLabelledBy={_accessibilityLabelledBy}
189
+ accessibilityValue={_accessibilityValue}
190
+ importantForAccessibility={
191
+ ariaHidden === true
192
+ ? 'no-hide-descendants'
193
+ : importantForAccessibility
194
+ }
195
+ nativeID={id ?? nativeID}
196
+ style={style}
197
+ pointerEvents={newPointerEvents}
198
+ ref={forwardedRef}
199
+ onKeyDown={_keyDown}
200
+ onKeyDownCapture={_keyDownCapture}
201
+ onKeyUp={_keyUp}
202
+ onKeyUpCapture={_keyUpCapture}
203
+ // [Windows
204
+ accessible={
205
+ importantForAccessibility === 'no-hide-descendants'
206
+ ? false
207
+ : otherProps.accessible
208
+ }
209
+ children={
210
+ importantForAccessibility === 'no-hide-descendants'
211
+ ? childrenWithImportantForAccessibility(otherProps.children)
212
+ : otherProps.children
213
+ }
214
+ // Windows]
215
+ />
216
+ );
217
+ }}
218
+ </TextAncestor.Consumer>
219
+ // Windows]
220
+ );
221
+ },
222
+ );
136
223
 
137
224
  View.displayName = 'View';
138
225