@office-iss/react-native-win32 0.71.5 → 0.72.0-preview.2

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 (326) hide show
  1. package/.flowconfig +15 -3
  2. package/CHANGELOG.json +321 -45
  3. package/CHANGELOG.md +149 -26
  4. package/IntegrationTests/IntegrationTestHarnessTest.js +1 -0
  5. package/Libraries/ActionSheetIOS/ActionSheetIOS.js +1 -1
  6. package/Libraries/Alert/Alert.d.ts +4 -4
  7. package/Libraries/Alert/Alert.win32.js +1 -0
  8. package/Libraries/Animated/Animated.d.ts +17 -6
  9. package/Libraries/Animated/NativeAnimatedHelper.js +18 -6
  10. package/Libraries/Animated/NativeAnimatedHelper.win32.js +606 -0
  11. package/Libraries/Animated/bezier.js +1 -1
  12. package/Libraries/Animated/components/AnimatedFlatList.js +8 -3
  13. package/Libraries/Animated/components/AnimatedScrollView.js +4 -1
  14. package/Libraries/Animated/components/AnimatedSectionList.js +12 -3
  15. package/Libraries/Animated/createAnimatedComponent.js +26 -239
  16. package/Libraries/Animated/nodes/AnimatedColor.js +47 -80
  17. package/Libraries/Animated/nodes/AnimatedInterpolation.js +167 -121
  18. package/Libraries/Animated/nodes/AnimatedNode.js +3 -5
  19. package/Libraries/Animated/nodes/AnimatedProps.js +7 -6
  20. package/Libraries/Animated/nodes/AnimatedStyle.js +42 -8
  21. package/Libraries/Animated/nodes/AnimatedTransform.js +1 -1
  22. package/Libraries/Animated/nodes/AnimatedValue.js +8 -12
  23. package/Libraries/Animated/nodes/AnimatedWithChildren.js +1 -1
  24. package/Libraries/Animated/useAnimatedProps.js +7 -10
  25. package/Libraries/BatchedBridge/MessageQueue.js +2 -1
  26. package/Libraries/BatchedBridge/NativeModules.d.ts +1 -1
  27. package/Libraries/BatchedBridge/NativeModules.js +1 -0
  28. package/Libraries/Blob/Blob.js +4 -0
  29. package/Libraries/Blob/FileReader.js +30 -2
  30. package/Libraries/Blob/URL.js +3 -1
  31. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +2 -2
  32. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +2 -3
  33. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.win32.js +2 -3
  34. package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +6 -4
  35. package/Libraries/Components/Button.js +3 -2
  36. package/Libraries/Components/Button.win32.js +451 -0
  37. package/Libraries/Components/Clipboard/Clipboard.js +1 -1
  38. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +4 -0
  39. package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +1 -0
  40. package/Libraries/Components/Pressable/Pressable.d.ts +1 -1
  41. package/Libraries/Components/Pressable/Pressable.js +1 -1
  42. package/Libraries/Components/RefreshControl/RefreshControl.js +1 -0
  43. package/Libraries/Components/SafeAreaView/SafeAreaView.js +1 -2
  44. package/Libraries/Components/SafeAreaView/SafeAreaView.win32.js +1 -2
  45. package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +12 -6
  46. package/Libraries/Components/ScrollView/ScrollView.d.ts +2 -2
  47. package/Libraries/Components/ScrollView/ScrollView.js +149 -91
  48. package/Libraries/Components/ScrollView/ScrollView.win32.js +1939 -0
  49. package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +16 -6
  50. package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +5 -7
  51. package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +1 -1
  52. package/Libraries/Components/StatusBar/StatusBar.js +3 -0
  53. package/Libraries/Components/Switch/Switch.js +3 -1
  54. package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +21 -11
  55. package/Libraries/Components/TextInput/InputAccessoryView.d.ts +1 -1
  56. package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +11 -5
  57. package/Libraries/Components/TextInput/TextInput.Types.win32.d.ts +51 -0
  58. package/Libraries/Components/TextInput/TextInput.Types.win32.js +3 -0
  59. package/Libraries/Components/TextInput/TextInput.Types.win32.js.map +1 -0
  60. package/Libraries/Components/TextInput/TextInput.d.ts +15 -5
  61. package/Libraries/Components/TextInput/TextInput.flow.js +1 -1
  62. package/Libraries/Components/TextInput/TextInput.js +130 -103
  63. package/Libraries/Components/TextInput/TextInput.win32.js +202 -890
  64. package/Libraries/Components/Touchable/Touchable.d.ts +1 -1
  65. package/Libraries/Components/Touchable/Touchable.flow.js +30 -4
  66. package/Libraries/Components/Touchable/Touchable.js +6 -3
  67. package/Libraries/Components/Touchable/Touchable.win32.js +6 -3
  68. package/Libraries/Components/Touchable/TouchableHighlight.js +1 -1
  69. package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -2
  70. package/Libraries/Components/Touchable/TouchableOpacity.js +3 -0
  71. package/Libraries/Components/Touchable/TouchableWin32.js.map +1 -1
  72. package/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts +1 -1
  73. package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +2 -2
  74. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +179 -0
  75. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +43 -0
  76. package/Libraries/Components/View/ReactNativeStyleAttributes.js +26 -0
  77. package/Libraries/Components/View/View.js +35 -16
  78. package/Libraries/Components/View/View.win32.js +38 -16
  79. package/Libraries/Components/View/ViewAccessibility.d.ts +6 -6
  80. package/Libraries/Components/View/ViewAccessibility.js +10 -1
  81. package/Libraries/Components/View/ViewAccessibility.win32.d.ts +5 -5
  82. package/Libraries/Components/View/ViewNativeComponent.js +32 -8
  83. package/Libraries/Components/View/ViewPropTypes.d.ts +1 -1
  84. package/Libraries/Components/View/ViewPropTypes.js +1 -1
  85. package/Libraries/Components/View/ViewPropTypes.win32.d.ts +1 -1
  86. package/Libraries/Components/View/ViewPropTypes.win32.js +1 -1
  87. package/Libraries/Components/View/ViewWin32.js +2 -35
  88. package/Libraries/Core/Devtools/openFileInEditor.js +1 -0
  89. package/Libraries/Core/Devtools/openURLInBrowser.js +1 -0
  90. package/Libraries/Core/Devtools/parseErrorStack.js +2 -2
  91. package/Libraries/Core/Devtools/parseHermesStack.js +54 -34
  92. package/Libraries/Core/ExceptionsManager.js +2 -2
  93. package/Libraries/Core/InitializeCore.js +2 -1
  94. package/Libraries/Core/ReactNativeVersion.js +3 -3
  95. package/Libraries/Core/ReactNativeVersionCheck.js +4 -8
  96. package/Libraries/Core/ReactNativeVersionCheck.win32.js +4 -8
  97. package/Libraries/Core/Timers/JSTimers.js +1 -1
  98. package/Libraries/Core/Timers/immediateShim.js +1 -0
  99. package/Libraries/Core/Timers/queueMicrotask.js +1 -1
  100. package/Libraries/Core/setUpAlert.js +1 -1
  101. package/Libraries/Core/setUpDOM.js +18 -0
  102. package/Libraries/Core/setUpDeveloperTools.js +1 -1
  103. package/Libraries/Core/setUpGlobals.js +5 -2
  104. package/Libraries/Core/setUpNavigator.js +6 -5
  105. package/Libraries/Core/setUpPerformance.js +23 -13
  106. package/Libraries/Core/setUpReactDevTools.js +2 -0
  107. package/Libraries/Core/setUpSegmentFetcher.js +0 -41
  108. package/Libraries/Core/setUpTimers.js +2 -2
  109. package/Libraries/DOM/Geometry/DOMRect.js +82 -0
  110. package/Libraries/DOM/Geometry/DOMRectReadOnly.js +188 -0
  111. package/Libraries/DOM/Nodes/ReactNativeElement.js +75 -0
  112. package/Libraries/DOM/Nodes/ReadOnlyElement.js +89 -0
  113. package/Libraries/DOM/Nodes/ReadOnlyNode.js +167 -0
  114. package/Libraries/DOM/OldStyleCollections/ArrayLikeUtils.js +46 -0
  115. package/Libraries/DOM/OldStyleCollections/DOMRectList.js +76 -0
  116. package/Libraries/DOM/OldStyleCollections/HTMLCollection.js +82 -0
  117. package/Libraries/DOM/OldStyleCollections/NodeList.js +104 -0
  118. package/Libraries/DevToolsSettings/DevToolsSettingsManager.android.js +35 -0
  119. package/Libraries/DevToolsSettings/DevToolsSettingsManager.d.ts +20 -0
  120. package/Libraries/DevToolsSettings/DevToolsSettingsManager.ios.js +49 -0
  121. package/Libraries/DevToolsSettings/DevToolsSettingsManager.win32.js +35 -0
  122. package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +24 -0
  123. package/Libraries/EventEmitter/NativeEventEmitter.d.ts +1 -2
  124. package/Libraries/EventEmitter/RCTDeviceEventEmitter.d.ts +1 -2
  125. package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +9 -1
  126. package/Libraries/Events/EventPolyfill.js +1 -1
  127. package/Libraries/Image/AssetRegistry.js +1 -1
  128. package/Libraries/Image/AssetSourceResolver.js +3 -3
  129. package/Libraries/Image/Image.android.js +4 -1
  130. package/Libraries/Image/Image.d.ts +63 -2
  131. package/Libraries/Image/Image.ios.js +3 -0
  132. package/Libraries/Image/Image.win32.js +3 -0
  133. package/Libraries/Image/ImageBackground.js +1 -0
  134. package/Libraries/Image/ImageProps.js +1 -1
  135. package/Libraries/Image/ImageViewNativeComponent.js +4 -4
  136. package/Libraries/Image/RelativeImageStub.js +1 -1
  137. package/Libraries/Image/TextInlineImageNativeComponent.js +1 -1
  138. package/Libraries/Image/resolveAssetSource.js +1 -1
  139. package/Libraries/Inspector/DevtoolsOverlay.js +26 -19
  140. package/Libraries/Inspector/ElementBox.js +4 -1
  141. package/Libraries/Inspector/Inspector.js +5 -6
  142. package/Libraries/Inspector/Inspector.win32.js +7 -6
  143. package/Libraries/Inspector/InspectorOverlay.js +3 -3
  144. package/Libraries/Inspector/InspectorOverlay.win32.js +2 -1
  145. package/Libraries/Inspector/NetworkOverlay.js +1 -1
  146. package/Libraries/Interaction/JSEventLoopWatchdog.js +1 -1
  147. package/Libraries/Interaction/PanResponder.js +5 -6
  148. package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -1
  149. package/Libraries/Linking/Linking.js +1 -4
  150. package/Libraries/Lists/FillRateHelper.js +4 -238
  151. package/Libraries/Lists/FlatList.d.ts +15 -22
  152. package/Libraries/Lists/FlatList.js +9 -6
  153. package/Libraries/Lists/SectionList.d.ts +10 -6
  154. package/Libraries/Lists/SectionList.js +5 -3
  155. package/Libraries/Lists/SectionListModern.js +3 -3
  156. package/Libraries/Lists/ViewabilityHelper.js +8 -344
  157. package/Libraries/Lists/VirtualizeUtils.js +4 -244
  158. package/Libraries/Lists/VirtualizedList.js +10 -1867
  159. package/Libraries/Lists/VirtualizedListContext.js +6 -104
  160. package/Libraries/Lists/VirtualizedSectionList.js +9 -602
  161. package/Libraries/Lists/__flowtests__/FlatList-flowtest.js +1 -0
  162. package/Libraries/Lists/__flowtests__/SectionList-flowtest.js +1 -1
  163. package/Libraries/LogBox/Data/LogBoxData.js +1 -1
  164. package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
  165. package/Libraries/LogBox/LogBox.js +1 -1
  166. package/Libraries/LogBox/UI/LogBoxInspector.js +1 -3
  167. package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.win32.js +168 -0
  168. package/Libraries/LogBox/UI/LogBoxInspectorHeader.win32.js +3 -0
  169. package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.win32.js +193 -0
  170. package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +1 -0
  171. package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.js +2 -2
  172. package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.win32.js +7 -3
  173. package/Libraries/LogBox/UI/LogBoxMessage.js +87 -5
  174. package/Libraries/LogBox/UI/LogBoxNotification.js +5 -7
  175. package/Libraries/Modal/Modal.js +2 -2
  176. package/Libraries/NativeComponent/BaseViewConfig.android.js +32 -12
  177. package/Libraries/NativeComponent/BaseViewConfig.ios.js +43 -19
  178. package/Libraries/NativeComponent/BaseViewConfig.win32.js +43 -19
  179. package/Libraries/NativeComponent/NativeComponentRegistryUnstable.js +4 -1
  180. package/Libraries/NativeComponent/ViewConfig.js +1 -0
  181. package/Libraries/NativeComponent/ViewConfigIgnore.js +1 -4
  182. package/Libraries/Network/RCTNetworking.android.js +2 -2
  183. package/Libraries/Network/RCTNetworking.ios.js +1 -1
  184. package/Libraries/Network/RCTNetworking.win32.js +1 -1
  185. package/Libraries/Network/XMLHttpRequest.js +1 -1
  186. package/Libraries/Pressability/Pressability.js +10 -4
  187. package/Libraries/Pressability/Pressability.win32.js +9 -3
  188. package/Libraries/ReactNative/AppContainer.js +7 -1
  189. package/Libraries/ReactNative/AppRegistry.d.ts +1 -1
  190. package/Libraries/ReactNative/AppRegistry.js +10 -13
  191. package/Libraries/ReactNative/FabricUIManager.js +24 -8
  192. package/Libraries/ReactNative/NativeUIManager.js +5 -5
  193. package/Libraries/ReactNative/ReactNativeFeatureFlags.js +10 -10
  194. package/Libraries/ReactNative/UIManager.js +168 -1
  195. package/Libraries/ReactNative/getCachedComponentWithDebugName.js +5 -5
  196. package/Libraries/ReactNative/getNativeComponentAttributes.js +1 -1
  197. package/Libraries/ReactNative/requireNativeComponent.d.ts +1 -1
  198. package/Libraries/ReactNative/requireNativeComponent.js +1 -1
  199. package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +1 -0
  200. package/Libraries/Renderer/implementations/ReactFabric-dev.js +26 -3
  201. package/Libraries/Renderer/implementations/ReactFabric-prod.js +13 -1
  202. package/Libraries/Renderer/implementations/ReactFabric-profiling.js +13 -1
  203. package/Libraries/Renderer/public/ReactFabricPublicInstanceUtils.js +38 -0
  204. package/Libraries/Renderer/shims/ReactNativeTypes.js +6 -6
  205. package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -7
  206. package/Libraries/Renderer/shims/createReactNativeComponentClass.js +2 -2
  207. package/Libraries/Share/Share.js +1 -1
  208. package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +1 -1
  209. package/Libraries/StyleSheet/StyleSheet.js +1 -1
  210. package/Libraries/StyleSheet/StyleSheet.win32.js +1 -1
  211. package/Libraries/StyleSheet/StyleSheetTypes.d.ts +115 -76
  212. package/Libraries/StyleSheet/StyleSheetTypes.js +188 -33
  213. package/Libraries/StyleSheet/flattenStyle.js +2 -0
  214. package/Libraries/StyleSheet/normalizeColor.js +1 -1
  215. package/Libraries/StyleSheet/processColor.js +1 -1
  216. package/Libraries/Text/Text.d.ts +12 -2
  217. package/Libraries/Text/Text.js +50 -41
  218. package/Libraries/Text/TextProps.js +3 -4
  219. package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +6 -0
  220. package/Libraries/Types/CodegenTypes.js +1 -0
  221. package/Libraries/UTFSequence.js +3 -1
  222. package/Libraries/Utilities/Appearance.d.ts +10 -0
  223. package/Libraries/Utilities/Appearance.js +13 -0
  224. package/Libraries/Utilities/Dimensions.js +1 -1
  225. package/Libraries/Utilities/Dimensions.win32.js +1 -1
  226. package/Libraries/Utilities/GlobalPerformanceLogger.js +12 -1
  227. package/Libraries/Utilities/HMRClient.js +16 -10
  228. package/Libraries/Utilities/{createPerformanceLogger.d.ts → IPerformanceLogger.d.ts} +4 -4
  229. package/Libraries/Utilities/IPerformanceLogger.js +49 -0
  230. package/Libraries/Utilities/LoadingView.android.js +28 -11
  231. package/Libraries/Utilities/NativeAppearance.js +1 -0
  232. package/Libraries/Utilities/NativePlatformConstantsWin.js +1 -1
  233. package/Libraries/Utilities/PixelRatio.js +2 -2
  234. package/Libraries/Utilities/Platform.win32.js +1 -1
  235. package/Libraries/Utilities/ReactNativeTestTools.js +1 -1
  236. package/Libraries/Utilities/__mocks__/PixelRatio.js +1 -1
  237. package/Libraries/Utilities/codegenNativeCommands.js +2 -0
  238. package/Libraries/Utilities/createPerformanceLogger.js +55 -43
  239. package/Libraries/Utilities/stringifySafe.js +2 -7
  240. package/Libraries/Utilities/useColorScheme.win32.js +26 -0
  241. package/Libraries/Utilities/useWindowDimensions.js +3 -3
  242. package/Libraries/WebPerformance/EventCounts.js +78 -0
  243. package/Libraries/WebPerformance/MemoryInfo.js +54 -0
  244. package/Libraries/WebPerformance/NativePerformance.js +38 -0
  245. package/Libraries/WebPerformance/NativePerformanceObserver.js +22 -7
  246. package/Libraries/WebPerformance/Performance.js +312 -0
  247. package/Libraries/WebPerformance/PerformanceEntry.js +45 -0
  248. package/Libraries/WebPerformance/PerformanceEventTiming.js +38 -0
  249. package/Libraries/WebPerformance/PerformanceObserver.js +196 -101
  250. package/Libraries/WebPerformance/RawPerformanceEntry.js +87 -0
  251. package/Libraries/WebPerformance/ReactNativeStartupTiming.js +65 -0
  252. package/Libraries/WebPerformance/__mocks__/NativePerformance.js +65 -0
  253. package/Libraries/WebPerformance/__mocks__/NativePerformanceObserver.js +101 -0
  254. package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
  255. package/Libraries/vendor/core/ErrorUtils.js +1 -1
  256. package/Libraries/vendor/emitter/EventEmitter.d.ts +2 -2
  257. package/Libraries/vendor/emitter/EventEmitter.js +9 -1
  258. package/flow/global.js +29 -4
  259. package/flow/jest.js +258 -164
  260. package/flow/use-sync-external-store.js +1 -0
  261. package/index.js +56 -42
  262. package/index.win32.js +56 -42
  263. package/interface.js +1 -1
  264. package/jest/local-setup.js +33 -0
  265. package/jest/mockComponent.js +4 -2
  266. package/jest/mockNativeComponent.js +1 -1
  267. package/jest/mockScrollView.js +2 -1
  268. package/jest/react-native-env.js +1 -3
  269. package/jest/setup.js +11 -8
  270. package/overrides.json +122 -85
  271. package/package.json +40 -30
  272. package/rn-get-polyfills.js +1 -1
  273. package/src/Libraries/Components/TextInput/TextInput.Types.win32.ts +68 -0
  274. package/src/Libraries/Components/Touchable/TouchableWin32.tsx +3 -3
  275. package/src/Libraries/Components/View/ViewAccessibility.win32.d.ts +5 -5
  276. package/src/Libraries/Components/View/ViewPropTypes.win32.d.ts +1 -1
  277. package/types/index.d.ts +2 -6
  278. package/types/modules/Codegen.d.ts +4 -4
  279. package/types/modules/globals.d.ts +27 -25
  280. package/types/public/DeprecatedPropertiesAlias.d.ts +0 -20
  281. package/types/public/ReactNativeRenderer.d.ts +2 -7
  282. package/Libraries/Animated/createAnimatedComponentInjection.js +0 -48
  283. package/Libraries/Animated/createAnimatedComponent_EXPERIMENTAL.js +0 -48
  284. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.flow.js +0 -208
  285. package/Libraries/Components/ActivityIndicator/ActivityIndicator.flow.js +0 -58
  286. package/Libraries/Components/DatePicker/DatePickerIOS.android.js +0 -47
  287. package/Libraries/Components/DatePicker/DatePickerIOS.d.ts +0 -92
  288. package/Libraries/Components/DatePicker/DatePickerIOS.flow.android.js +0 -14
  289. package/Libraries/Components/DatePicker/DatePickerIOS.flow.ios.js +0 -113
  290. package/Libraries/Components/DatePicker/DatePickerIOS.ios.js +0 -242
  291. package/Libraries/Components/DatePicker/DatePickerIOS.win32.js +0 -47
  292. package/Libraries/Components/DatePicker/RCTDatePickerNativeComponent.js +0 -60
  293. package/Libraries/Components/DatePickerAndroid/NativeDatePickerAndroid.js +0 -26
  294. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.android.js +0 -45
  295. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.d.ts +0 -62
  296. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.ios.js +0 -75
  297. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.win32.js +0 -45
  298. package/Libraries/Components/ProgressViewIOS/RCTProgressViewNativeComponent.js +0 -33
  299. package/Libraries/Components/SafeAreaView/SafeAreaView.flow.js +0 -19
  300. package/Libraries/Components/Slider/Slider.d.ts +0 -132
  301. package/Libraries/Components/Slider/Slider.js +0 -282
  302. package/Libraries/Components/Slider/SliderNativeComponent.js +0 -56
  303. package/Libraries/Components/TextInput/Win32TextInputNativeComponent.js +0 -23
  304. package/Libraries/Interaction/Batchinator.js +0 -76
  305. package/Libraries/Interaction/BridgeSpyStallHandler.js +0 -63
  306. package/Libraries/Interaction/InteractionStallDebugger.js +0 -23
  307. package/Libraries/Interaction/PanResponder.flow.js +0 -257
  308. package/Libraries/Lists/CellRenderMask.js +0 -155
  309. package/Libraries/Lists/ChildListCollection.js +0 -72
  310. package/Libraries/Lists/StateSafePureComponent.js +0 -85
  311. package/Libraries/Lists/VirtualizedList.d.ts +0 -347
  312. package/Libraries/Lists/VirtualizedListCellRenderer.js +0 -259
  313. package/Libraries/Lists/VirtualizedListProps.js +0 -279
  314. package/Libraries/Performance/PureComponentDebug.js +0 -74
  315. package/Libraries/Reliability/UserFlow.js +0 -158
  316. package/Libraries/Renderer/implementations/ReactNativeRenderer.d.ts +0 -149
  317. package/Libraries/Renderer/shims/ReactNativeTypes.d.ts +0 -141
  318. package/Libraries/Utilities/MatrixMath.js +0 -748
  319. package/Libraries/Utilities/buildStyleInterpolator.js +0 -209
  320. package/Libraries/Utilities/clamp.js +0 -23
  321. package/Libraries/Utilities/deprecatedPropType.js +0 -36
  322. package/Libraries/Utilities/groupByEveryN.js +0 -51
  323. package/Libraries/Utilities/mergeIntoFast.js +0 -26
  324. package/Libraries/Utilities/setAndForwardRef.js +0 -71
  325. package/Libraries/Utilities/truncate.js +0 -51
  326. package/flow/JSITimerInternalType.js +0 -30
@@ -10,351 +10,15 @@
10
10
 
11
11
  'use strict';
12
12
 
13
- import type {FrameMetricProps} from './VirtualizedListProps';
13
+ export type {
14
+ ViewToken,
15
+ ViewabilityConfig,
16
+ ViewabilityConfigCallbackPair,
17
+ } from '@react-native/virtualized-lists';
14
18
 
15
- const invariant = require('invariant');
19
+ import {typeof ViewabilityHelper as ViewabilityHelperType} from '@react-native/virtualized-lists';
16
20
 
17
- export type ViewToken = {
18
- item: any,
19
- key: string,
20
- index: ?number,
21
- isViewable: boolean,
22
- section?: any,
23
- ...
24
- };
25
-
26
- export type ViewabilityConfigCallbackPair = {
27
- viewabilityConfig: ViewabilityConfig,
28
- onViewableItemsChanged: (info: {
29
- viewableItems: Array<ViewToken>,
30
- changed: Array<ViewToken>,
31
- ...
32
- }) => void,
33
- ...
34
- };
35
-
36
- export type ViewabilityConfig = {|
37
- /**
38
- * Minimum amount of time (in milliseconds) that an item must be physically viewable before the
39
- * viewability callback will be fired. A high number means that scrolling through content without
40
- * stopping will not mark the content as viewable.
41
- */
42
- minimumViewTime?: number,
43
-
44
- /**
45
- * Percent of viewport that must be covered for a partially occluded item to count as
46
- * "viewable", 0-100. Fully visible items are always considered viewable. A value of 0 means
47
- * that a single pixel in the viewport makes the item viewable, and a value of 100 means that
48
- * an item must be either entirely visible or cover the entire viewport to count as viewable.
49
- */
50
- viewAreaCoveragePercentThreshold?: number,
51
-
52
- /**
53
- * Similar to `viewAreaPercentThreshold`, but considers the percent of the item that is visible,
54
- * rather than the fraction of the viewable area it covers.
55
- */
56
- itemVisiblePercentThreshold?: number,
57
-
58
- /**
59
- * Nothing is considered viewable until the user scrolls or `recordInteraction` is called after
60
- * render.
61
- */
62
- waitForInteraction?: boolean,
63
- |};
64
-
65
- /**
66
- * A Utility class for calculating viewable items based on current metrics like scroll position and
67
- * layout.
68
- *
69
- * An item is said to be in a "viewable" state when any of the following
70
- * is true for longer than `minimumViewTime` milliseconds (after an interaction if `waitForInteraction`
71
- * is true):
72
- *
73
- * - Occupying >= `viewAreaCoveragePercentThreshold` of the view area XOR fraction of the item
74
- * visible in the view area >= `itemVisiblePercentThreshold`.
75
- * - Entirely visible on screen
76
- */
77
- class ViewabilityHelper {
78
- _config: ViewabilityConfig;
79
- _hasInteracted: boolean = false;
80
- _timers: Set<number> = new Set();
81
- _viewableIndices: Array<number> = [];
82
- _viewableItems: Map<string, ViewToken> = new Map();
83
-
84
- constructor(
85
- config: ViewabilityConfig = {viewAreaCoveragePercentThreshold: 0},
86
- ) {
87
- this._config = config;
88
- }
89
-
90
- /**
91
- * Cleanup, e.g. on unmount. Clears any pending timers.
92
- */
93
- dispose() {
94
- /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This
95
- * comment suppresses an error found when Flow v0.63 was deployed. To see
96
- * the error delete this comment and run Flow. */
97
- this._timers.forEach(clearTimeout);
98
- }
99
-
100
- /**
101
- * Determines which items are viewable based on the current metrics and config.
102
- */
103
- computeViewableItems(
104
- props: FrameMetricProps,
105
- scrollOffset: number,
106
- viewportHeight: number,
107
- getFrameMetrics: (
108
- index: number,
109
- props: FrameMetricProps,
110
- ) => ?{
111
- length: number,
112
- offset: number,
113
- ...
114
- },
115
- // Optional optimization to reduce the scan size
116
- renderRange?: {
117
- first: number,
118
- last: number,
119
- ...
120
- },
121
- ): Array<number> {
122
- const itemCount = props.getItemCount(props.data);
123
- const {itemVisiblePercentThreshold, viewAreaCoveragePercentThreshold} =
124
- this._config;
125
- const viewAreaMode = viewAreaCoveragePercentThreshold != null;
126
- const viewablePercentThreshold = viewAreaMode
127
- ? viewAreaCoveragePercentThreshold
128
- : itemVisiblePercentThreshold;
129
- invariant(
130
- viewablePercentThreshold != null &&
131
- (itemVisiblePercentThreshold != null) !==
132
- (viewAreaCoveragePercentThreshold != null),
133
- 'Must set exactly one of itemVisiblePercentThreshold or viewAreaCoveragePercentThreshold',
134
- );
135
- const viewableIndices = [];
136
- if (itemCount === 0) {
137
- return viewableIndices;
138
- }
139
- let firstVisible = -1;
140
- const {first, last} = renderRange || {first: 0, last: itemCount - 1};
141
- if (last >= itemCount) {
142
- console.warn(
143
- 'Invalid render range computing viewability ' +
144
- JSON.stringify({renderRange, itemCount}),
145
- );
146
- return [];
147
- }
148
- for (let idx = first; idx <= last; idx++) {
149
- const metrics = getFrameMetrics(idx, props);
150
- if (!metrics) {
151
- continue;
152
- }
153
- const top = metrics.offset - scrollOffset;
154
- const bottom = top + metrics.length;
155
- if (top < viewportHeight && bottom > 0) {
156
- firstVisible = idx;
157
- if (
158
- _isViewable(
159
- viewAreaMode,
160
- viewablePercentThreshold,
161
- top,
162
- bottom,
163
- viewportHeight,
164
- metrics.length,
165
- )
166
- ) {
167
- viewableIndices.push(idx);
168
- }
169
- } else if (firstVisible >= 0) {
170
- break;
171
- }
172
- }
173
- return viewableIndices;
174
- }
175
-
176
- /**
177
- * Figures out which items are viewable and how that has changed from before and calls
178
- * `onViewableItemsChanged` as appropriate.
179
- */
180
- onUpdate(
181
- props: FrameMetricProps,
182
- scrollOffset: number,
183
- viewportHeight: number,
184
- getFrameMetrics: (
185
- index: number,
186
- props: FrameMetricProps,
187
- ) => ?{
188
- length: number,
189
- offset: number,
190
- ...
191
- },
192
- createViewToken: (
193
- index: number,
194
- isViewable: boolean,
195
- props: FrameMetricProps,
196
- ) => ViewToken,
197
- onViewableItemsChanged: ({
198
- viewableItems: Array<ViewToken>,
199
- changed: Array<ViewToken>,
200
- ...
201
- }) => void,
202
- // Optional optimization to reduce the scan size
203
- renderRange?: {
204
- first: number,
205
- last: number,
206
- ...
207
- },
208
- ): void {
209
- const itemCount = props.getItemCount(props.data);
210
- if (
211
- (this._config.waitForInteraction && !this._hasInteracted) ||
212
- itemCount === 0 ||
213
- !getFrameMetrics(0, props)
214
- ) {
215
- return;
216
- }
217
- let viewableIndices: Array<number> = [];
218
- if (itemCount) {
219
- viewableIndices = this.computeViewableItems(
220
- props,
221
- scrollOffset,
222
- viewportHeight,
223
- getFrameMetrics,
224
- renderRange,
225
- );
226
- }
227
- if (
228
- this._viewableIndices.length === viewableIndices.length &&
229
- this._viewableIndices.every((v, ii) => v === viewableIndices[ii])
230
- ) {
231
- // We might get a lot of scroll events where visibility doesn't change and we don't want to do
232
- // extra work in those cases.
233
- return;
234
- }
235
- this._viewableIndices = viewableIndices;
236
- if (this._config.minimumViewTime) {
237
- const handle: TimeoutID = setTimeout(() => {
238
- /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This
239
- * comment suppresses an error found when Flow v0.63 was deployed. To
240
- * see the error delete this comment and run Flow. */
241
- this._timers.delete(handle);
242
- this._onUpdateSync(
243
- props,
244
- viewableIndices,
245
- onViewableItemsChanged,
246
- createViewToken,
247
- );
248
- }, this._config.minimumViewTime);
249
- /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This
250
- * comment suppresses an error found when Flow v0.63 was deployed. To see
251
- * the error delete this comment and run Flow. */
252
- this._timers.add(handle);
253
- } else {
254
- this._onUpdateSync(
255
- props,
256
- viewableIndices,
257
- onViewableItemsChanged,
258
- createViewToken,
259
- );
260
- }
261
- }
262
-
263
- /**
264
- * clean-up cached _viewableIndices to evaluate changed items on next update
265
- */
266
- resetViewableIndices() {
267
- this._viewableIndices = [];
268
- }
269
-
270
- /**
271
- * Records that an interaction has happened even if there has been no scroll.
272
- */
273
- recordInteraction() {
274
- this._hasInteracted = true;
275
- }
276
-
277
- _onUpdateSync(
278
- props: FrameMetricProps,
279
- viewableIndicesToCheck: Array<number>,
280
- onViewableItemsChanged: ({
281
- changed: Array<ViewToken>,
282
- viewableItems: Array<ViewToken>,
283
- ...
284
- }) => void,
285
- createViewToken: (
286
- index: number,
287
- isViewable: boolean,
288
- props: FrameMetricProps,
289
- ) => ViewToken,
290
- ) {
291
- // Filter out indices that have gone out of view since this call was scheduled.
292
- viewableIndicesToCheck = viewableIndicesToCheck.filter(ii =>
293
- this._viewableIndices.includes(ii),
294
- );
295
- const prevItems = this._viewableItems;
296
- const nextItems = new Map(
297
- viewableIndicesToCheck.map(ii => {
298
- const viewable = createViewToken(ii, true, props);
299
- return [viewable.key, viewable];
300
- }),
301
- );
302
-
303
- const changed = [];
304
- for (const [key, viewable] of nextItems) {
305
- if (!prevItems.has(key)) {
306
- changed.push(viewable);
307
- }
308
- }
309
- for (const [key, viewable] of prevItems) {
310
- if (!nextItems.has(key)) {
311
- changed.push({...viewable, isViewable: false});
312
- }
313
- }
314
- if (changed.length > 0) {
315
- this._viewableItems = nextItems;
316
- onViewableItemsChanged({
317
- viewableItems: Array.from(nextItems.values()),
318
- changed,
319
- viewabilityConfig: this._config,
320
- });
321
- }
322
- }
323
- }
324
-
325
- function _isViewable(
326
- viewAreaMode: boolean,
327
- viewablePercentThreshold: number,
328
- top: number,
329
- bottom: number,
330
- viewportHeight: number,
331
- itemLength: number,
332
- ): boolean {
333
- if (_isEntirelyVisible(top, bottom, viewportHeight)) {
334
- return true;
335
- } else {
336
- const pixels = _getPixelsVisible(top, bottom, viewportHeight);
337
- const percent =
338
- 100 * (viewAreaMode ? pixels / viewportHeight : pixels / itemLength);
339
- return percent >= viewablePercentThreshold;
340
- }
341
- }
342
-
343
- function _getPixelsVisible(
344
- top: number,
345
- bottom: number,
346
- viewportHeight: number,
347
- ): number {
348
- const visibleHeight = Math.min(bottom, viewportHeight) - Math.max(top, 0);
349
- return Math.max(0, visibleHeight);
350
- }
351
-
352
- function _isEntirelyVisible(
353
- top: number,
354
- bottom: number,
355
- viewportHeight: number,
356
- ): boolean {
357
- return top >= 0 && bottom <= viewportHeight && bottom > top;
358
- }
21
+ const ViewabilityHelper: ViewabilityHelperType =
22
+ require('@react-native/virtualized-lists').ViewabilityHelper;
359
23
 
360
24
  module.exports = ViewabilityHelper;
@@ -10,249 +10,9 @@
10
10
 
11
11
  'use strict';
12
12
 
13
- import type {FrameMetricProps} from './VirtualizedListProps';
13
+ import {typeof keyExtractor as KeyExtractorType} from '@react-native/virtualized-lists';
14
14
 
15
- /**
16
- * Used to find the indices of the frames that overlap the given offsets. Useful for finding the
17
- * items that bound different windows of content, such as the visible area or the buffered overscan
18
- * area.
19
- */
20
- export function elementsThatOverlapOffsets(
21
- offsets: Array<number>,
22
- props: FrameMetricProps,
23
- getFrameMetrics: (
24
- index: number,
25
- props: FrameMetricProps,
26
- ) => {
27
- length: number,
28
- offset: number,
29
- ...
30
- },
31
- zoomScale: number = 1,
32
- ): Array<number> {
33
- const itemCount = props.getItemCount(props.data);
34
- const result = [];
35
- for (let offsetIndex = 0; offsetIndex < offsets.length; offsetIndex++) {
36
- const currentOffset = offsets[offsetIndex];
37
- let left = 0;
38
- let right = itemCount - 1;
39
-
40
- while (left <= right) {
41
- // eslint-disable-next-line no-bitwise
42
- const mid = left + ((right - left) >>> 1);
43
- const frame = getFrameMetrics(mid, props);
44
- const scaledOffsetStart = frame.offset * zoomScale;
45
- const scaledOffsetEnd = (frame.offset + frame.length) * zoomScale;
46
-
47
- // We want the first frame that contains the offset, with inclusive bounds. Thus, for the
48
- // first frame the scaledOffsetStart is inclusive, while for other frames it is exclusive.
49
- if (
50
- (mid === 0 && currentOffset < scaledOffsetStart) ||
51
- (mid !== 0 && currentOffset <= scaledOffsetStart)
52
- ) {
53
- right = mid - 1;
54
- } else if (currentOffset > scaledOffsetEnd) {
55
- left = mid + 1;
56
- } else {
57
- result[offsetIndex] = mid;
58
- break;
59
- }
60
- }
61
- }
62
-
63
- return result;
64
- }
65
-
66
- /**
67
- * Computes the number of elements in the `next` range that are new compared to the `prev` range.
68
- * Handy for calculating how many new items will be rendered when the render window changes so we
69
- * can restrict the number of new items render at once so that content can appear on the screen
70
- * faster.
71
- */
72
- export function newRangeCount(
73
- prev: {
74
- first: number,
75
- last: number,
76
- ...
77
- },
78
- next: {
79
- first: number,
80
- last: number,
81
- ...
82
- },
83
- ): number {
84
- return (
85
- next.last -
86
- next.first +
87
- 1 -
88
- Math.max(
89
- 0,
90
- 1 + Math.min(next.last, prev.last) - Math.max(next.first, prev.first),
91
- )
92
- );
93
- }
94
-
95
- /**
96
- * Custom logic for determining which items should be rendered given the current frame and scroll
97
- * metrics, as well as the previous render state. The algorithm may evolve over time, but generally
98
- * prioritizes the visible area first, then expands that with overscan regions ahead and behind,
99
- * biased in the direction of scroll.
100
- */
101
- export function computeWindowedRenderLimits(
102
- props: FrameMetricProps,
103
- maxToRenderPerBatch: number,
104
- windowSize: number,
105
- prev: {
106
- first: number,
107
- last: number,
108
- },
109
- getFrameMetricsApprox: (
110
- index: number,
111
- props: FrameMetricProps,
112
- ) => {
113
- length: number,
114
- offset: number,
115
- ...
116
- },
117
- scrollMetrics: {
118
- dt: number,
119
- offset: number,
120
- velocity: number,
121
- visibleLength: number,
122
- zoomScale: number,
123
- ...
124
- },
125
- ): {
126
- first: number,
127
- last: number,
128
- } {
129
- const itemCount = props.getItemCount(props.data);
130
- if (itemCount === 0) {
131
- return {first: 0, last: -1};
132
- }
133
- const {offset, velocity, visibleLength, zoomScale = 1} = scrollMetrics;
134
-
135
- // Start with visible area, then compute maximum overscan region by expanding from there, biased
136
- // in the direction of scroll. Total overscan area is capped, which should cap memory consumption
137
- // too.
138
- const visibleBegin = Math.max(0, offset);
139
- const visibleEnd = visibleBegin + visibleLength;
140
- const overscanLength = (windowSize - 1) * visibleLength;
141
-
142
- // Considering velocity seems to introduce more churn than it's worth.
143
- const leadFactor = 0.5; // Math.max(0, Math.min(1, velocity / 25 + 0.5));
144
-
145
- const fillPreference =
146
- velocity > 1 ? 'after' : velocity < -1 ? 'before' : 'none';
147
-
148
- const overscanBegin = Math.max(
149
- 0,
150
- visibleBegin - (1 - leadFactor) * overscanLength,
151
- );
152
- const overscanEnd = Math.max(0, visibleEnd + leadFactor * overscanLength);
153
-
154
- const lastItemOffset =
155
- getFrameMetricsApprox(itemCount - 1, props).offset * zoomScale;
156
- if (lastItemOffset < overscanBegin) {
157
- // Entire list is before our overscan window
158
- return {
159
- first: Math.max(0, itemCount - 1 - maxToRenderPerBatch),
160
- last: itemCount - 1,
161
- };
162
- }
163
-
164
- // Find the indices that correspond to the items at the render boundaries we're targeting.
165
- let [overscanFirst, first, last, overscanLast] = elementsThatOverlapOffsets(
166
- [overscanBegin, visibleBegin, visibleEnd, overscanEnd],
167
- props,
168
- getFrameMetricsApprox,
169
- zoomScale,
170
- );
171
- overscanFirst = overscanFirst == null ? 0 : overscanFirst;
172
- first = first == null ? Math.max(0, overscanFirst) : first;
173
- overscanLast = overscanLast == null ? itemCount - 1 : overscanLast;
174
- last =
175
- last == null
176
- ? Math.min(overscanLast, first + maxToRenderPerBatch - 1)
177
- : last;
178
- const visible = {first, last};
179
-
180
- // We want to limit the number of new cells we're rendering per batch so that we can fill the
181
- // content on the screen quickly. If we rendered the entire overscan window at once, the user
182
- // could be staring at white space for a long time waiting for a bunch of offscreen content to
183
- // render.
184
- let newCellCount = newRangeCount(prev, visible);
185
-
186
- while (true) {
187
- if (first <= overscanFirst && last >= overscanLast) {
188
- // If we fill the entire overscan range, we're done.
189
- break;
190
- }
191
- const maxNewCells = newCellCount >= maxToRenderPerBatch;
192
- const firstWillAddMore = first <= prev.first || first > prev.last;
193
- const firstShouldIncrement =
194
- first > overscanFirst && (!maxNewCells || !firstWillAddMore);
195
- const lastWillAddMore = last >= prev.last || last < prev.first;
196
- const lastShouldIncrement =
197
- last < overscanLast && (!maxNewCells || !lastWillAddMore);
198
- if (maxNewCells && !firstShouldIncrement && !lastShouldIncrement) {
199
- // We only want to stop if we've hit maxNewCells AND we cannot increment first or last
200
- // without rendering new items. This let's us preserve as many already rendered items as
201
- // possible, reducing render churn and keeping the rendered overscan range as large as
202
- // possible.
203
- break;
204
- }
205
- if (
206
- firstShouldIncrement &&
207
- !(fillPreference === 'after' && lastShouldIncrement && lastWillAddMore)
208
- ) {
209
- if (firstWillAddMore) {
210
- newCellCount++;
211
- }
212
- first--;
213
- }
214
- if (
215
- lastShouldIncrement &&
216
- !(fillPreference === 'before' && firstShouldIncrement && firstWillAddMore)
217
- ) {
218
- if (lastWillAddMore) {
219
- newCellCount++;
220
- }
221
- last++;
222
- }
223
- }
224
- if (
225
- !(
226
- last >= first &&
227
- first >= 0 &&
228
- last < itemCount &&
229
- first >= overscanFirst &&
230
- last <= overscanLast &&
231
- first <= visible.first &&
232
- last >= visible.last
233
- )
234
- ) {
235
- throw new Error(
236
- 'Bad window calculation ' +
237
- JSON.stringify({
238
- first,
239
- last,
240
- itemCount,
241
- overscanFirst,
242
- overscanLast,
243
- visible,
244
- }),
245
- );
246
- }
247
- return {first, last};
248
- }
15
+ const keyExtractor: KeyExtractorType =
16
+ require('@react-native/virtualized-lists').keyExtractor;
249
17
 
250
- export function keyExtractor(item: any, index: number): string {
251
- if (typeof item === 'object' && item?.key != null) {
252
- return item.key;
253
- }
254
- if (typeof item === 'object' && item?.id != null) {
255
- return item.id;
256
- }
257
- return String(index);
258
- }
18
+ module.exports = {keyExtractor};