@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
@@ -1,109 +0,0 @@
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
- * @emails oncall+react_native
9
- */
10
-
11
- 'use strict';
12
-
13
- import * as React from 'react';
14
- import ReactTestRenderer from 'react-test-renderer';
15
-
16
- import SectionList from '../SectionList';
17
-
18
- describe('SectionList', () => {
19
- it('renders empty list', () => {
20
- const component = ReactTestRenderer.create(
21
- <SectionList
22
- sections={[]}
23
- renderItem={({item}) => <item v={item.key} />}
24
- />,
25
- );
26
- expect(component).toMatchSnapshot();
27
- });
28
- it('rendering empty section headers is fine', () => {
29
- const component = ReactTestRenderer.create(
30
- <SectionList
31
- sections={[{key: 's1', data: [{key: 'i1'}, {key: 'i2'}]}]}
32
- renderItem={({item}) => <item v={item.key} />}
33
- renderSectionHeader={() => null}
34
- />,
35
- );
36
- expect(component).toMatchSnapshot();
37
- });
38
- it('renders all the bells and whistles', () => {
39
- const component = ReactTestRenderer.create(
40
- <SectionList
41
- initialNumToRender={Infinity}
42
- ItemSeparatorComponent={props => (
43
- <defaultItemSeparator v={propStr(props)} />
44
- )}
45
- ListEmptyComponent={props => <empty v={propStr(props)} />}
46
- ListFooterComponent={props => <footer v={propStr(props)} />}
47
- ListHeaderComponent={props => <header v={propStr(props)} />}
48
- SectionSeparatorComponent={props => (
49
- <sectionSeparator v={propStr(props)} />
50
- )}
51
- sections={[
52
- {
53
- renderItem: props => <itemForSection1 v={propStr(props)} />,
54
- key: 's1',
55
- keyExtractor: (item, index) => item.id,
56
- ItemSeparatorComponent: props => (
57
- <itemSeparatorForSection1 v={propStr(props)} />
58
- ),
59
- data: [{id: 'i1s1'}, {id: 'i2s1'}],
60
- },
61
- {
62
- key: 's2',
63
- data: [{key: 'i1s2'}, {key: 'i2s2'}],
64
- },
65
- {
66
- key: 's3',
67
- data: [{key: 'i1s3'}, {key: 'i2s3'}],
68
- },
69
- ]}
70
- refreshing={false}
71
- onRefresh={jest.fn()}
72
- renderItem={props => <defaultItem v={propStr(props)} />}
73
- renderSectionHeader={props => <sectionHeader v={propStr(props)} />}
74
- renderSectionFooter={props => <sectionFooter v={propStr(props)} />}
75
- />,
76
- );
77
- expect(component).toMatchSnapshot();
78
- });
79
- it('renders a footer when there is no data', () => {
80
- const component = ReactTestRenderer.create(
81
- <SectionList
82
- sections={[{key: 's1', data: []}]}
83
- renderItem={({item}) => <item v={item.key} />}
84
- renderSectionHeader={props => <sectionHeader v={propStr(props)} />}
85
- renderSectionFooter={props => <sectionFooter v={propStr(props)} />}
86
- />,
87
- );
88
- expect(component).toMatchSnapshot();
89
- });
90
- it('renders a footer when there is no data and no header', () => {
91
- const component = ReactTestRenderer.create(
92
- <SectionList
93
- sections={[{key: 's1', data: []}]}
94
- renderItem={({item}) => <item v={item.key} />}
95
- renderSectionFooter={props => <sectionFooter v={propStr(props)} />}
96
- />,
97
- );
98
- expect(component).toMatchSnapshot();
99
- });
100
- });
101
-
102
- function propStr(props) {
103
- return Object.keys(props)
104
- .map(k => {
105
- const propObj = props[k] || {};
106
- return `${k}:${propObj.key || propObj.id || props[k]}`;
107
- })
108
- .join(',');
109
- }
@@ -1,440 +0,0 @@
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
- * @emails oncall+react_native
9
- */
10
-
11
- 'use strict';
12
-
13
- const ViewabilityHelper = require('../ViewabilityHelper');
14
-
15
- let rowFrames;
16
- let data;
17
- function getFrameMetrics(index: number) {
18
- const frame = rowFrames[data[index].key];
19
- return {length: frame.height, offset: frame.y};
20
- }
21
- function createViewToken(index: number, isViewable: boolean) {
22
- return {key: data[index].key, isViewable};
23
- }
24
-
25
- describe('computeViewableItems', function () {
26
- it('returns all 4 entirely visible rows as viewable', function () {
27
- const helper = new ViewabilityHelper({
28
- viewAreaCoveragePercentThreshold: 50,
29
- });
30
- rowFrames = {
31
- a: {y: 0, height: 50},
32
- b: {y: 50, height: 50},
33
- c: {y: 100, height: 50},
34
- d: {y: 150, height: 50},
35
- };
36
- data = [{key: 'a'}, {key: 'b'}, {key: 'c'}, {key: 'd'}];
37
- expect(
38
- helper.computeViewableItems(data.length, 0, 200, getFrameMetrics),
39
- ).toEqual([0, 1, 2, 3]);
40
- });
41
-
42
- it('returns top 2 rows as viewable (1. entirely visible and 2. majority)', function () {
43
- const helper = new ViewabilityHelper({
44
- viewAreaCoveragePercentThreshold: 50,
45
- });
46
- rowFrames = {
47
- a: {y: 0, height: 50},
48
- b: {y: 50, height: 150},
49
- c: {y: 200, height: 50},
50
- d: {y: 250, height: 50},
51
- };
52
- data = [{key: 'a'}, {key: 'b'}, {key: 'c'}, {key: 'd'}];
53
- expect(
54
- helper.computeViewableItems(data.length, 0, 200, getFrameMetrics),
55
- ).toEqual([0, 1]);
56
- });
57
-
58
- it('returns only 2nd row as viewable (majority)', function () {
59
- const helper = new ViewabilityHelper({
60
- viewAreaCoveragePercentThreshold: 50,
61
- });
62
- rowFrames = {
63
- a: {y: 0, height: 50},
64
- b: {y: 50, height: 150},
65
- c: {y: 200, height: 50},
66
- d: {y: 250, height: 50},
67
- };
68
- data = [{key: 'a'}, {key: 'b'}, {key: 'c'}, {key: 'd'}];
69
- expect(
70
- helper.computeViewableItems(data.length, 25, 200, getFrameMetrics),
71
- ).toEqual([1]);
72
- });
73
-
74
- it('handles empty input', function () {
75
- const helper = new ViewabilityHelper({
76
- viewAreaCoveragePercentThreshold: 50,
77
- });
78
- rowFrames = {};
79
- data = [];
80
- expect(
81
- helper.computeViewableItems(data.length, 0, 200, getFrameMetrics),
82
- ).toEqual([]);
83
- });
84
-
85
- it('handles different view area coverage percent thresholds', function () {
86
- rowFrames = {
87
- a: {y: 0, height: 50},
88
- b: {y: 50, height: 150},
89
- c: {y: 200, height: 500},
90
- d: {y: 700, height: 50},
91
- };
92
- data = [{key: 'a'}, {key: 'b'}, {key: 'c'}, {key: 'd'}];
93
-
94
- let helper = new ViewabilityHelper({viewAreaCoveragePercentThreshold: 0});
95
- expect(
96
- helper.computeViewableItems(data.length, 0, 50, getFrameMetrics),
97
- ).toEqual([0]);
98
- expect(
99
- helper.computeViewableItems(data.length, 1, 50, getFrameMetrics),
100
- ).toEqual([0, 1]);
101
- expect(
102
- helper.computeViewableItems(data.length, 199, 50, getFrameMetrics),
103
- ).toEqual([1, 2]);
104
- expect(
105
- helper.computeViewableItems(data.length, 250, 50, getFrameMetrics),
106
- ).toEqual([2]);
107
-
108
- helper = new ViewabilityHelper({viewAreaCoveragePercentThreshold: 100});
109
- expect(
110
- helper.computeViewableItems(data.length, 0, 200, getFrameMetrics),
111
- ).toEqual([0, 1]);
112
- expect(
113
- helper.computeViewableItems(data.length, 1, 200, getFrameMetrics),
114
- ).toEqual([1]);
115
- expect(
116
- helper.computeViewableItems(data.length, 400, 200, getFrameMetrics),
117
- ).toEqual([2]);
118
- expect(
119
- helper.computeViewableItems(data.length, 600, 200, getFrameMetrics),
120
- ).toEqual([3]);
121
-
122
- helper = new ViewabilityHelper({viewAreaCoveragePercentThreshold: 10});
123
- expect(
124
- helper.computeViewableItems(data.length, 30, 200, getFrameMetrics),
125
- ).toEqual([0, 1, 2]);
126
- expect(
127
- helper.computeViewableItems(data.length, 31, 200, getFrameMetrics),
128
- ).toEqual([1, 2]);
129
- });
130
-
131
- it('handles different item visible percent thresholds', function () {
132
- rowFrames = {
133
- a: {y: 0, height: 50},
134
- b: {y: 50, height: 150},
135
- c: {y: 200, height: 50},
136
- d: {y: 250, height: 50},
137
- };
138
- data = [{key: 'a'}, {key: 'b'}, {key: 'c'}, {key: 'd'}];
139
- let helper = new ViewabilityHelper({itemVisiblePercentThreshold: 0});
140
- expect(
141
- helper.computeViewableItems(data.length, 0, 50, getFrameMetrics),
142
- ).toEqual([0]);
143
- expect(
144
- helper.computeViewableItems(data.length, 1, 50, getFrameMetrics),
145
- ).toEqual([0, 1]);
146
-
147
- helper = new ViewabilityHelper({itemVisiblePercentThreshold: 100});
148
- expect(
149
- helper.computeViewableItems(data.length, 0, 250, getFrameMetrics),
150
- ).toEqual([0, 1, 2]);
151
- expect(
152
- helper.computeViewableItems(data.length, 1, 250, getFrameMetrics),
153
- ).toEqual([1, 2]);
154
-
155
- helper = new ViewabilityHelper({itemVisiblePercentThreshold: 10});
156
- expect(
157
- helper.computeViewableItems(data.length, 184, 20, getFrameMetrics),
158
- ).toEqual([1]);
159
- expect(
160
- helper.computeViewableItems(data.length, 185, 20, getFrameMetrics),
161
- ).toEqual([1, 2]);
162
- expect(
163
- helper.computeViewableItems(data.length, 186, 20, getFrameMetrics),
164
- ).toEqual([2]);
165
- });
166
- });
167
-
168
- describe('onUpdate', function () {
169
- it('returns 1 visible row as viewable then scrolls away', function () {
170
- const helper = new ViewabilityHelper();
171
- rowFrames = {
172
- a: {y: 0, height: 50},
173
- };
174
- data = [{key: 'a'}];
175
- const onViewableItemsChanged = jest.fn();
176
- helper.onUpdate(
177
- data.length,
178
- 0,
179
- 200,
180
- getFrameMetrics,
181
- createViewToken,
182
- onViewableItemsChanged,
183
- );
184
- expect(onViewableItemsChanged.mock.calls.length).toBe(1);
185
- expect(onViewableItemsChanged.mock.calls[0][0]).toEqual({
186
- changed: [{isViewable: true, key: 'a'}],
187
- viewabilityConfig: {viewAreaCoveragePercentThreshold: 0},
188
- viewableItems: [{isViewable: true, key: 'a'}],
189
- });
190
- helper.onUpdate(
191
- data.length,
192
- 0,
193
- 200,
194
- getFrameMetrics,
195
- createViewToken,
196
- onViewableItemsChanged,
197
- );
198
- expect(onViewableItemsChanged.mock.calls.length).toBe(1); // nothing changed!
199
- helper.onUpdate(
200
- data.length,
201
- 100,
202
- 200,
203
- getFrameMetrics,
204
- createViewToken,
205
- onViewableItemsChanged,
206
- );
207
- expect(onViewableItemsChanged.mock.calls.length).toBe(2);
208
- expect(onViewableItemsChanged.mock.calls[1][0]).toEqual({
209
- changed: [{isViewable: false, key: 'a'}],
210
- viewabilityConfig: {viewAreaCoveragePercentThreshold: 0},
211
- viewableItems: [],
212
- });
213
- });
214
-
215
- it('returns 1st visible row then 1st and 2nd then just 2nd', function () {
216
- const helper = new ViewabilityHelper();
217
- rowFrames = {
218
- a: {y: 0, height: 200},
219
- b: {y: 200, height: 200},
220
- };
221
- data = [{key: 'a'}, {key: 'b'}];
222
- const onViewableItemsChanged = jest.fn();
223
- helper.onUpdate(
224
- data.length,
225
- 0,
226
- 200,
227
- getFrameMetrics,
228
- createViewToken,
229
- onViewableItemsChanged,
230
- );
231
- expect(onViewableItemsChanged.mock.calls.length).toBe(1);
232
- expect(onViewableItemsChanged.mock.calls[0][0]).toEqual({
233
- changed: [{isViewable: true, key: 'a'}],
234
- viewabilityConfig: {viewAreaCoveragePercentThreshold: 0},
235
- viewableItems: [{isViewable: true, key: 'a'}],
236
- });
237
- helper.onUpdate(
238
- data.length,
239
- 100,
240
- 200,
241
- getFrameMetrics,
242
- createViewToken,
243
- onViewableItemsChanged,
244
- );
245
- expect(onViewableItemsChanged.mock.calls.length).toBe(2);
246
- // Both visible with 100px overlap each
247
- expect(onViewableItemsChanged.mock.calls[1][0]).toEqual({
248
- changed: [{isViewable: true, key: 'b'}],
249
- viewabilityConfig: {viewAreaCoveragePercentThreshold: 0},
250
- viewableItems: [
251
- {isViewable: true, key: 'a'},
252
- {isViewable: true, key: 'b'},
253
- ],
254
- });
255
- helper.onUpdate(
256
- data.length,
257
- 200,
258
- 200,
259
- getFrameMetrics,
260
- createViewToken,
261
- onViewableItemsChanged,
262
- );
263
- expect(onViewableItemsChanged.mock.calls.length).toBe(3);
264
- expect(onViewableItemsChanged.mock.calls[2][0]).toEqual({
265
- changed: [{isViewable: false, key: 'a'}],
266
- viewabilityConfig: {viewAreaCoveragePercentThreshold: 0},
267
- viewableItems: [{isViewable: true, key: 'b'}],
268
- });
269
- });
270
-
271
- it('minimumViewTime delays callback', function () {
272
- const helper = new ViewabilityHelper({
273
- minimumViewTime: 350,
274
- viewAreaCoveragePercentThreshold: 0,
275
- });
276
- rowFrames = {
277
- a: {y: 0, height: 200},
278
- b: {y: 200, height: 200},
279
- };
280
- data = [{key: 'a'}, {key: 'b'}];
281
- const onViewableItemsChanged = jest.fn();
282
- helper.onUpdate(
283
- data.length,
284
- 0,
285
- 200,
286
- getFrameMetrics,
287
- createViewToken,
288
- onViewableItemsChanged,
289
- );
290
- expect(onViewableItemsChanged).not.toBeCalled();
291
-
292
- jest.runAllTimers();
293
-
294
- expect(onViewableItemsChanged.mock.calls.length).toBe(1);
295
- expect(onViewableItemsChanged.mock.calls[0][0]).toEqual({
296
- changed: [{isViewable: true, key: 'a'}],
297
- viewabilityConfig: {
298
- minimumViewTime: 350,
299
- viewAreaCoveragePercentThreshold: 0,
300
- },
301
- viewableItems: [{isViewable: true, key: 'a'}],
302
- });
303
- });
304
-
305
- it('minimumViewTime skips briefly visible items', function () {
306
- const helper = new ViewabilityHelper({
307
- minimumViewTime: 350,
308
- viewAreaCoveragePercentThreshold: 0,
309
- });
310
- rowFrames = {
311
- a: {y: 0, height: 250},
312
- b: {y: 250, height: 200},
313
- };
314
- data = [{key: 'a'}, {key: 'b'}];
315
- const onViewableItemsChanged = jest.fn();
316
- helper.onUpdate(
317
- data.length,
318
- 0,
319
- 200,
320
- getFrameMetrics,
321
- createViewToken,
322
- onViewableItemsChanged,
323
- );
324
- helper.onUpdate(
325
- data.length,
326
- 300, // scroll past item 'a'
327
- 200,
328
- getFrameMetrics,
329
- createViewToken,
330
- onViewableItemsChanged,
331
- );
332
-
333
- jest.runAllTimers();
334
-
335
- expect(onViewableItemsChanged.mock.calls.length).toBe(1);
336
- expect(onViewableItemsChanged.mock.calls[0][0]).toEqual({
337
- changed: [{isViewable: true, key: 'b'}],
338
- viewabilityConfig: {
339
- minimumViewTime: 350,
340
- viewAreaCoveragePercentThreshold: 0,
341
- },
342
- viewableItems: [{isViewable: true, key: 'b'}],
343
- });
344
- });
345
-
346
- it('waitForInteraction blocks callback until interaction', function () {
347
- const helper = new ViewabilityHelper({
348
- waitForInteraction: true,
349
- viewAreaCoveragePercentThreshold: 0,
350
- });
351
- rowFrames = {
352
- a: {y: 0, height: 200},
353
- b: {y: 200, height: 200},
354
- };
355
- data = [{key: 'a'}, {key: 'b'}];
356
- const onViewableItemsChanged = jest.fn();
357
- helper.onUpdate(
358
- data.length,
359
- 0,
360
- 100,
361
- getFrameMetrics,
362
- createViewToken,
363
- onViewableItemsChanged,
364
- );
365
- expect(onViewableItemsChanged).not.toBeCalled();
366
-
367
- helper.recordInteraction();
368
-
369
- helper.onUpdate(
370
- data.length,
371
- 20,
372
- 100,
373
- getFrameMetrics,
374
- createViewToken,
375
- onViewableItemsChanged,
376
- );
377
- expect(onViewableItemsChanged.mock.calls.length).toBe(1);
378
- expect(onViewableItemsChanged.mock.calls[0][0]).toEqual({
379
- changed: [{isViewable: true, key: 'a'}],
380
- viewabilityConfig: {
381
- waitForInteraction: true,
382
- viewAreaCoveragePercentThreshold: 0,
383
- },
384
- viewableItems: [{isViewable: true, key: 'a'}],
385
- });
386
- });
387
-
388
- it('returns the right visible row after the underlying data changed', function () {
389
- const helper = new ViewabilityHelper();
390
- rowFrames = {
391
- a: {y: 0, height: 200},
392
- b: {y: 200, height: 200},
393
- };
394
- data = [{key: 'a'}, {key: 'b'}];
395
- const onViewableItemsChanged = jest.fn();
396
- helper.onUpdate(
397
- data.length,
398
- 0,
399
- 200,
400
- getFrameMetrics,
401
- createViewToken,
402
- onViewableItemsChanged,
403
- );
404
- expect(onViewableItemsChanged.mock.calls.length).toBe(1);
405
- expect(onViewableItemsChanged.mock.calls[0][0]).toEqual({
406
- changed: [{isViewable: true, key: 'a'}],
407
- viewabilityConfig: {viewAreaCoveragePercentThreshold: 0},
408
- viewableItems: [{isViewable: true, key: 'a'}],
409
- });
410
-
411
- // update data
412
- rowFrames = {
413
- c: {y: 0, height: 200},
414
- a: {y: 200, height: 200},
415
- b: {y: 400, height: 200},
416
- };
417
- data = [{key: 'c'}, {key: 'a'}, {key: 'b'}];
418
-
419
- helper.resetViewableIndices();
420
-
421
- helper.onUpdate(
422
- data.length,
423
- 0,
424
- 200,
425
- getFrameMetrics,
426
- createViewToken,
427
- onViewableItemsChanged,
428
- );
429
-
430
- expect(onViewableItemsChanged.mock.calls.length).toBe(2);
431
- expect(onViewableItemsChanged.mock.calls[1][0]).toEqual({
432
- changed: [
433
- {isViewable: true, key: 'c'},
434
- {isViewable: false, key: 'a'},
435
- ],
436
- viewabilityConfig: {viewAreaCoveragePercentThreshold: 0},
437
- viewableItems: [{isViewable: true, key: 'c'}],
438
- });
439
- });
440
- });
@@ -1,91 +0,0 @@
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
- * @emails oncall+react_native
9
- */
10
-
11
- 'use strict';
12
-
13
- import {elementsThatOverlapOffsets, newRangeCount} from '../VirtualizeUtils';
14
-
15
- describe('newRangeCount', function () {
16
- it('handles subset', function () {
17
- expect(newRangeCount({first: 1, last: 4}, {first: 2, last: 3})).toBe(0);
18
- });
19
- it('handles forward disjoint set', function () {
20
- expect(newRangeCount({first: 1, last: 4}, {first: 6, last: 9})).toBe(4);
21
- });
22
- it('handles reverse disjoint set', function () {
23
- expect(newRangeCount({first: 6, last: 8}, {first: 1, last: 4})).toBe(4);
24
- });
25
- it('handles superset', function () {
26
- expect(newRangeCount({first: 1, last: 4}, {first: 0, last: 5})).toBe(2);
27
- });
28
- it('handles end extension', function () {
29
- expect(newRangeCount({first: 1, last: 4}, {first: 1, last: 8})).toBe(4);
30
- });
31
- it('handles front extension', function () {
32
- expect(newRangeCount({first: 1, last: 4}, {first: 0, last: 4})).toBe(1);
33
- });
34
- it('handles forward intersect', function () {
35
- expect(newRangeCount({first: 1, last: 4}, {first: 3, last: 6})).toBe(2);
36
- });
37
- it('handles reverse intersect', function () {
38
- expect(newRangeCount({first: 3, last: 6}, {first: 1, last: 4})).toBe(2);
39
- });
40
- });
41
-
42
- describe('elementsThatOverlapOffsets', function () {
43
- it('handles fixed length', function () {
44
- const offsets = [0, 250, 350, 450];
45
- function getFrameMetrics(index: number) {
46
- return {
47
- length: 100,
48
- offset: 100 * index,
49
- };
50
- }
51
- expect(
52
- elementsThatOverlapOffsets(offsets, 100, getFrameMetrics, 1),
53
- ).toEqual([0, 2, 3, 4]);
54
- });
55
- it('handles variable length', function () {
56
- const offsets = [150, 250, 900];
57
- const frames = [
58
- {offset: 0, length: 50},
59
- {offset: 50, length: 200},
60
- {offset: 250, length: 600},
61
- {offset: 850, length: 100},
62
- {offset: 950, length: 150},
63
- ];
64
- expect(
65
- elementsThatOverlapOffsets(offsets, frames.length, ii => frames[ii], 1),
66
- ).toEqual([1, 1, 3]);
67
- });
68
- it('handles frame boundaries', function () {
69
- const offsets = [0, 100, 200, 300];
70
- function getFrameMetrics(index: number) {
71
- return {
72
- length: 100,
73
- offset: 100 * index,
74
- };
75
- }
76
- expect(
77
- elementsThatOverlapOffsets(offsets, 100, getFrameMetrics, 1),
78
- ).toEqual([0, 0, 1, 2]);
79
- });
80
- it('handles out of bounds', function () {
81
- const offsets = [-100, 150, 900];
82
- const frames = [
83
- {offset: 0, length: 50},
84
- {offset: 50, length: 150},
85
- {offset: 250, length: 100},
86
- ];
87
- expect(
88
- elementsThatOverlapOffsets(offsets, frames.length, ii => frames[ii], 1),
89
- ).toEqual([undefined, 1]);
90
- });
91
- });