@office-iss/react-native-win32 0.0.0-canary.283 → 0.0.0-canary.284

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 (244) hide show
  1. package/.flowconfig +1 -1
  2. package/CHANGELOG.json +40 -1
  3. package/CHANGELOG.md +20 -8
  4. package/IntegrationTests/AccessibilityManagerTest.js +17 -12
  5. package/IntegrationTests/AppEventsTest.js +47 -32
  6. package/IntegrationTests/GlobalEvalWithSourceUrlTest.js +10 -14
  7. package/IntegrationTests/ImageCachePolicyTest.js +64 -81
  8. package/IntegrationTests/ImageSnapshotTest.js +17 -20
  9. package/IntegrationTests/IntegrationTestHarnessTest.js +34 -52
  10. package/IntegrationTests/IntegrationTestsApp.js +11 -6
  11. package/IntegrationTests/LayoutEventsTest.js +1 -1
  12. package/IntegrationTests/LoggingTestModule.js +2 -1
  13. package/IntegrationTests/PromiseTest.js +51 -43
  14. package/IntegrationTests/SimpleSnapshotTest.js +19 -24
  15. package/IntegrationTests/SyncMethodTest.js +9 -13
  16. package/IntegrationTests/TimersTest.js +3 -3
  17. package/Libraries/ActionSheetIOS/ActionSheetIOS.js +3 -3
  18. package/Libraries/Alert/Alert.js +1 -1
  19. package/Libraries/Alert/Alert.win32.js +1 -1
  20. package/Libraries/Alert/RCTAlertManager.android.js +1 -1
  21. package/Libraries/Alert/RCTAlertManager.ios.js +1 -1
  22. package/Libraries/Animated/AnimatedMock.js +1 -1
  23. package/Libraries/Animated/AnimatedWeb.js +27 -9
  24. package/Libraries/Animated/nodes/AnimatedValue.js +35 -13
  25. package/Libraries/Animated/useAnimatedProps.js +47 -85
  26. package/Libraries/AppState/AppState.js +1 -1
  27. package/Libraries/BatchedBridge/BatchedBridge.js +4 -2
  28. package/Libraries/BatchedBridge/MessageQueue.js +2 -2
  29. package/Libraries/BatchedBridge/NativeModules.js +4 -3
  30. package/Libraries/Blob/Blob.js +4 -4
  31. package/Libraries/Blob/BlobManager.js +3 -2
  32. package/Libraries/Blob/BlobRegistry.js +3 -9
  33. package/Libraries/Blob/File.js +3 -2
  34. package/Libraries/Blob/FileReader.js +1 -1
  35. package/Libraries/BugReporting/BugReporting.js +2 -2
  36. package/Libraries/BugReporting/dumpReactTree.js +2 -2
  37. package/Libraries/BugReporting/getReactData.js +1 -1
  38. package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.android.js +1 -1
  39. package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.ios.js +1 -1
  40. package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.win32.js +1 -1
  41. package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +5 -5
  42. package/Libraries/Components/Button.js +2 -2
  43. package/Libraries/Components/Button.win32.js +2 -2
  44. package/Libraries/Components/Clipboard/Clipboard.js +1 -1
  45. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +7 -7
  46. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.js +1 -2
  47. package/Libraries/Components/Keyboard/Keyboard.js +9 -9
  48. package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +4 -4
  49. package/Libraries/Components/Pressable/Pressable.js +4 -4
  50. package/Libraries/Components/Pressable/Pressable.win32.js +4 -4
  51. package/Libraries/Components/Pressable/useAndroidRippleForView.js +9 -9
  52. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.android.js +10 -11
  53. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.js +1 -1
  54. package/Libraries/Components/RefreshControl/RefreshControl.js +9 -9
  55. package/Libraries/Components/ScrollView/ScrollView.js +32 -26
  56. package/Libraries/Components/ScrollView/ScrollViewCommands.js +2 -2
  57. package/Libraries/Components/ScrollView/ScrollViewNativeComponentType.js +2 -2
  58. package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +1 -1
  59. package/Libraries/Components/ScrollView/processDecelerationRate.js +1 -1
  60. package/Libraries/Components/Sound/SoundManager.js +1 -1
  61. package/Libraries/Components/StaticRenderer.js +4 -4
  62. package/Libraries/Components/StatusBar/StatusBar.js +33 -18
  63. package/Libraries/Components/Switch/Switch.js +6 -6
  64. package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +31 -31
  65. package/Libraries/Components/TextInput/InputAccessoryView.js +2 -2
  66. package/Libraries/Components/TextInput/TextInput.flow.js +35 -35
  67. package/Libraries/Components/TextInput/TextInput.js +35 -35
  68. package/Libraries/Components/TextInput/TextInput.win32.js +35 -35
  69. package/Libraries/Components/TextInput/TextInputNativeCommands.js +1 -1
  70. package/Libraries/Components/ToastAndroid/ToastAndroid.d.ts +68 -6
  71. package/Libraries/Components/Touchable/TouchableBounce.js +5 -5
  72. package/Libraries/Components/Touchable/TouchableHighlight.js +11 -11
  73. package/Libraries/Components/Touchable/TouchableNativeFeedback.js +14 -14
  74. package/Libraries/Components/Touchable/TouchableNativeFeedback.win32.js +6 -6
  75. package/Libraries/Components/Touchable/TouchableOpacity.js +6 -6
  76. package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +2 -2
  77. package/Libraries/Components/UnimplementedViews/UnimplementedView.js +9 -1
  78. package/Libraries/Components/View/ViewAccessibility.js +2 -2
  79. package/Libraries/Components/View/ViewAccessibility.win32.js +2 -2
  80. package/Libraries/Components/View/ViewPropTypes.js +22 -22
  81. package/Libraries/Components/View/ViewPropTypes.win32.js +22 -22
  82. package/Libraries/Core/RawEventEmitter.js +2 -2
  83. package/Libraries/Core/ReactNativeVersion.js +3 -5
  84. package/Libraries/Core/Timers/JSTimers.js +3 -3
  85. package/Libraries/Core/polyfillPromise.js +1 -1
  86. package/Libraries/Core/registerCallableModule.js +1 -1
  87. package/Libraries/Core/setUpAlert.js +1 -1
  88. package/Libraries/Core/setUpDeveloperTools.js +0 -2
  89. package/Libraries/Core/setUpErrorHandling.js +6 -1
  90. package/Libraries/Core/setUpReactDevTools.js +1 -1
  91. package/Libraries/Core/setUpTimers.js +35 -56
  92. package/Libraries/Core/setUpXHR.js +5 -5
  93. package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +2 -1
  94. package/Libraries/Events/CustomEvent.js +2 -2
  95. package/Libraries/Image/AssetRegistry.js +6 -1
  96. package/Libraries/Image/AssetSourceResolver.js +2 -2
  97. package/Libraries/Image/ImageProps.js +17 -17
  98. package/Libraries/Image/nativeImageSource.js +2 -2
  99. package/Libraries/Inspector/ElementProperties.js +4 -3
  100. package/Libraries/Inspector/Inspector.js +1 -1
  101. package/Libraries/Inspector/Inspector.win32.js +1 -1
  102. package/Libraries/Inspector/InspectorOverlay.js +4 -3
  103. package/Libraries/Inspector/InspectorOverlay.win32.js +3 -3
  104. package/Libraries/Inspector/InspectorPanel.js +6 -6
  105. package/Libraries/Inspector/NetworkOverlay.js +6 -5
  106. package/Libraries/Inspector/PerformanceOverlay.js +2 -1
  107. package/Libraries/Inspector/resolveBoxStyle.js +2 -2
  108. package/Libraries/Interaction/InteractionManager.js +3 -2
  109. package/Libraries/Interaction/PanResponder.js +6 -6
  110. package/Libraries/Interaction/TouchHistoryMath.js +26 -0
  111. package/Libraries/JSInspector/NetworkAgent.js +2 -1
  112. package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -2
  113. package/Libraries/Linking/Linking.js +0 -1
  114. package/Libraries/Lists/FlatList.js +9 -10
  115. package/Libraries/Lists/SectionList.js +7 -9
  116. package/Libraries/Lists/SectionListModern.js +6 -6
  117. package/Libraries/LogBox/Data/LogBoxData.js +14 -14
  118. package/Libraries/LogBox/Data/LogBoxLog.js +51 -29
  119. package/Libraries/LogBox/Data/parseLogBoxLog.js +10 -10
  120. package/Libraries/LogBox/LogBox.js +13 -1
  121. package/Libraries/LogBox/LogBoxInspectorContainer.js +3 -3
  122. package/Libraries/LogBox/LogBoxNotificationContainer.js +3 -3
  123. package/Libraries/LogBox/UI/LogBoxButton.js +4 -4
  124. package/Libraries/LogBox/UI/LogBoxInspectorBody.js +8 -2
  125. package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.js +50 -31
  126. package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.win32.js +50 -31
  127. package/Libraries/LogBox/UI/LogBoxInspectorMessageHeader.js +2 -2
  128. package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.js +2 -2
  129. package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.win32.js +2 -2
  130. package/Libraries/LogBox/UI/LogBoxInspectorSection.js +2 -2
  131. package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +2 -2
  132. package/Libraries/LogBox/UI/LogBoxInspectorStackFrames.js +2 -2
  133. package/Libraries/Modal/Modal.js +7 -7
  134. package/Libraries/Network/XMLHttpRequest.js +1 -1
  135. package/Libraries/Network/convertRequestBody.js +3 -1
  136. package/Libraries/PermissionsAndroid/PermissionsAndroid.js +4 -4
  137. package/Libraries/Pressability/Pressability.js +10 -10
  138. package/Libraries/Pressability/Pressability.win32.js +10 -10
  139. package/Libraries/Pressability/PressabilityDebug.js +2 -2
  140. package/Libraries/Pressability/PressabilityPerformanceEventEmitter.js +2 -2
  141. package/Libraries/Promise.js +2 -2
  142. package/Libraries/ReactNative/AppContainer.js +2 -2
  143. package/Libraries/ReactNative/BridgelessUIManager.js +3 -8
  144. package/Libraries/ReactNative/I18nManager.js +3 -2
  145. package/Libraries/ReactNative/PaperUIManager.js +1 -1
  146. package/Libraries/ReactNative/PaperUIManager.win32.js +1 -1
  147. package/Libraries/ReactNative/ReactNativeFeatureFlags.js +2 -2
  148. package/Libraries/ReactNative/ReactNativeRuntimeDiagnostics.js +2 -2
  149. package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +3 -2
  150. package/Libraries/StyleSheet/Rect.js +2 -2
  151. package/Libraries/StyleSheet/StyleSheet.js +1 -1
  152. package/Libraries/StyleSheet/StyleSheet.win32.js +1 -1
  153. package/Libraries/StyleSheet/StyleSheetTypes.d.ts +1 -1
  154. package/Libraries/StyleSheet/private/_TransformStyle.js +18 -18
  155. package/Libraries/StyleSheet/processBackgroundImage.js +138 -136
  156. package/Libraries/Text/TextAncestor.js +1 -2
  157. package/Libraries/TurboModule/TurboModuleRegistry.js +1 -1
  158. package/Libraries/Types/CodegenTypes.js +2 -1
  159. package/Libraries/Types/CoreEventTypes.js +40 -40
  160. package/Libraries/Types/CoreEventTypes.win32.js +40 -40
  161. package/Libraries/UTFSequence.js +2 -2
  162. package/Libraries/Utilities/BackHandler.android.js +2 -2
  163. package/Libraries/Utilities/BackHandler.ios.js +2 -2
  164. package/Libraries/Utilities/BackHandler.win32.js +2 -2
  165. package/Libraries/Utilities/HMRClient.js +2 -2
  166. package/Libraries/Utilities/Platform.android.js +4 -4
  167. package/Libraries/Utilities/Platform.flow.js +8 -8
  168. package/Libraries/Utilities/Platform.flow.win32.js +8 -8
  169. package/Libraries/Utilities/Platform.ios.js +4 -4
  170. package/Libraries/Utilities/Platform.win32.js +2 -2
  171. package/Libraries/Utilities/ReactNativeTestTools.js +3 -2
  172. package/Libraries/Utilities/codegenNativeCommands.js +2 -2
  173. package/Libraries/Utilities/codegenNativeComponent.js +2 -2
  174. package/Libraries/Utilities/differ/deepDiffer.js +3 -3
  175. package/Libraries/Utilities/stringifySafe.js +2 -2
  176. package/Libraries/Vibration/Vibration.js +1 -1
  177. package/Libraries/WebSocket/WebSocketEvent.js +1 -1
  178. package/Libraries/YellowBox/YellowBoxDeprecated.js +4 -3
  179. package/Libraries/vendor/core/ErrorUtils.js +1 -1
  180. package/flow/jest.js +14 -14
  181. package/index.js +16 -13
  182. package/index.win32.js +16 -13
  183. package/jest/setup.js +214 -197
  184. package/overrides.json +26 -26
  185. package/package.json +16 -16
  186. package/src/private/featureflags/ReactNativeFeatureFlags.js +11 -30
  187. package/src/private/featureflags/specs/NativeReactNativeFeatureFlags.js +3 -2
  188. package/src/private/specs/components/ActivityIndicatorViewNativeComponent.js +2 -2
  189. package/src/private/specs/components/AndroidDrawerLayoutNativeComponent.js +6 -6
  190. package/src/private/specs/components/AndroidHorizontalScrollContentViewNativeComponent.js +2 -2
  191. package/src/private/specs/components/AndroidSwipeRefreshLayoutNativeComponent.js +2 -2
  192. package/src/private/specs/components/AndroidSwitchNativeComponent.js +4 -4
  193. package/src/private/specs/components/DebuggingOverlayNativeComponent.js +2 -2
  194. package/src/private/specs/components/ProgressBarAndroidNativeComponent.js +2 -2
  195. package/src/private/specs/components/PullToRefreshViewNativeComponent.js +2 -2
  196. package/src/private/specs/components/RCTInputAccessoryViewNativeComponent.js +2 -2
  197. package/src/private/specs/components/RCTModalHostViewNativeComponent.js +4 -4
  198. package/src/private/specs/components/RCTSafeAreaViewNativeComponent.js +2 -2
  199. package/src/private/specs/components/SwitchNativeComponent.js +4 -4
  200. package/src/private/specs/components/UnimplementedNativeViewNativeComponent.js +2 -2
  201. package/src/private/specs/modules/NativeAccessibilityManager.js +2 -2
  202. package/src/private/specs/modules/NativeActionSheetManager.js +7 -7
  203. package/src/private/specs/modules/NativeAlertManager.js +2 -2
  204. package/src/private/specs/modules/NativeAnimatedModule.js +2 -2
  205. package/src/private/specs/modules/NativeAnimatedTurboModule.js +2 -2
  206. package/src/private/specs/modules/NativeAppState.js +3 -3
  207. package/src/private/specs/modules/NativeBlobModule.js +1 -1
  208. package/src/private/specs/modules/NativeClipboard.js +1 -1
  209. package/src/private/specs/modules/NativeDeviceInfo.js +8 -8
  210. package/src/private/specs/modules/NativeDialogManagerAndroid.js +4 -4
  211. package/src/private/specs/modules/NativeExceptionsManager.js +2 -2
  212. package/src/private/specs/modules/NativeFantom.js +6 -0
  213. package/src/private/specs/modules/NativeFrameRateLogger.js +1 -1
  214. package/src/private/specs/modules/NativeI18nManager.js +2 -2
  215. package/src/private/specs/modules/NativeImageEditor.js +9 -9
  216. package/src/private/specs/modules/NativeImageLoaderAndroid.js +1 -1
  217. package/src/private/specs/modules/NativeImageLoaderIOS.js +1 -1
  218. package/src/private/specs/modules/NativeImageLoaderWin32.js +1 -1
  219. package/src/private/specs/modules/NativeImageStoreAndroid.js +1 -1
  220. package/src/private/specs/modules/NativeImageStoreIOS.js +3 -3
  221. package/src/private/specs/modules/NativeNetworkingIOS.js +2 -2
  222. package/src/private/specs/modules/NativePlatformConstantsAndroid.js +4 -4
  223. package/src/private/specs/modules/NativePlatformConstantsIOS.js +4 -4
  224. package/src/private/specs/modules/NativePlatformConstantsWin.js +5 -10
  225. package/src/private/specs/modules/NativePushNotificationManagerIOS.js +7 -7
  226. package/src/private/specs/modules/NativeSampleTurboModule.js +2 -2
  227. package/src/private/specs/modules/NativeSettingsManager.js +2 -2
  228. package/src/private/specs/modules/NativeShareModule.js +3 -3
  229. package/src/private/specs/modules/NativeSourceCode.js +2 -2
  230. package/src/private/specs/modules/NativeStatusBarManagerAndroid.js +4 -4
  231. package/src/private/specs/modules/NativeStatusBarManagerIOS.js +6 -6
  232. package/src/private/specs/modules/NativeToastAndroid.js +2 -2
  233. package/src/private/specs/modules/NativeVibration.js +1 -1
  234. package/src/private/specs/modules/NativeWebSocketModule.js +1 -1
  235. package/src/private/webapis/intersectionobserver/IntersectionObserver.js +2 -2
  236. package/src/private/webapis/intersectionobserver/{IntersectionObserverManager.js → internals/IntersectionObserverManager.js} +9 -9
  237. package/src/private/webapis/mutationobserver/MutationObserver.js +2 -2
  238. package/src/private/webapis/mutationobserver/{MutationObserverManager.js → internals/MutationObserverManager.js} +8 -8
  239. package/src/private/webapis/performance/EventTiming.js +1 -1
  240. package/src/private/webapis/performance/Performance.js +3 -3
  241. package/src/private/webapis/performance/PerformanceObserver.js +2 -2
  242. package/src/private/webapis/performance/{RawPerformanceEntry.js → internals/RawPerformanceEntry.js} +6 -6
  243. package/src/private/webapis/performance/{Utilities.js → internals/Utilities.js} +1 -1
  244. package/src/private/webapis/performance/specs/__mocks__/NativePerformanceMock.js +1 -1
@@ -22,16 +22,13 @@ import LogBoxButton from './LogBoxButton';
22
22
  import LogBoxInspectorSection from './LogBoxInspectorSection';
23
23
  import * as LogBoxStyle from './LogBoxStyle';
24
24
  import * as React from 'react';
25
- type Props = $ReadOnly<{|
26
- codeFrame: ?CodeFrame,
27
- |}>;
28
25
 
29
- function LogBoxInspectorCodeFrame(props: Props): React.Node {
30
- const codeFrame = props.codeFrame;
31
- if (codeFrame == null) {
32
- return null;
33
- }
26
+ type Props = $ReadOnly<{
27
+ componentCodeFrame: ?CodeFrame,
28
+ codeFrame: ?CodeFrame,
29
+ }>;
34
30
 
31
+ function CodeFrameDisplay({codeFrame}: {codeFrame: CodeFrame}): React.Node {
35
32
  function getFileName() {
36
33
  // $FlowFixMe[incompatible-use]
37
34
  const matches = /[^/]*$/.exec(codeFrame.fileName);
@@ -56,30 +53,52 @@ function LogBoxInspectorCodeFrame(props: Props): React.Node {
56
53
  }
57
54
 
58
55
  return (
59
- <LogBoxInspectorSection heading="Source" action={<AppInfo />}>
60
- <View style={styles.box}>
61
- <View style={styles.frame}>
62
- <ScrollView
63
- horizontal
64
- contentContainerStyle={styles.contentContainer}>
65
- <AnsiHighlight style={styles.content} text={codeFrame.content} />
66
- </ScrollView>
67
- </View>
68
- <LogBoxButton
69
- backgroundColor={{
70
- default: 'transparent',
71
- pressed: LogBoxStyle.getBackgroundDarkColor(1),
72
- }}
73
- style={styles.button}
74
- onPress={() => {
75
- openFileInEditor(codeFrame.fileName, codeFrame.location?.row ?? 0);
76
- }}>
77
- <Text style={styles.fileText}>
78
- {getFileName()}
79
- {getLocation()}
80
- </Text>
81
- </LogBoxButton>
56
+ <View style={styles.box}>
57
+ <View style={styles.frame}>
58
+ <ScrollView horizontal contentContainerStyle={styles.contentContainer}>
59
+ <AnsiHighlight style={styles.content} text={codeFrame.content} />
60
+ </ScrollView>
82
61
  </View>
62
+ <LogBoxButton
63
+ backgroundColor={{
64
+ default: 'transparent',
65
+ pressed: LogBoxStyle.getBackgroundDarkColor(1),
66
+ }}
67
+ style={styles.button}
68
+ onPress={() => {
69
+ openFileInEditor(codeFrame.fileName, codeFrame.location?.row ?? 0);
70
+ }}>
71
+ <Text style={styles.fileText}>
72
+ {getFileName()}
73
+ {getLocation()}
74
+ </Text>
75
+ </LogBoxButton>
76
+ </View>
77
+ );
78
+ }
79
+
80
+ function LogBoxInspectorCodeFrame(props: Props): React.Node {
81
+ const {codeFrame, componentCodeFrame} = props;
82
+ let sources = [];
83
+ if (codeFrame != null) {
84
+ sources.push(codeFrame);
85
+ }
86
+ if (
87
+ componentCodeFrame != null &&
88
+ componentCodeFrame?.content !== codeFrame?.content
89
+ ) {
90
+ sources.push(componentCodeFrame);
91
+ }
92
+ if (sources.length === 0) {
93
+ return null;
94
+ }
95
+ return (
96
+ <LogBoxInspectorSection
97
+ heading={sources.length > 1 ? 'Sources' : 'Source'}
98
+ action={<AppInfo />}>
99
+ {sources.map((frame, index) => (
100
+ <CodeFrameDisplay key={index} codeFrame={frame} />
101
+ ))}
83
102
  </LogBoxInspectorSection>
84
103
  );
85
104
  }
@@ -18,13 +18,13 @@ import LogBoxMessage from './LogBoxMessage';
18
18
  import * as LogBoxStyle from './LogBoxStyle';
19
19
  import * as React from 'react';
20
20
 
21
- type Props = $ReadOnly<{|
21
+ type Props = $ReadOnly<{
22
22
  collapsed: boolean,
23
23
  message: Message,
24
24
  level: LogLevel,
25
25
  title: string,
26
26
  onPress: () => void,
27
- |}>;
27
+ }>;
28
28
 
29
29
  const SHOW_MORE_MESSAGE_LENGTH = 300;
30
30
 
@@ -20,9 +20,9 @@ import LogBoxInspectorSection from './LogBoxInspectorSection';
20
20
  import * as LogBoxStyle from './LogBoxStyle';
21
21
  import * as React from 'react';
22
22
 
23
- type Props = $ReadOnly<{|
23
+ type Props = $ReadOnly<{
24
24
  log: LogBoxLog,
25
- |}>;
25
+ }>;
26
26
 
27
27
  const BEFORE_SLASH_RE = /^(.*)[\\/]/;
28
28
 
@@ -20,9 +20,9 @@ import LogBoxInspectorSection from './LogBoxInspectorSection';
20
20
  import * as LogBoxStyle from './LogBoxStyle';
21
21
  import * as React from 'react';
22
22
 
23
- type Props = $ReadOnly<{|
23
+ type Props = $ReadOnly<{
24
24
  log: LogBoxLog,
25
- |}>;
25
+ }>;
26
26
 
27
27
  const BEFORE_SLASH_RE = /^(.*)[\\/]/;
28
28
 
@@ -14,11 +14,11 @@ import Text from '../../Text/Text';
14
14
  import * as LogBoxStyle from './LogBoxStyle';
15
15
  import * as React from 'react';
16
16
 
17
- type Props = $ReadOnly<{|
17
+ type Props = $ReadOnly<{
18
18
  heading: string,
19
19
  children: React.Node,
20
20
  action?: ?React.Node,
21
- |}>;
21
+ }>;
22
22
 
23
23
  function LogBoxInspectorSection(props: Props): React.Node {
24
24
  return (
@@ -18,10 +18,10 @@ import LogBoxButton from './LogBoxButton';
18
18
  import * as LogBoxStyle from './LogBoxStyle';
19
19
  import * as React from 'react';
20
20
 
21
- type Props = $ReadOnly<{|
21
+ type Props = $ReadOnly<{
22
22
  onPress?: ?(event: PressEvent) => void,
23
23
  status: 'COMPLETE' | 'FAILED' | 'NONE' | 'PENDING',
24
- |}>;
24
+ }>;
25
25
 
26
26
  function LogBoxInspectorSourceMapStatus(props: Props): React.Node {
27
27
  const [state, setState] = React.useState({
@@ -23,10 +23,10 @@ import LogBoxInspectorStackFrame from './LogBoxInspectorStackFrame';
23
23
  import * as LogBoxStyle from './LogBoxStyle';
24
24
  import * as React from 'react';
25
25
 
26
- type Props = $ReadOnly<{|
26
+ type Props = $ReadOnly<{
27
27
  log: LogBoxLog,
28
28
  onRetry: () => void,
29
- |}>;
29
+ }>;
30
30
 
31
31
  export function getCollapseMessage(
32
32
  stackFrames: Stack,
@@ -18,15 +18,15 @@ import ModalInjection from './ModalInjection';
18
18
  import NativeModalManager from './NativeModalManager';
19
19
  import RCTModalHostView from './RCTModalHostViewNativeComponent';
20
20
  import {VirtualizedListContextResetter} from '@react-native/virtualized-lists';
21
+ import React from 'react';
21
22
 
22
- const ScrollView = require('../Components/ScrollView/ScrollView');
23
+ const ScrollView = require('../Components/ScrollView/ScrollView').default;
23
24
  const View = require('../Components/View/View');
24
25
  const AppContainer = require('../ReactNative/AppContainer');
25
26
  const I18nManager = require('../ReactNative/I18nManager');
26
27
  const {RootTagContext} = require('../ReactNative/RootTag');
27
28
  const StyleSheet = require('../StyleSheet/StyleSheet');
28
29
  const Platform = require('../Utilities/Platform');
29
- const React = require('react');
30
30
 
31
31
  type ModalEventDefinitions = {
32
32
  modalDismissed: [{modalID: number}],
@@ -53,11 +53,11 @@ const ModalEventEmitter =
53
53
  // destroyed before the callback is fired.
54
54
  let uniqueModalIdentifier = 0;
55
55
 
56
- type OrientationChangeEvent = $ReadOnly<{|
56
+ type OrientationChangeEvent = $ReadOnly<{
57
57
  orientation: 'portrait' | 'landscape',
58
- |}>;
58
+ }>;
59
59
 
60
- export type Props = $ReadOnly<{|
60
+ export type Props = $ReadOnly<{
61
61
  ...ViewProps,
62
62
 
63
63
  /**
@@ -171,7 +171,7 @@ export type Props = $ReadOnly<{|
171
171
  * Defaults to `white` if not provided and transparent is `false`. Ignored if `transparent` is `true`.
172
172
  */
173
173
  backdropColor?: ?string,
174
- |}>;
174
+ }>;
175
175
 
176
176
  function confirmProps(props: Props) {
177
177
  if (__DEV__) {
@@ -202,7 +202,7 @@ type State = {
202
202
  };
203
203
 
204
204
  class Modal extends React.Component<Props, State> {
205
- static defaultProps: {|hardwareAccelerated: boolean, visible: boolean|} = {
205
+ static defaultProps: {hardwareAccelerated: boolean, visible: boolean} = {
206
206
  visible: true,
207
207
  hardwareAccelerated: false,
208
208
  };
@@ -15,7 +15,7 @@ import type {IPerformanceLogger} from '../Utilities/createPerformanceLogger';
15
15
  import {type EventSubscription} from '../vendor/emitter/EventEmitter';
16
16
  import EventTarget from 'event-target-shim';
17
17
 
18
- const BlobManager = require('../Blob/BlobManager');
18
+ const BlobManager = require('../Blob/BlobManager').default;
19
19
  const GlobalPerformanceLogger = require('../Utilities/GlobalPerformanceLogger');
20
20
  const RCTNetworking = require('./RCTNetworking').default;
21
21
  const base64 = require('base64-js');
@@ -10,7 +10,9 @@
10
10
 
11
11
  'use strict';
12
12
 
13
- const Blob = require('../Blob/Blob');
13
+ import typeof BlobT from '../Blob/Blob';
14
+
15
+ const Blob: BlobT = require('../Blob/Blob').default;
14
16
  const binaryToBase64 = require('../Utilities/binaryToBase64');
15
17
  const FormData = require('./FormData');
16
18
 
@@ -88,7 +88,7 @@ const PERMISSIONS = Object.freeze({
88
88
  */
89
89
 
90
90
  class PermissionsAndroid {
91
- PERMISSIONS: $ReadOnly<{|
91
+ PERMISSIONS: $ReadOnly<{
92
92
  ACCEPT_HANDOVER: string,
93
93
  ACCESS_BACKGROUND_LOCATION: string,
94
94
  ACCESS_COARSE_LOCATION: string,
@@ -132,12 +132,12 @@ class PermissionsAndroid {
132
132
  WRITE_CALL_LOG: string,
133
133
  WRITE_CONTACTS: string,
134
134
  WRITE_EXTERNAL_STORAGE: string,
135
- |}> = PERMISSIONS;
136
- RESULTS: $ReadOnly<{|
135
+ }> = PERMISSIONS;
136
+ RESULTS: $ReadOnly<{
137
137
  DENIED: 'denied',
138
138
  GRANTED: 'granted',
139
139
  NEVER_ASK_AGAIN: 'never_ask_again',
140
- |}> = PERMISSION_REQUEST_RESULT;
140
+ }> = PERMISSION_REQUEST_RESULT;
141
141
 
142
142
  /**
143
143
  * DEPRECATED - use check
@@ -27,7 +27,7 @@ import PressabilityPerformanceEventEmitter from './PressabilityPerformanceEventE
27
27
  import {type PressabilityTouchSignal as TouchSignal} from './PressabilityTypes.js';
28
28
  import invariant from 'invariant';
29
29
 
30
- export type PressabilityConfig = $ReadOnly<{|
30
+ export type PressabilityConfig = $ReadOnly<{
31
31
  /**
32
32
  * Whether a press gesture can be interrupted by a parent gesture such as a
33
33
  * scroll event. Defaults to true.
@@ -135,9 +135,9 @@ export type PressabilityConfig = $ReadOnly<{|
135
135
  * while this pressable is responder.
136
136
  */
137
137
  blockNativeResponder?: ?boolean,
138
- |}>;
138
+ }>;
139
139
 
140
- export type EventHandlers = $ReadOnly<{|
140
+ export type EventHandlers = $ReadOnly<{
141
141
  onBlur: (event: BlurEvent) => void,
142
142
  onClick: (event: PressEvent) => void,
143
143
  onFocus: (event: FocusEvent) => void,
@@ -151,7 +151,7 @@ export type EventHandlers = $ReadOnly<{|
151
151
  onResponderTerminate: (event: PressEvent) => void,
152
152
  onResponderTerminationRequest: () => boolean,
153
153
  onStartShouldSetResponder: () => boolean,
154
- |}>;
154
+ }>;
155
155
 
156
156
  type TouchState =
157
157
  | 'NOT_RESPONDER'
@@ -378,16 +378,16 @@ export default class Pressability {
378
378
  _pressDelayTimeout: ?TimeoutID = null;
379
379
  _pressOutDelayTimeout: ?TimeoutID = null;
380
380
  _responderID: ?number | HostInstance = null;
381
- _responderRegion: ?$ReadOnly<{|
381
+ _responderRegion: ?$ReadOnly<{
382
382
  bottom: number,
383
383
  left: number,
384
384
  right: number,
385
385
  top: number,
386
- |}> = null;
387
- _touchActivatePosition: ?$ReadOnly<{|
386
+ }> = null;
387
+ _touchActivatePosition: ?$ReadOnly<{
388
388
  pageX: number,
389
389
  pageY: number,
390
- |}>;
390
+ }>;
391
391
  _touchActivateTime: ?number;
392
392
  _touchState: TouchState = 'NOT_RESPONDER';
393
393
 
@@ -830,12 +830,12 @@ export default class Pressability {
830
830
 
831
831
  _isTouchWithinResponderRegion(
832
832
  touch: $PropertyType<PressEvent, 'nativeEvent'>,
833
- responderRegion: $ReadOnly<{|
833
+ responderRegion: $ReadOnly<{
834
834
  bottom: number,
835
835
  left: number,
836
836
  right: number,
837
837
  top: number,
838
- |}>,
838
+ }>,
839
839
  ): boolean {
840
840
  const hitSlop = normalizeRect(this._config.hitSlop);
841
841
  const pressRectOffset = normalizeRect(this._config.pressRectOffset);
@@ -28,7 +28,7 @@ import PressabilityPerformanceEventEmitter from './PressabilityPerformanceEventE
28
28
  import {type PressabilityTouchSignal as TouchSignal} from './PressabilityTypes.js';
29
29
  import invariant from 'invariant';
30
30
 
31
- export type PressabilityConfig = $ReadOnly<{|
31
+ export type PressabilityConfig = $ReadOnly<{
32
32
  /**
33
33
  * Whether a press gesture can be interrupted by a parent gesture such as a
34
34
  * scroll event. Defaults to true.
@@ -162,9 +162,9 @@ export type PressabilityConfig = $ReadOnly<{|
162
162
  */
163
163
  onMouseLeave?: ?(event: MouseEvent) => mixed,
164
164
  // Windows]
165
- |}>;
165
+ }>;
166
166
 
167
- export type EventHandlers = $ReadOnly<{|
167
+ export type EventHandlers = $ReadOnly<{
168
168
  onBlur: (event: BlurEvent) => void,
169
169
  onClick: (event: PressEvent) => void,
170
170
  onFocus: (event: FocusEvent) => void,
@@ -182,7 +182,7 @@ export type EventHandlers = $ReadOnly<{|
182
182
  onKeyUp: (event: KeyEvent) => void,
183
183
  onKeyDown: (event: KeyEvent) => void,
184
184
  // Windows]
185
- |}>;
185
+ }>;
186
186
 
187
187
  type TouchState =
188
188
  | 'NOT_RESPONDER'
@@ -409,16 +409,16 @@ export default class Pressability {
409
409
  _pressDelayTimeout: ?TimeoutID = null;
410
410
  _pressOutDelayTimeout: ?TimeoutID = null;
411
411
  _responderID: ?number | HostInstance = null;
412
- _responderRegion: ?$ReadOnly<{|
412
+ _responderRegion: ?$ReadOnly<{
413
413
  bottom: number,
414
414
  left: number,
415
415
  right: number,
416
416
  top: number,
417
- |}> = null;
418
- _touchActivatePosition: ?$ReadOnly<{|
417
+ }> = null;
418
+ _touchActivatePosition: ?$ReadOnly<{
419
419
  pageX: number,
420
420
  pageY: number,
421
- |}>;
421
+ }>;
422
422
  _touchActivateTime: ?number;
423
423
  _touchState: TouchState = 'NOT_RESPONDER';
424
424
  _isKeyDown: boolean = false;
@@ -935,12 +935,12 @@ export default class Pressability {
935
935
 
936
936
  _isTouchWithinResponderRegion(
937
937
  touch: $PropertyType<PressEvent, 'nativeEvent'>,
938
- responderRegion: $ReadOnly<{|
938
+ responderRegion: $ReadOnly<{
939
939
  bottom: number,
940
940
  left: number,
941
941
  right: number,
942
942
  top: number,
943
- |}>,
943
+ }>,
944
944
  ): boolean {
945
945
  const hitSlop = normalizeRect(this._config.hitSlop);
946
946
  const pressRectOffset = normalizeRect(this._config.pressRectOffset);
@@ -15,10 +15,10 @@ import normalizeColor from '../StyleSheet/normalizeColor';
15
15
  import {type RectOrSize, normalizeRect} from '../StyleSheet/Rect';
16
16
  import * as React from 'react';
17
17
 
18
- type Props = $ReadOnly<{|
18
+ type Props = $ReadOnly<{
19
19
  color: ColorValue,
20
20
  hitSlop: ?RectOrSize,
21
- |}>;
21
+ }>;
22
22
 
23
23
  /**
24
24
  * Displays a debug overlay to visualize press targets when enabled via the
@@ -10,10 +10,10 @@
10
10
 
11
11
  import {type PressabilityTouchSignal as TouchSignal} from './PressabilityTypes.js';
12
12
 
13
- export type PressabilityPerformanceEvent = $ReadOnly<{|
13
+ export type PressabilityPerformanceEvent = $ReadOnly<{
14
14
  signal: TouchSignal,
15
15
  nativeTimestamp: number,
16
- |}>;
16
+ }>;
17
17
  export type PressabilityPerformanceEventListener =
18
18
  PressabilityPerformanceEvent => void;
19
19
 
@@ -10,7 +10,7 @@
10
10
 
11
11
  'use strict';
12
12
 
13
- const Promise = require('promise/setimmediate/es6-extensions');
13
+ import Promise from 'promise/setimmediate/es6-extensions';
14
14
 
15
15
  require('promise/setimmediate/finally');
16
16
 
@@ -20,4 +20,4 @@ if (__DEV__) {
20
20
  );
21
21
  }
22
22
 
23
- module.exports = Promise;
23
+ export default Promise;
@@ -13,7 +13,7 @@ import type {RootTag} from './RootTag';
13
13
 
14
14
  import * as React from 'react';
15
15
 
16
- export type Props = $ReadOnly<{|
16
+ export type Props = $ReadOnly<{
17
17
  children?: React.Node,
18
18
  fabric?: boolean,
19
19
  rootTag: number | RootTag,
@@ -22,7 +22,7 @@ export type Props = $ReadOnly<{|
22
22
  rootViewStyle?: ?ViewStyleProp,
23
23
  internal_excludeLogBox?: boolean,
24
24
  internal_excludeInspector?: boolean,
25
- |}>;
25
+ }>;
26
26
 
27
27
  const AppContainer: component(...Props) = __DEV__
28
28
  ? require('./AppContainer-dev').default
@@ -182,14 +182,9 @@ const UIManagerJSPlatformAPIs = Platform.select({
182
182
  return [];
183
183
  },
184
184
  setLayoutAnimationEnabledExperimental: (enabled: boolean): void => {
185
- /**
186
- * Layout animations are always enabled in the New Architecture.
187
- * They cannot be turned off.
188
- */
189
- if (!enabled) {
190
- raiseSoftError(
191
- 'setLayoutAnimationEnabledExperimental(false)',
192
- 'Layout animations are always enabled in the New Architecture.',
185
+ if (__DEV__) {
186
+ console.warn(
187
+ 'setLayoutAnimationEnabledExperimental is currently a no-op in the New Architecture.',
193
188
  );
194
189
  }
195
190
  },
@@ -56,6 +56,7 @@ module.exports = {
56
56
  NativeI18nManager.swapLeftAndRightInRTL(flipStyles);
57
57
  },
58
58
 
59
- isRTL: i18nConstants.isRTL,
60
- doLeftAndRightSwapInRTL: i18nConstants.doLeftAndRightSwapInRTL,
59
+ isRTL: i18nConstants.isRTL as I18nManagerConstants['isRTL'],
60
+ doLeftAndRightSwapInRTL:
61
+ i18nConstants.doLeftAndRightSwapInRTL as I18nManagerConstants['doLeftAndRightSwapInRTL'],
61
62
  };
@@ -14,7 +14,7 @@ import type {UIManagerJSInterface} from '../Types/UIManagerJSInterface';
14
14
  import NativeUIManager from './NativeUIManager';
15
15
  import nullthrows from 'nullthrows';
16
16
 
17
- const NativeModules = require('../BatchedBridge/NativeModules');
17
+ const NativeModules = require('../BatchedBridge/NativeModules').default;
18
18
  const defineLazyObjectProperty = require('../Utilities/defineLazyObjectProperty');
19
19
  const Platform = require('../Utilities/Platform');
20
20
  const UIManagerProperties = require('./UIManagerProperties');
@@ -14,7 +14,7 @@ import type {UIManagerJSInterface} from '../Types/UIManagerJSInterface';
14
14
  import NativeUIManager from './NativeUIManager';
15
15
  import nullthrows from 'nullthrows';
16
16
 
17
- const NativeModules = require('../BatchedBridge/NativeModules');
17
+ const NativeModules = require('../BatchedBridge/NativeModules').default;
18
18
  const defineLazyObjectProperty = require('../Utilities/defineLazyObjectProperty');
19
19
  const Platform = require('../Utilities/Platform');
20
20
  const UIManagerProperties = require('./UIManagerProperties');
@@ -8,7 +8,7 @@
8
8
  * @format
9
9
  */
10
10
 
11
- export type FeatureFlags = {|
11
+ export type FeatureFlags = {
12
12
  /**
13
13
  * Function used to enable / disable W3C pointer event emitting in React Native.
14
14
  * If enabled you must also flip the equivalent native flags on each platform:
@@ -21,7 +21,7 @@ export type FeatureFlags = {|
21
21
  * for its hover callbacks
22
22
  */
23
23
  shouldPressibilityUseW3CPointerEventsForHover: () => boolean,
24
- |};
24
+ };
25
25
 
26
26
  const ReactNativeFeatureFlags: FeatureFlags = {
27
27
  shouldEmitW3CPointerEvents: () => false,
@@ -14,7 +14,7 @@
14
14
  * Perform a set of runtime diagnostics, usually useful for test purpose.
15
15
  * This is only meaningful for __DEV__ mode.
16
16
  */
17
- export type RuntimeDiagnostics = {|
17
+ export type RuntimeDiagnostics = {
18
18
  /**
19
19
  * Check if the runtime diagnostics is enabled at all.
20
20
  */
@@ -24,7 +24,7 @@ export type RuntimeDiagnostics = {|
24
24
  * If enabled, simulate early JavaScript errors during initialization.
25
25
  */
26
26
  simulateEarlyJavaScriptErrors: () => void,
27
- |};
27
+ };
28
28
 
29
29
  export type RuntimeDiagnosticFlag = 'early_js_errors' | 'all';
30
30
 
@@ -38,7 +38,7 @@ import typeof Platform from '../Utilities/Platform';
38
38
  // flowlint unsafe-getters-setters:off
39
39
  module.exports = {
40
40
  get BatchedBridge(): BatchedBridge {
41
- return require('../BatchedBridge/BatchedBridge');
41
+ return require('../BatchedBridge/BatchedBridge').default;
42
42
  },
43
43
  get ExceptionsManager(): ExceptionsManager {
44
44
  return require('../Core/ExceptionsManager');
@@ -77,7 +77,8 @@ module.exports = {
77
77
  return require('../Core/ReactFiberErrorDialog').default;
78
78
  },
79
79
  get legacySendAccessibilityEvent(): legacySendAccessibilityEvent {
80
- return require('../Components/AccessibilityInfo/legacySendAccessibilityEvent');
80
+ return require('../Components/AccessibilityInfo/legacySendAccessibilityEvent')
81
+ .default;
81
82
  },
82
83
  get RawEventEmitter(): RawEventEmitter {
83
84
  return require('../Core/RawEventEmitter').default;
@@ -8,12 +8,12 @@
8
8
  * @flow strict
9
9
  */
10
10
 
11
- export type Rect = $ReadOnly<{|
11
+ export type Rect = $ReadOnly<{
12
12
  bottom?: ?number,
13
13
  left?: ?number,
14
14
  right?: ?number,
15
15
  top?: ?number,
16
- |}>;
16
+ }>;
17
17
 
18
18
  export type RectOrSize = Rect | number;
19
19
 
@@ -24,10 +24,10 @@ import type {
24
24
  } from './StyleSheetTypes';
25
25
 
26
26
  import composeStyles from '../../src/private/styles/composeStyles';
27
+ import flatten from './flattenStyle';
27
28
 
28
29
  const ReactNativeStyleAttributes = require('../Components/View/ReactNativeStyleAttributes');
29
30
  const PixelRatio = require('../Utilities/PixelRatio').default;
30
- const flatten = require('./flattenStyle');
31
31
 
32
32
  export type {NativeColorValue} from './StyleSheetTypes';
33
33
 
@@ -24,11 +24,11 @@ import type {
24
24
  } from './StyleSheetTypes';
25
25
 
26
26
  import composeStyles from '../../src/private/styles/composeStyles';
27
+ import flatten from './flattenStyle';
27
28
 
28
29
  const ReactNativeStyleAttributes = require('../Components/View/ReactNativeStyleAttributes');
29
30
  const PixelRatio = require('../Utilities/PixelRatio').default;
30
31
  const Platform = require('../Utilities/Platform'); // [Win32]
31
- const flatten = require('./flattenStyle');
32
32
 
33
33
  export type {NativeColorValue} from './StyleSheetTypes';
34
34
 
@@ -372,7 +372,7 @@ export type GradientValue = {
372
372
  // Angle or direction enums
373
373
  direction?: string | undefined;
374
374
  colorStops: ReadonlyArray<{
375
- color: ColorValue;
375
+ color: ColorValue | null;
376
376
  positions?: ReadonlyArray<string[]> | undefined;
377
377
  }>;
378
378
  };