@office-iss/react-native-win32 0.71.4 → 0.72.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 (323) hide show
  1. package/.flowconfig +15 -3
  2. package/CHANGELOG.json +310 -40
  3. package/CHANGELOG.md +145 -23
  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/TouchableWithoutFeedback.d.ts +1 -1
  72. package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +2 -2
  73. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +189 -0
  74. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +43 -0
  75. package/Libraries/Components/View/ReactNativeStyleAttributes.js +26 -0
  76. package/Libraries/Components/View/View.js +71 -45
  77. package/Libraries/Components/View/View.win32.js +38 -16
  78. package/Libraries/Components/View/ViewAccessibility.d.ts +6 -6
  79. package/Libraries/Components/View/ViewAccessibility.js +10 -1
  80. package/Libraries/Components/View/ViewAccessibility.win32.d.ts +5 -5
  81. package/Libraries/Components/View/ViewNativeComponent.js +32 -8
  82. package/Libraries/Components/View/ViewPropTypes.d.ts +1 -1
  83. package/Libraries/Components/View/ViewPropTypes.js +1 -1
  84. package/Libraries/Components/View/ViewPropTypes.win32.d.ts +1 -1
  85. package/Libraries/Components/View/ViewPropTypes.win32.js +1 -1
  86. package/Libraries/Core/Devtools/openFileInEditor.js +1 -0
  87. package/Libraries/Core/Devtools/openURLInBrowser.js +1 -0
  88. package/Libraries/Core/Devtools/parseErrorStack.js +2 -2
  89. package/Libraries/Core/Devtools/parseHermesStack.js +54 -34
  90. package/Libraries/Core/ExceptionsManager.js +2 -2
  91. package/Libraries/Core/InitializeCore.js +2 -1
  92. package/Libraries/Core/ReactNativeVersion.js +3 -3
  93. package/Libraries/Core/ReactNativeVersionCheck.js +1 -9
  94. package/Libraries/Core/ReactNativeVersionCheck.win32.js +1 -9
  95. package/Libraries/Core/Timers/JSTimers.js +1 -1
  96. package/Libraries/Core/Timers/immediateShim.js +1 -0
  97. package/Libraries/Core/Timers/queueMicrotask.js +1 -1
  98. package/Libraries/Core/setUpAlert.js +1 -1
  99. package/Libraries/Core/setUpDOM.js +18 -0
  100. package/Libraries/Core/setUpDeveloperTools.js +1 -1
  101. package/Libraries/Core/setUpGlobals.js +5 -2
  102. package/Libraries/Core/setUpNavigator.js +6 -5
  103. package/Libraries/Core/setUpPerformance.js +23 -13
  104. package/Libraries/Core/setUpReactDevTools.js +2 -0
  105. package/Libraries/Core/setUpSegmentFetcher.js +0 -41
  106. package/Libraries/Core/setUpTimers.js +2 -2
  107. package/Libraries/DOM/Geometry/DOMRect.js +82 -0
  108. package/Libraries/DOM/Geometry/DOMRectReadOnly.js +188 -0
  109. package/Libraries/DOM/Nodes/ReactNativeElement.js +75 -0
  110. package/Libraries/DOM/Nodes/ReadOnlyElement.js +89 -0
  111. package/Libraries/DOM/Nodes/ReadOnlyNode.js +167 -0
  112. package/Libraries/DOM/OldStyleCollections/ArrayLikeUtils.js +46 -0
  113. package/Libraries/DOM/OldStyleCollections/DOMRectList.js +76 -0
  114. package/Libraries/DOM/OldStyleCollections/HTMLCollection.js +82 -0
  115. package/Libraries/DOM/OldStyleCollections/NodeList.js +104 -0
  116. package/Libraries/DevToolsSettings/DevToolsSettingsManager.android.js +35 -0
  117. package/Libraries/DevToolsSettings/DevToolsSettingsManager.d.ts +20 -0
  118. package/Libraries/DevToolsSettings/DevToolsSettingsManager.ios.js +49 -0
  119. package/Libraries/DevToolsSettings/DevToolsSettingsManager.win32.js +35 -0
  120. package/Libraries/{Utilities/NativeDevSplitBundleLoader.js → DevToolsSettings/NativeDevToolsSettingsManager.js} +7 -2
  121. package/Libraries/EventEmitter/NativeEventEmitter.d.ts +1 -2
  122. package/Libraries/EventEmitter/RCTDeviceEventEmitter.d.ts +1 -2
  123. package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +9 -1
  124. package/Libraries/Events/EventPolyfill.js +1 -1
  125. package/Libraries/Image/AssetRegistry.js +1 -1
  126. package/Libraries/Image/AssetSourceResolver.js +3 -3
  127. package/Libraries/Image/Image.android.js +4 -1
  128. package/Libraries/Image/Image.d.ts +63 -2
  129. package/Libraries/Image/Image.ios.js +3 -0
  130. package/Libraries/Image/Image.win32.js +3 -0
  131. package/Libraries/Image/ImageBackground.js +1 -0
  132. package/Libraries/Image/ImageProps.js +1 -1
  133. package/Libraries/Image/ImageViewNativeComponent.js +4 -4
  134. package/Libraries/Image/RelativeImageStub.js +1 -1
  135. package/Libraries/Image/TextInlineImageNativeComponent.js +1 -1
  136. package/Libraries/Image/resolveAssetSource.js +1 -1
  137. package/Libraries/Inspector/DevtoolsOverlay.js +29 -19
  138. package/Libraries/Inspector/ElementBox.js +4 -1
  139. package/Libraries/Inspector/Inspector.js +5 -6
  140. package/Libraries/Inspector/Inspector.win32.js +7 -6
  141. package/Libraries/Inspector/InspectorOverlay.js +3 -3
  142. package/Libraries/Inspector/InspectorOverlay.win32.js +2 -1
  143. package/Libraries/Inspector/NetworkOverlay.js +1 -1
  144. package/Libraries/Interaction/JSEventLoopWatchdog.js +1 -1
  145. package/Libraries/Interaction/PanResponder.js +5 -6
  146. package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -1
  147. package/Libraries/Linking/Linking.js +1 -4
  148. package/Libraries/Lists/FillRateHelper.js +4 -238
  149. package/Libraries/Lists/FlatList.d.ts +15 -22
  150. package/Libraries/Lists/FlatList.js +9 -6
  151. package/Libraries/Lists/SectionList.d.ts +10 -6
  152. package/Libraries/Lists/SectionList.js +5 -3
  153. package/Libraries/Lists/SectionListModern.js +3 -3
  154. package/Libraries/Lists/ViewabilityHelper.js +8 -344
  155. package/Libraries/Lists/VirtualizeUtils.js +4 -244
  156. package/Libraries/Lists/VirtualizedList.js +10 -1867
  157. package/Libraries/Lists/VirtualizedListContext.js +6 -104
  158. package/Libraries/Lists/VirtualizedSectionList.js +9 -602
  159. package/Libraries/Lists/__flowtests__/FlatList-flowtest.js +1 -0
  160. package/Libraries/Lists/__flowtests__/SectionList-flowtest.js +1 -1
  161. package/Libraries/LogBox/Data/LogBoxData.js +1 -1
  162. package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
  163. package/Libraries/LogBox/LogBox.js +1 -1
  164. package/Libraries/LogBox/UI/LogBoxInspector.js +1 -3
  165. package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.win32.js +168 -0
  166. package/Libraries/LogBox/UI/LogBoxInspectorHeader.win32.js +3 -0
  167. package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.win32.js +193 -0
  168. package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +1 -0
  169. package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.js +2 -2
  170. package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.win32.js +7 -3
  171. package/Libraries/LogBox/UI/LogBoxMessage.js +87 -5
  172. package/Libraries/LogBox/UI/LogBoxNotification.js +5 -7
  173. package/Libraries/Modal/Modal.js +2 -2
  174. package/Libraries/NativeComponent/BaseViewConfig.android.js +32 -12
  175. package/Libraries/NativeComponent/BaseViewConfig.ios.js +43 -19
  176. package/Libraries/NativeComponent/BaseViewConfig.win32.js +43 -19
  177. package/Libraries/NativeComponent/NativeComponentRegistryUnstable.js +4 -1
  178. package/Libraries/NativeComponent/ViewConfig.js +1 -0
  179. package/Libraries/NativeComponent/ViewConfigIgnore.js +1 -4
  180. package/Libraries/Network/RCTNetworking.android.js +2 -2
  181. package/Libraries/Network/RCTNetworking.ios.js +1 -1
  182. package/Libraries/Network/RCTNetworking.win32.js +1 -1
  183. package/Libraries/Network/XMLHttpRequest.js +1 -1
  184. package/Libraries/Pressability/Pressability.js +11 -5
  185. package/Libraries/Pressability/Pressability.win32.js +9 -3
  186. package/Libraries/ReactNative/AppContainer.js +7 -1
  187. package/Libraries/ReactNative/AppRegistry.d.ts +1 -1
  188. package/Libraries/ReactNative/AppRegistry.js +10 -13
  189. package/Libraries/ReactNative/FabricUIManager.js +24 -8
  190. package/Libraries/ReactNative/NativeUIManager.js +5 -5
  191. package/Libraries/ReactNative/ReactNativeFeatureFlags.js +10 -10
  192. package/Libraries/ReactNative/UIManager.js +142 -1
  193. package/Libraries/ReactNative/getCachedComponentWithDebugName.js +5 -5
  194. package/Libraries/ReactNative/getNativeComponentAttributes.js +1 -1
  195. package/Libraries/ReactNative/requireNativeComponent.d.ts +1 -1
  196. package/Libraries/ReactNative/requireNativeComponent.js +1 -1
  197. package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +1 -0
  198. package/Libraries/Renderer/implementations/ReactFabric-dev.js +26 -3
  199. package/Libraries/Renderer/implementations/ReactFabric-prod.js +13 -1
  200. package/Libraries/Renderer/implementations/ReactFabric-profiling.js +13 -1
  201. package/Libraries/Renderer/public/ReactFabricPublicInstanceUtils.js +38 -0
  202. package/Libraries/Renderer/shims/ReactNativeTypes.js +38 -20
  203. package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -7
  204. package/Libraries/Renderer/shims/createReactNativeComponentClass.js +2 -2
  205. package/Libraries/Share/Share.js +1 -1
  206. package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +1 -1
  207. package/Libraries/StyleSheet/StyleSheet.js +1 -1
  208. package/Libraries/StyleSheet/StyleSheet.win32.js +1 -1
  209. package/Libraries/StyleSheet/StyleSheetTypes.d.ts +115 -76
  210. package/Libraries/StyleSheet/StyleSheetTypes.js +188 -33
  211. package/Libraries/StyleSheet/flattenStyle.js +2 -0
  212. package/Libraries/StyleSheet/normalizeColor.js +1 -1
  213. package/Libraries/StyleSheet/processColor.js +1 -1
  214. package/Libraries/Text/Text.d.ts +12 -2
  215. package/Libraries/Text/Text.js +50 -41
  216. package/Libraries/Text/TextProps.js +3 -4
  217. package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +6 -0
  218. package/Libraries/Types/CodegenTypes.js +1 -0
  219. package/Libraries/UTFSequence.js +3 -1
  220. package/Libraries/Utilities/Appearance.d.ts +10 -0
  221. package/Libraries/Utilities/Appearance.js +13 -0
  222. package/Libraries/Utilities/Dimensions.js +1 -1
  223. package/Libraries/Utilities/Dimensions.win32.js +1 -1
  224. package/Libraries/Utilities/GlobalPerformanceLogger.js +12 -1
  225. package/Libraries/Utilities/HMRClient.js +16 -10
  226. package/Libraries/Utilities/{createPerformanceLogger.d.ts → IPerformanceLogger.d.ts} +4 -4
  227. package/Libraries/Utilities/IPerformanceLogger.js +49 -0
  228. package/Libraries/Utilities/LoadingView.android.js +28 -11
  229. package/Libraries/Utilities/NativeAppearance.js +1 -0
  230. package/Libraries/Utilities/NativePlatformConstantsWin.js +1 -1
  231. package/Libraries/Utilities/PixelRatio.js +2 -2
  232. package/Libraries/Utilities/Platform.win32.js +1 -1
  233. package/Libraries/Utilities/ReactNativeTestTools.js +1 -1
  234. package/Libraries/Utilities/__mocks__/PixelRatio.js +1 -1
  235. package/Libraries/Utilities/codegenNativeCommands.js +2 -0
  236. package/Libraries/Utilities/createPerformanceLogger.js +55 -43
  237. package/Libraries/Utilities/stringifySafe.js +2 -7
  238. package/Libraries/Utilities/useColorScheme.js +1 -1
  239. package/Libraries/Utilities/useWindowDimensions.js +3 -3
  240. package/Libraries/WebPerformance/EventCounts.js +78 -0
  241. package/Libraries/WebPerformance/MemoryInfo.js +54 -0
  242. package/Libraries/WebPerformance/NativePerformance.js +38 -0
  243. package/Libraries/WebPerformance/NativePerformanceObserver.js +22 -7
  244. package/Libraries/WebPerformance/Performance.js +312 -0
  245. package/Libraries/WebPerformance/PerformanceEntry.js +45 -0
  246. package/Libraries/WebPerformance/PerformanceEventTiming.js +38 -0
  247. package/Libraries/WebPerformance/PerformanceObserver.js +196 -101
  248. package/Libraries/WebPerformance/RawPerformanceEntry.js +87 -0
  249. package/Libraries/WebPerformance/ReactNativeStartupTiming.js +65 -0
  250. package/Libraries/WebPerformance/__mocks__/NativePerformance.js +65 -0
  251. package/Libraries/WebPerformance/__mocks__/NativePerformanceObserver.js +101 -0
  252. package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
  253. package/Libraries/vendor/core/ErrorUtils.js +1 -1
  254. package/Libraries/vendor/emitter/EventEmitter.d.ts +2 -2
  255. package/Libraries/vendor/emitter/EventEmitter.js +9 -1
  256. package/flow/global.js +29 -4
  257. package/flow/jest.js +258 -164
  258. package/index.js +56 -42
  259. package/index.win32.js +56 -42
  260. package/interface.js +1 -1
  261. package/jest/local-setup.js +33 -0
  262. package/jest/mockComponent.js +4 -2
  263. package/jest/mockNativeComponent.js +1 -1
  264. package/jest/mockScrollView.js +2 -1
  265. package/jest/react-native-env.js +1 -3
  266. package/jest/setup.js +11 -8
  267. package/overrides.json +115 -85
  268. package/package.json +38 -28
  269. package/rn-get-polyfills.js +1 -1
  270. package/src/Libraries/Components/TextInput/TextInput.Types.win32.ts +68 -0
  271. package/src/Libraries/Components/View/ViewAccessibility.win32.d.ts +5 -5
  272. package/src/Libraries/Components/View/ViewPropTypes.win32.d.ts +1 -1
  273. package/types/index.d.ts +2 -6
  274. package/types/modules/Codegen.d.ts +4 -4
  275. package/types/modules/globals.d.ts +27 -25
  276. package/types/public/DeprecatedPropertiesAlias.d.ts +0 -20
  277. package/types/public/ReactNativeRenderer.d.ts +2 -7
  278. package/Libraries/Animated/createAnimatedComponentInjection.js +0 -48
  279. package/Libraries/Animated/createAnimatedComponent_EXPERIMENTAL.js +0 -48
  280. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.flow.js +0 -208
  281. package/Libraries/Components/ActivityIndicator/ActivityIndicator.flow.js +0 -58
  282. package/Libraries/Components/DatePicker/DatePickerIOS.android.js +0 -47
  283. package/Libraries/Components/DatePicker/DatePickerIOS.d.ts +0 -92
  284. package/Libraries/Components/DatePicker/DatePickerIOS.flow.android.js +0 -14
  285. package/Libraries/Components/DatePicker/DatePickerIOS.flow.ios.js +0 -113
  286. package/Libraries/Components/DatePicker/DatePickerIOS.ios.js +0 -242
  287. package/Libraries/Components/DatePicker/DatePickerIOS.win32.js +0 -47
  288. package/Libraries/Components/DatePicker/RCTDatePickerNativeComponent.js +0 -60
  289. package/Libraries/Components/DatePickerAndroid/NativeDatePickerAndroid.js +0 -26
  290. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.android.js +0 -45
  291. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.d.ts +0 -62
  292. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.ios.js +0 -75
  293. package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.win32.js +0 -45
  294. package/Libraries/Components/ProgressViewIOS/RCTProgressViewNativeComponent.js +0 -33
  295. package/Libraries/Components/SafeAreaView/SafeAreaView.flow.js +0 -19
  296. package/Libraries/Components/Slider/Slider.d.ts +0 -132
  297. package/Libraries/Components/Slider/Slider.js +0 -282
  298. package/Libraries/Components/Slider/SliderNativeComponent.js +0 -56
  299. package/Libraries/Components/TextInput/Win32TextInputNativeComponent.js +0 -23
  300. package/Libraries/Interaction/Batchinator.js +0 -76
  301. package/Libraries/Interaction/BridgeSpyStallHandler.js +0 -63
  302. package/Libraries/Interaction/InteractionStallDebugger.js +0 -23
  303. package/Libraries/Interaction/PanResponder.flow.js +0 -257
  304. package/Libraries/Lists/CellRenderMask.js +0 -155
  305. package/Libraries/Lists/ChildListCollection.js +0 -72
  306. package/Libraries/Lists/StateSafePureComponent.js +0 -85
  307. package/Libraries/Lists/VirtualizedList.d.ts +0 -347
  308. package/Libraries/Lists/VirtualizedListCellRenderer.js +0 -259
  309. package/Libraries/Lists/VirtualizedListProps.js +0 -279
  310. package/Libraries/Performance/PureComponentDebug.js +0 -74
  311. package/Libraries/Reliability/UserFlow.js +0 -158
  312. package/Libraries/Renderer/implementations/ReactNativeRenderer.d.ts +0 -149
  313. package/Libraries/Renderer/shims/ReactNativeTypes.d.ts +0 -141
  314. package/Libraries/Utilities/MatrixMath.js +0 -748
  315. package/Libraries/Utilities/buildStyleInterpolator.js +0 -209
  316. package/Libraries/Utilities/clamp.js +0 -23
  317. package/Libraries/Utilities/deprecatedPropType.js +0 -36
  318. package/Libraries/Utilities/groupByEveryN.js +0 -51
  319. package/Libraries/Utilities/mergeIntoFast.js +0 -26
  320. package/Libraries/Utilities/setAndForwardRef.js +0 -71
  321. package/Libraries/Utilities/truncate.js +0 -51
  322. package/flow/JSITimerInternalType.js +0 -30
  323. package/flow/use-sync-external-store.js +0 -19
@@ -8,608 +8,15 @@
8
8
  * @format
9
9
  */
10
10
 
11
- import type {ViewToken} from './ViewabilityHelper';
11
+ 'use strict';
12
12
 
13
- import View from '../Components/View/View';
14
- import VirtualizedList from './VirtualizedList';
15
- import {keyExtractor as defaultKeyExtractor} from './VirtualizeUtils';
16
- import invariant from 'invariant';
17
- import * as React from 'react';
13
+ import {typeof VirtualizedSectionList as VirtualizedSectionListType} from '@react-native/virtualized-lists';
18
14
 
19
- type Item = any;
15
+ const VirtualizedSectionList: VirtualizedSectionListType =
16
+ require('@react-native/virtualized-lists').VirtualizedSectionList;
20
17
 
21
- export type SectionBase<SectionItemT> = {
22
- /**
23
- * The data for rendering items in this section.
24
- */
25
- data: $ReadOnlyArray<SectionItemT>,
26
- /**
27
- * Optional key to keep track of section re-ordering. If you don't plan on re-ordering sections,
28
- * the array index will be used by default.
29
- */
30
- key?: string,
31
- // Optional props will override list-wide props just for this section.
32
- renderItem?: ?(info: {
33
- item: SectionItemT,
34
- index: number,
35
- section: SectionBase<SectionItemT>,
36
- separators: {
37
- highlight: () => void,
38
- unhighlight: () => void,
39
- updateProps: (select: 'leading' | 'trailing', newProps: Object) => void,
40
- ...
41
- },
42
- ...
43
- }) => null | React.Element<any>,
44
- ItemSeparatorComponent?: ?React.ComponentType<any>,
45
- keyExtractor?: (item: SectionItemT, index?: ?number) => string,
46
- ...
47
- };
48
-
49
- type RequiredProps<SectionT: SectionBase<any>> = {|
50
- sections: $ReadOnlyArray<SectionT>,
51
- |};
52
-
53
- type OptionalProps<SectionT: SectionBase<any>> = {|
54
- /**
55
- * Default renderer for every item in every section.
56
- */
57
- renderItem?: (info: {
58
- item: Item,
59
- index: number,
60
- section: SectionT,
61
- separators: {
62
- highlight: () => void,
63
- unhighlight: () => void,
64
- updateProps: (select: 'leading' | 'trailing', newProps: Object) => void,
65
- ...
66
- },
67
- ...
68
- }) => null | React.Element<any>,
69
- /**
70
- * Rendered at the top of each section. These stick to the top of the `ScrollView` by default on
71
- * iOS. See `stickySectionHeadersEnabled`.
72
- */
73
- renderSectionHeader?: ?(info: {
74
- section: SectionT,
75
- ...
76
- }) => null | React.Element<any>,
77
- /**
78
- * Rendered at the bottom of each section.
79
- */
80
- renderSectionFooter?: ?(info: {
81
- section: SectionT,
82
- ...
83
- }) => null | React.Element<any>,
84
- /**
85
- * Rendered at the top and bottom of each section (note this is different from
86
- * `ItemSeparatorComponent` which is only rendered between items). These are intended to separate
87
- * sections from the headers above and below and typically have the same highlight response as
88
- * `ItemSeparatorComponent`. Also receives `highlighted`, `[leading/trailing][Item/Separator]`,
89
- * and any custom props from `separators.updateProps`.
90
- */
91
- SectionSeparatorComponent?: ?React.ComponentType<any>,
92
- /**
93
- * Makes section headers stick to the top of the screen until the next one pushes it off. Only
94
- * enabled by default on iOS because that is the platform standard there.
95
- */
96
- stickySectionHeadersEnabled?: boolean,
97
- onEndReached?: ?({distanceFromEnd: number, ...}) => void,
98
- |};
99
-
100
- type VirtualizedListProps = React.ElementConfig<typeof VirtualizedList>;
101
-
102
- export type Props<SectionT> = {|
103
- ...RequiredProps<SectionT>,
104
- ...OptionalProps<SectionT>,
105
- ...$Diff<
106
- VirtualizedListProps,
107
- {
108
- renderItem: $PropertyType<VirtualizedListProps, 'renderItem'>,
109
- data: $PropertyType<VirtualizedListProps, 'data'>,
110
- ...
111
- },
112
- >,
113
- |};
114
- export type ScrollToLocationParamsType = {|
115
- animated?: ?boolean,
116
- itemIndex: number,
117
- sectionIndex: number,
118
- viewOffset?: number,
119
- viewPosition?: number,
120
- |};
121
-
122
- type State = {childProps: VirtualizedListProps, ...};
123
-
124
- /**
125
- * Right now this just flattens everything into one list and uses VirtualizedList under the
126
- * hood. The only operation that might not scale well is concatting the data arrays of all the
127
- * sections when new props are received, which should be plenty fast for up to ~10,000 items.
128
- */
129
- class VirtualizedSectionList<
130
- SectionT: SectionBase<any>,
131
- > extends React.PureComponent<Props<SectionT>, State> {
132
- scrollToLocation(params: ScrollToLocationParamsType) {
133
- let index = params.itemIndex;
134
- for (let i = 0; i < params.sectionIndex; i++) {
135
- index += this.props.getItemCount(this.props.sections[i].data) + 2;
136
- }
137
- let viewOffset = params.viewOffset || 0;
138
- if (this._listRef == null) {
139
- return;
140
- }
141
- if (params.itemIndex > 0 && this.props.stickySectionHeadersEnabled) {
142
- const frame = this._listRef.__getFrameMetricsApprox(
143
- index - params.itemIndex,
144
- this._listRef.props,
145
- );
146
- viewOffset += frame.length;
147
- }
148
- const toIndexParams = {
149
- ...params,
150
- viewOffset,
151
- index,
152
- };
153
- // $FlowFixMe[incompatible-use]
154
- this._listRef.scrollToIndex(toIndexParams);
155
- }
156
-
157
- getListRef(): ?React.ElementRef<typeof VirtualizedList> {
158
- return this._listRef;
159
- }
160
-
161
- render(): React.Node {
162
- const {
163
- ItemSeparatorComponent, // don't pass through, rendered with renderItem
164
- SectionSeparatorComponent,
165
- renderItem: _renderItem,
166
- renderSectionFooter,
167
- renderSectionHeader,
168
- sections: _sections,
169
- stickySectionHeadersEnabled,
170
- ...passThroughProps
171
- } = this.props;
172
-
173
- const listHeaderOffset = this.props.ListHeaderComponent ? 1 : 0;
174
-
175
- const stickyHeaderIndices = this.props.stickySectionHeadersEnabled
176
- ? ([]: Array<number>)
177
- : undefined;
178
-
179
- let itemCount = 0;
180
- for (const section of this.props.sections) {
181
- // Track the section header indices
182
- if (stickyHeaderIndices != null) {
183
- stickyHeaderIndices.push(itemCount + listHeaderOffset);
184
- }
185
-
186
- // Add two for the section header and footer.
187
- itemCount += 2;
188
- itemCount += this.props.getItemCount(section.data);
189
- }
190
- const renderItem = this._renderItem(itemCount);
191
-
192
- return (
193
- <VirtualizedList
194
- {...passThroughProps}
195
- keyExtractor={this._keyExtractor}
196
- stickyHeaderIndices={stickyHeaderIndices}
197
- renderItem={renderItem}
198
- data={this.props.sections}
199
- getItem={(sections, index) =>
200
- this._getItem(this.props, sections, index)
201
- }
202
- getItemCount={() => itemCount}
203
- onViewableItemsChanged={
204
- this.props.onViewableItemsChanged
205
- ? this._onViewableItemsChanged
206
- : undefined
207
- }
208
- ref={this._captureRef}
209
- />
210
- );
211
- }
212
-
213
- _getItem(
214
- props: Props<SectionT>,
215
- sections: ?$ReadOnlyArray<Item>,
216
- index: number,
217
- ): ?Item {
218
- if (!sections) {
219
- return null;
220
- }
221
- let itemIdx = index - 1;
222
- for (let i = 0; i < sections.length; i++) {
223
- const section = sections[i];
224
- const sectionData = section.data;
225
- const itemCount = props.getItemCount(sectionData);
226
- if (itemIdx === -1 || itemIdx === itemCount) {
227
- // We intend for there to be overflow by one on both ends of the list.
228
- // This will be for headers and footers. When returning a header or footer
229
- // item the section itself is the item.
230
- return section;
231
- } else if (itemIdx < itemCount) {
232
- // If we are in the bounds of the list's data then return the item.
233
- return props.getItem(sectionData, itemIdx);
234
- } else {
235
- itemIdx -= itemCount + 2; // Add two for the header and footer
236
- }
237
- }
238
- return null;
239
- }
240
-
241
- // $FlowFixMe[missing-local-annot]
242
- _keyExtractor = (item: Item, index: number) => {
243
- const info = this._subExtractor(index);
244
- return (info && info.key) || String(index);
245
- };
246
-
247
- _subExtractor(index: number): ?{
248
- section: SectionT,
249
- // Key of the section or combined key for section + item
250
- key: string,
251
- // Relative index within the section
252
- index: ?number,
253
- // True if this is the section header
254
- header?: ?boolean,
255
- leadingItem?: ?Item,
256
- leadingSection?: ?SectionT,
257
- trailingItem?: ?Item,
258
- trailingSection?: ?SectionT,
259
- ...
260
- } {
261
- let itemIndex = index;
262
- const {getItem, getItemCount, keyExtractor, sections} = this.props;
263
- for (let i = 0; i < sections.length; i++) {
264
- const section = sections[i];
265
- const sectionData = section.data;
266
- const key = section.key || String(i);
267
- itemIndex -= 1; // The section adds an item for the header
268
- if (itemIndex >= getItemCount(sectionData) + 1) {
269
- itemIndex -= getItemCount(sectionData) + 1; // The section adds an item for the footer.
270
- } else if (itemIndex === -1) {
271
- return {
272
- section,
273
- key: key + ':header',
274
- index: null,
275
- header: true,
276
- trailingSection: sections[i + 1],
277
- };
278
- } else if (itemIndex === getItemCount(sectionData)) {
279
- return {
280
- section,
281
- key: key + ':footer',
282
- index: null,
283
- header: false,
284
- trailingSection: sections[i + 1],
285
- };
286
- } else {
287
- const extractor =
288
- section.keyExtractor || keyExtractor || defaultKeyExtractor;
289
- return {
290
- section,
291
- key:
292
- key + ':' + extractor(getItem(sectionData, itemIndex), itemIndex),
293
- index: itemIndex,
294
- leadingItem: getItem(sectionData, itemIndex - 1),
295
- leadingSection: sections[i - 1],
296
- trailingItem: getItem(sectionData, itemIndex + 1),
297
- trailingSection: sections[i + 1],
298
- };
299
- }
300
- }
301
- }
302
-
303
- _convertViewable = (viewable: ViewToken): ?ViewToken => {
304
- invariant(viewable.index != null, 'Received a broken ViewToken');
305
- const info = this._subExtractor(viewable.index);
306
- if (!info) {
307
- return null;
308
- }
309
- const keyExtractorWithNullableIndex = info.section.keyExtractor;
310
- const keyExtractorWithNonNullableIndex =
311
- this.props.keyExtractor || defaultKeyExtractor;
312
- const key =
313
- keyExtractorWithNullableIndex != null
314
- ? keyExtractorWithNullableIndex(viewable.item, info.index)
315
- : keyExtractorWithNonNullableIndex(viewable.item, info.index ?? 0);
316
-
317
- return {
318
- ...viewable,
319
- index: info.index,
320
- key,
321
- section: info.section,
322
- };
323
- };
324
-
325
- _onViewableItemsChanged = ({
326
- viewableItems,
327
- changed,
328
- }: {
329
- viewableItems: Array<ViewToken>,
330
- changed: Array<ViewToken>,
331
- ...
332
- }) => {
333
- const onViewableItemsChanged = this.props.onViewableItemsChanged;
334
- if (onViewableItemsChanged != null) {
335
- onViewableItemsChanged({
336
- viewableItems: viewableItems
337
- .map(this._convertViewable, this)
338
- .filter(Boolean),
339
- changed: changed.map(this._convertViewable, this).filter(Boolean),
340
- });
341
- }
342
- };
343
-
344
- _renderItem =
345
- (listItemCount: number): $FlowFixMe =>
346
- // eslint-disable-next-line react/no-unstable-nested-components
347
- ({item, index}: {item: Item, index: number, ...}) => {
348
- const info = this._subExtractor(index);
349
- if (!info) {
350
- return null;
351
- }
352
- const infoIndex = info.index;
353
- if (infoIndex == null) {
354
- const {section} = info;
355
- if (info.header === true) {
356
- const {renderSectionHeader} = this.props;
357
- return renderSectionHeader ? renderSectionHeader({section}) : null;
358
- } else {
359
- const {renderSectionFooter} = this.props;
360
- return renderSectionFooter ? renderSectionFooter({section}) : null;
361
- }
362
- } else {
363
- const renderItem = info.section.renderItem || this.props.renderItem;
364
- const SeparatorComponent = this._getSeparatorComponent(
365
- index,
366
- info,
367
- listItemCount,
368
- );
369
- invariant(renderItem, 'no renderItem!');
370
- return (
371
- <ItemWithSeparator
372
- SeparatorComponent={SeparatorComponent}
373
- LeadingSeparatorComponent={
374
- infoIndex === 0 ? this.props.SectionSeparatorComponent : undefined
375
- }
376
- cellKey={info.key}
377
- index={infoIndex}
378
- item={item}
379
- leadingItem={info.leadingItem}
380
- leadingSection={info.leadingSection}
381
- prevCellKey={(this._subExtractor(index - 1) || {}).key}
382
- // Callback to provide updateHighlight for this item
383
- setSelfHighlightCallback={this._setUpdateHighlightFor}
384
- setSelfUpdatePropsCallback={this._setUpdatePropsFor}
385
- // Provide child ability to set highlight/updateProps for previous item using prevCellKey
386
- updateHighlightFor={this._updateHighlightFor}
387
- updatePropsFor={this._updatePropsFor}
388
- renderItem={renderItem}
389
- section={info.section}
390
- trailingItem={info.trailingItem}
391
- trailingSection={info.trailingSection}
392
- inverted={!!this.props.inverted}
393
- />
394
- );
395
- }
396
- };
397
-
398
- _updatePropsFor = (cellKey: string, value: any) => {
399
- const updateProps = this._updatePropsMap[cellKey];
400
- if (updateProps != null) {
401
- updateProps(value);
402
- }
403
- };
404
-
405
- _updateHighlightFor = (cellKey: string, value: boolean) => {
406
- const updateHighlight = this._updateHighlightMap[cellKey];
407
- if (updateHighlight != null) {
408
- updateHighlight(value);
409
- }
410
- };
411
-
412
- _setUpdateHighlightFor = (
413
- cellKey: string,
414
- updateHighlightFn: ?(boolean) => void,
415
- ) => {
416
- if (updateHighlightFn != null) {
417
- this._updateHighlightMap[cellKey] = updateHighlightFn;
418
- } else {
419
- delete this._updateHighlightFor[cellKey];
420
- }
421
- };
422
-
423
- _setUpdatePropsFor = (cellKey: string, updatePropsFn: ?(boolean) => void) => {
424
- if (updatePropsFn != null) {
425
- this._updatePropsMap[cellKey] = updatePropsFn;
426
- } else {
427
- delete this._updatePropsMap[cellKey];
428
- }
429
- };
430
-
431
- _getSeparatorComponent(
432
- index: number,
433
- info?: ?Object,
434
- listItemCount: number,
435
- ): ?React.ComponentType<any> {
436
- info = info || this._subExtractor(index);
437
- if (!info) {
438
- return null;
439
- }
440
- const ItemSeparatorComponent =
441
- info.section.ItemSeparatorComponent || this.props.ItemSeparatorComponent;
442
- const {SectionSeparatorComponent} = this.props;
443
- const isLastItemInList = index === listItemCount - 1;
444
- const isLastItemInSection =
445
- info.index === this.props.getItemCount(info.section.data) - 1;
446
- if (SectionSeparatorComponent && isLastItemInSection) {
447
- return SectionSeparatorComponent;
448
- }
449
- if (ItemSeparatorComponent && !isLastItemInSection && !isLastItemInList) {
450
- return ItemSeparatorComponent;
451
- }
452
- return null;
453
- }
454
-
455
- _updateHighlightMap: {[string]: (boolean) => void} = {};
456
- _updatePropsMap: {[string]: void | (boolean => void)} = {};
457
- _listRef: ?React.ElementRef<typeof VirtualizedList>;
458
- _captureRef = (ref: null | React$ElementRef<Class<VirtualizedList>>) => {
459
- this._listRef = ref;
460
- };
461
- }
462
-
463
- type ItemWithSeparatorCommonProps = $ReadOnly<{|
464
- leadingItem: ?Item,
465
- leadingSection: ?Object,
466
- section: Object,
467
- trailingItem: ?Item,
468
- trailingSection: ?Object,
469
- |}>;
470
-
471
- type ItemWithSeparatorProps = $ReadOnly<{|
472
- ...ItemWithSeparatorCommonProps,
473
- LeadingSeparatorComponent: ?React.ComponentType<any>,
474
- SeparatorComponent: ?React.ComponentType<any>,
475
- cellKey: string,
476
- index: number,
477
- item: Item,
478
- setSelfHighlightCallback: (
479
- cellKey: string,
480
- updateFn: ?(boolean) => void,
481
- ) => void,
482
- setSelfUpdatePropsCallback: (
483
- cellKey: string,
484
- updateFn: ?(boolean) => void,
485
- ) => void,
486
- prevCellKey?: ?string,
487
- updateHighlightFor: (prevCellKey: string, value: boolean) => void,
488
- updatePropsFor: (prevCellKey: string, value: Object) => void,
489
- renderItem: Function,
490
- inverted: boolean,
491
- |}>;
492
-
493
- function ItemWithSeparator(props: ItemWithSeparatorProps): React.Node {
494
- const {
495
- LeadingSeparatorComponent,
496
- // this is the trailing separator and is associated with this item
497
- SeparatorComponent,
498
- cellKey,
499
- prevCellKey,
500
- setSelfHighlightCallback,
501
- updateHighlightFor,
502
- setSelfUpdatePropsCallback,
503
- updatePropsFor,
504
- item,
505
- index,
506
- section,
507
- inverted,
508
- } = props;
509
-
510
- const [leadingSeparatorHiglighted, setLeadingSeparatorHighlighted] =
511
- React.useState(false);
512
-
513
- const [separatorHighlighted, setSeparatorHighlighted] = React.useState(false);
514
-
515
- const [leadingSeparatorProps, setLeadingSeparatorProps] = React.useState({
516
- leadingItem: props.leadingItem,
517
- leadingSection: props.leadingSection,
518
- section: props.section,
519
- trailingItem: props.item,
520
- trailingSection: props.trailingSection,
521
- });
522
- const [separatorProps, setSeparatorProps] = React.useState({
523
- leadingItem: props.item,
524
- leadingSection: props.leadingSection,
525
- section: props.section,
526
- trailingItem: props.trailingItem,
527
- trailingSection: props.trailingSection,
528
- });
529
-
530
- React.useEffect(() => {
531
- setSelfHighlightCallback(cellKey, setSeparatorHighlighted);
532
- setSelfUpdatePropsCallback(cellKey, setSeparatorProps);
533
-
534
- return () => {
535
- setSelfUpdatePropsCallback(cellKey, null);
536
- setSelfHighlightCallback(cellKey, null);
537
- };
538
- }, [
539
- cellKey,
540
- setSelfHighlightCallback,
541
- setSeparatorProps,
542
- setSelfUpdatePropsCallback,
543
- ]);
544
-
545
- const separators = {
546
- highlight: () => {
547
- setLeadingSeparatorHighlighted(true);
548
- setSeparatorHighlighted(true);
549
- if (prevCellKey != null) {
550
- updateHighlightFor(prevCellKey, true);
551
- }
552
- },
553
- unhighlight: () => {
554
- setLeadingSeparatorHighlighted(false);
555
- setSeparatorHighlighted(false);
556
- if (prevCellKey != null) {
557
- updateHighlightFor(prevCellKey, false);
558
- }
559
- },
560
- updateProps: (
561
- select: 'leading' | 'trailing',
562
- newProps: $Shape<ItemWithSeparatorCommonProps>,
563
- ) => {
564
- if (select === 'leading') {
565
- if (LeadingSeparatorComponent != null) {
566
- setLeadingSeparatorProps({...leadingSeparatorProps, ...newProps});
567
- } else if (prevCellKey != null) {
568
- // update the previous item's separator
569
- updatePropsFor(prevCellKey, {...leadingSeparatorProps, ...newProps});
570
- }
571
- } else if (select === 'trailing' && SeparatorComponent != null) {
572
- setSeparatorProps({...separatorProps, ...newProps});
573
- }
574
- },
575
- };
576
- const element = props.renderItem({
577
- item,
578
- index,
579
- section,
580
- separators,
581
- });
582
- const leadingSeparator = LeadingSeparatorComponent != null && (
583
- <LeadingSeparatorComponent
584
- highlighted={leadingSeparatorHiglighted}
585
- {...leadingSeparatorProps}
586
- />
587
- );
588
- const separator = SeparatorComponent != null && (
589
- <SeparatorComponent
590
- highlighted={separatorHighlighted}
591
- {...separatorProps}
592
- />
593
- );
594
- return leadingSeparator || separator ? (
595
- <View>
596
- {inverted === false ? leadingSeparator : separator}
597
- {element}
598
- {inverted === false ? separator : leadingSeparator}
599
- </View>
600
- ) : (
601
- element
602
- );
603
- }
604
-
605
- /* $FlowFixMe[class-object-subtyping] added when improving typing for this
606
- * parameters */
607
- // $FlowFixMe[method-unbinding]
608
- module.exports = (VirtualizedSectionList: React.AbstractComponent<
609
- React.ElementConfig<typeof VirtualizedSectionList>,
610
- $ReadOnly<{
611
- getListRef: () => ?React.ElementRef<typeof VirtualizedList>,
612
- scrollToLocation: (params: ScrollToLocationParamsType) => void,
613
- ...
614
- }>,
615
- >);
18
+ export type {
19
+ SectionBase,
20
+ ScrollToLocationParamsType,
21
+ } from '@react-native/virtualized-lists';
22
+ module.exports = VirtualizedSectionList;
@@ -93,6 +93,7 @@ module.exports = {
93
93
  <FlatList
94
94
  // $FlowExpectedError - bad title type number, should be string
95
95
  renderItem={(info: {item: {title: number}}) => <span />}
96
+ // $FlowExpectedError - bad title type number, should be string
96
97
  data={data}
97
98
  />,
98
99
  // EverythingIsFine
@@ -76,7 +76,7 @@ module.exports = {
76
76
  },
77
77
 
78
78
  testBadInheritedDefaultProp(): React.MixedElement {
79
- const sections = [];
79
+ const sections: $FlowFixMe = [];
80
80
  return (
81
81
  <SectionList
82
82
  renderItem={renderMyListItem}
@@ -154,7 +154,7 @@ function appendNewLog(newLog: LogBoxLog) {
154
154
  if (newLog.level === 'fatal') {
155
155
  // If possible, to avoid jank, we don't want to open the error before
156
156
  // it's symbolicated. To do that, we optimistically wait for
157
- // sybolication for up to a second before adding the log.
157
+ // symbolication for up to a second before adding the log.
158
158
  const OPTIMISTIC_WAIT_TIME = 1000;
159
159
 
160
160
  let addPendingLog: ?() => void = () => {
@@ -302,7 +302,7 @@ export function parseLogBoxException(
302
302
  }
303
303
 
304
304
  // Most `console.error` calls won't have a componentStack. We parse them like
305
- // regular logs which have the component stack burried in the message.
305
+ // regular logs which have the component stack buried in the message.
306
306
  return {
307
307
  level: 'error',
308
308
  stack: error.stack,
@@ -258,4 +258,4 @@ if (__DEV__) {
258
258
  };
259
259
  }
260
260
 
261
- module.exports = (LogBox: ILogBox);
261
+ export default (LogBox: ILogBox);
@@ -92,9 +92,7 @@ const headerTitleMap = {
92
92
  component: 'Render Error',
93
93
  };
94
94
 
95
- function LogBoxInspectorBody(
96
- props: $TEMPORARY$object<{log: LogBoxLog, onRetry: () => void}>,
97
- ) {
95
+ function LogBoxInspectorBody(props: {log: LogBoxLog, onRetry: () => void}) {
98
96
  const [collapsed, setCollapsed] = React.useState(true);
99
97
 
100
98
  React.useEffect(() => {