@office-iss/react-native-win32 0.73.2 → 0.74.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 (479) hide show
  1. package/.eslintignore +1 -1
  2. package/.flowconfig +11 -3
  3. package/CHANGELOG.json +411 -54
  4. package/CHANGELOG.md +157 -30
  5. package/IntegrationTests/AccessibilityManagerTest.js +2 -2
  6. package/IntegrationTests/AppEventsTest.js +2 -2
  7. package/IntegrationTests/LayoutEventsTest.js +8 -10
  8. package/IntegrationTests/LoggingTestModule.js +1 -2
  9. package/IntegrationTests/websocket_integration_test_server.js +1 -1
  10. package/Libraries/ActionSheetIOS/ActionSheetIOS.d.ts +6 -0
  11. package/Libraries/ActionSheetIOS/ActionSheetIOS.js +6 -0
  12. package/Libraries/ActionSheetIOS/NativeActionSheetManager.js +4 -45
  13. package/Libraries/Alert/NativeAlertManager.js +4 -26
  14. package/Libraries/Animated/Animated.js +2 -2
  15. package/Libraries/Animated/AnimatedPlatformConfig.js +1 -1
  16. package/Libraries/Animated/NativeAnimatedHelper.js +14 -11
  17. package/Libraries/Animated/NativeAnimatedHelper.win32.js +14 -11
  18. package/Libraries/Animated/NativeAnimatedModule.js +4 -68
  19. package/Libraries/Animated/NativeAnimatedTurboModule.js +4 -69
  20. package/Libraries/Animated/animations/Animation.js +6 -22
  21. package/Libraries/Animated/components/AnimatedFlatList.js +1 -16
  22. package/Libraries/Animated/components/AnimatedScrollView.js +36 -31
  23. package/Libraries/Animated/components/AnimatedSectionList.js +1 -20
  24. package/Libraries/Animated/createAnimatedComponent.js +45 -40
  25. package/Libraries/Animated/nodes/AnimatedStyle.js +1 -1
  26. package/Libraries/Animated/shouldUseTurboAnimatedModule.js +1 -1
  27. package/Libraries/Animated/useAnimatedProps.js +21 -1
  28. package/Libraries/AppState/NativeAppState.js +4 -24
  29. package/Libraries/BatchedBridge/NativeModules.js +1 -1
  30. package/Libraries/Blob/Blob.js +1 -4
  31. package/Libraries/Blob/BlobManager.js +6 -8
  32. package/Libraries/Blob/File.js +1 -1
  33. package/Libraries/Blob/NativeBlobModule.js +4 -50
  34. package/Libraries/Blob/NativeFileReaderModule.js +4 -13
  35. package/Libraries/BugReporting/NativeBugReporting.js +4 -12
  36. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +5 -1
  37. package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.win32.js +48 -7
  38. package/Libraries/Components/AccessibilityInfo/NativeAccessibilityInfo.js +3 -23
  39. package/Libraries/Components/AccessibilityInfo/NativeAccessibilityInfoWin32.js +11 -0
  40. package/Libraries/Components/AccessibilityInfo/NativeAccessibilityManager.js +4 -57
  41. package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.android.js +3 -2
  42. package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.win32.js +3 -2
  43. package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +9 -40
  44. package/Libraries/Components/ActivityIndicator/ActivityIndicatorViewNativeComponent.js +3 -43
  45. package/Libraries/Components/Button/ButtonWin32.Props.d.ts +36 -36
  46. package/Libraries/Components/Button/ButtonWin32.Props.js +2 -2
  47. package/Libraries/Components/Button/ButtonWin32.Props.js.map +1 -1
  48. package/Libraries/Components/Button/ButtonWin32.d.ts +19 -19
  49. package/Libraries/Components/Button/ButtonWin32.js +82 -82
  50. package/Libraries/Components/Button/ButtonWin32.js.map +1 -1
  51. package/Libraries/Components/Button.js +103 -107
  52. package/Libraries/Components/Button.win32.js +297 -301
  53. package/Libraries/Components/Clipboard/NativeClipboard.js +3 -11
  54. package/Libraries/Components/DrawerAndroid/AndroidDrawerLayoutNativeComponent.js +3 -114
  55. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +1 -5
  56. package/Libraries/Components/EnterString.win32.d.ts +12 -12
  57. package/Libraries/Components/EnterString.win32.js +81 -81
  58. package/Libraries/Components/EnterString.win32.js.map +1 -1
  59. package/Libraries/Components/Keyboard/NativeKeyboardObserver.js +3 -10
  60. package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroid.android.js +69 -0
  61. package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroid.d.ts +24 -0
  62. package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroid.js +33 -0
  63. package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroidNativeComponent.js +13 -0
  64. package/Libraries/Components/Pressable/Pressable.js +1 -1
  65. package/Libraries/Components/Pressable/Pressable.win32.js +1 -1
  66. package/Libraries/Components/Pressable/useAndroidRippleForView.js +5 -4
  67. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroidNativeComponent.js +4 -24
  68. package/Libraries/Components/RefreshControl/AndroidSwipeRefreshLayoutNativeComponent.js +3 -64
  69. package/Libraries/Components/RefreshControl/PullToRefreshViewNativeComponent.js +3 -61
  70. package/Libraries/Components/RefreshControl/RefreshControl.js +1 -1
  71. package/Libraries/Components/SafeAreaView/RCTSafeAreaViewNativeComponent.js +3 -15
  72. package/Libraries/Components/ScrollView/AndroidHorizontalScrollContentViewNativeComponent.js +3 -16
  73. package/Libraries/Components/ScrollView/ScrollContentViewNativeComponent.js +1 -1
  74. package/Libraries/Components/ScrollView/ScrollView.d.ts +5 -6
  75. package/Libraries/Components/ScrollView/ScrollView.js +12 -38
  76. package/Libraries/Components/ScrollView/ScrollView.win32.js +12 -38
  77. package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +1 -2
  78. package/Libraries/Components/Sound/NativeSoundManager.js +3 -12
  79. package/Libraries/Components/StatusBar/NativeStatusBarManagerAndroid.js +3 -58
  80. package/Libraries/Components/StatusBar/NativeStatusBarManagerIOS.js +3 -79
  81. package/Libraries/Components/Switch/AndroidSwitchNativeComponent.js +4 -53
  82. package/Libraries/Components/Switch/Switch.js +0 -2
  83. package/Libraries/Components/Switch/SwitchNativeComponent.js +4 -52
  84. package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +8 -0
  85. package/Libraries/Components/TextInput/InputAccessoryView.js +18 -20
  86. package/Libraries/Components/TextInput/RCTInputAccessoryViewNativeComponent.js +4 -17
  87. package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +3 -6
  88. package/Libraries/Components/TextInput/Tests/TextInputTest.d.ts +8 -8
  89. package/Libraries/Components/TextInput/Tests/TextInputTest.js +127 -127
  90. package/Libraries/Components/TextInput/Tests/TextInputTest.js.map +1 -1
  91. package/Libraries/Components/TextInput/TextInput.d.ts +16 -0
  92. package/Libraries/Components/TextInput/TextInput.flow.js +16 -0
  93. package/Libraries/Components/TextInput/TextInput.js +65 -32
  94. package/Libraries/Components/TextInput/TextInput.win32.js +70 -37
  95. package/Libraries/Components/ToastAndroid/NativeToastAndroid.js +3 -28
  96. package/Libraries/Components/Touchable/PooledClass.js +1 -1
  97. package/Libraries/Components/Touchable/Tests/TouchableWin32Test.d.ts +8 -8
  98. package/Libraries/Components/Touchable/Tests/TouchableWin32Test.js +343 -344
  99. package/Libraries/Components/Touchable/Tests/TouchableWin32Test.js.map +1 -1
  100. package/Libraries/Components/Touchable/Touchable.js +2 -3
  101. package/Libraries/Components/Touchable/Touchable.win32.js +2 -3
  102. package/Libraries/Components/Touchable/TouchableHighlight.js +4 -4
  103. package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -1
  104. package/Libraries/Components/Touchable/TouchableOpacity.js +5 -2
  105. package/Libraries/Components/Touchable/TouchableWin32.Props.d.ts +37 -37
  106. package/Libraries/Components/Touchable/TouchableWin32.Props.js +2 -2
  107. package/Libraries/Components/Touchable/TouchableWin32.Props.js.map +1 -1
  108. package/Libraries/Components/Touchable/TouchableWin32.Types.d.ts +114 -114
  109. package/Libraries/Components/Touchable/TouchableWin32.Types.js +2 -2
  110. package/Libraries/Components/Touchable/TouchableWin32.Types.js.map +1 -1
  111. package/Libraries/Components/Touchable/TouchableWin32.d.ts +91 -91
  112. package/Libraries/Components/Touchable/TouchableWin32.js +506 -506
  113. package/Libraries/Components/Touchable/TouchableWin32.js.map +1 -1
  114. package/Libraries/Components/UnimplementedViews/UnimplementedNativeViewNativeComponent.js +3 -16
  115. package/Libraries/Components/View/ReactNativeStyleAttributes.js +1 -1
  116. package/Libraries/Components/View/View.js +0 -11
  117. package/Libraries/Components/View/View.win32.js +18 -17
  118. package/Libraries/Components/View/ViewAccessibility.d.ts +33 -17
  119. package/Libraries/Components/View/ViewPropTypes.d.ts +28 -17
  120. package/Libraries/Components/View/ViewPropTypes.js +36 -36
  121. package/Libraries/Components/View/ViewPropTypes.win32.js +36 -36
  122. package/Libraries/Core/InitializeCore.js +1 -1
  123. package/Libraries/Core/NativeExceptionsManager.js +3 -93
  124. package/Libraries/Core/ReactNativeVersion.js +12 -6
  125. package/Libraries/Core/ReactNativeVersionCheck.js +6 -6
  126. package/Libraries/Core/ReactNativeVersionCheck.win32.js +6 -6
  127. package/Libraries/Core/SegmentFetcher/NativeSegmentFetcher.js +3 -18
  128. package/Libraries/Core/Timers/NativeTiming.js +3 -16
  129. package/Libraries/Core/registerCallableModule.js +42 -0
  130. package/Libraries/Core/setUpPerformance.js +2 -2
  131. package/Libraries/Core/setUpPerformanceObserver.js +3 -1
  132. package/Libraries/Debugging/DebuggingOverlay.js +111 -0
  133. package/Libraries/Debugging/DebuggingOverlayNativeComponent.js +13 -0
  134. package/Libraries/Debugging/DebuggingOverlayRegistry.js +513 -0
  135. package/Libraries/Debugging/useSubscribeToDebuggingOverlayRegistry.js +32 -0
  136. package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +3 -14
  137. package/Libraries/HeapCapture/NativeJSCHeapCapture.js +3 -9
  138. package/Libraries/Image/AssetSourceResolver.js +5 -5
  139. package/Libraries/Image/AssetUtils.js +4 -5
  140. package/Libraries/Image/Image.android.js +146 -174
  141. package/Libraries/Image/Image.d.ts +1 -1
  142. package/Libraries/Image/Image.ios.js +53 -79
  143. package/Libraries/Image/Image.win32.js +52 -74
  144. package/Libraries/Image/ImageBackground.js +2 -2
  145. package/Libraries/Image/ImageInjection.js +76 -18
  146. package/Libraries/Image/ImageTypes.d.ts +25 -25
  147. package/Libraries/Image/ImageTypes.flow.js +71 -0
  148. package/Libraries/Image/ImageTypes.js +7 -7
  149. package/Libraries/Image/ImageTypes.js.map +1 -1
  150. package/Libraries/Image/ImageUtils.js +1 -1
  151. package/Libraries/Image/ImageViewNativeComponent.js +18 -0
  152. package/Libraries/Image/NativeImageEditor.js +3 -42
  153. package/Libraries/Image/NativeImageLoaderAndroid.js +4 -28
  154. package/Libraries/Image/NativeImageLoaderIOS.js +4 -28
  155. package/Libraries/Image/NativeImageLoaderWin32.js +4 -36
  156. package/Libraries/Image/NativeImageStoreAndroid.js +3 -16
  157. package/Libraries/Image/NativeImageStoreIOS.js +3 -23
  158. package/Libraries/Image/Tests/ImageWin32Test.d.ts +8 -8
  159. package/Libraries/Image/Tests/ImageWin32Test.js +21 -21
  160. package/Libraries/Image/Tests/ImageWin32Test.js.map +1 -1
  161. package/Libraries/Image/resolveAssetSource.js +59 -26
  162. package/Libraries/Inspector/ElementProperties.js +26 -52
  163. package/Libraries/Inspector/Inspector.js +122 -186
  164. package/Libraries/Inspector/Inspector.win32.js +118 -185
  165. package/Libraries/Inspector/InspectorOverlay.js +21 -33
  166. package/Libraries/Inspector/InspectorOverlay.win32.js +22 -33
  167. package/Libraries/Inspector/InspectorPanel.js +3 -17
  168. package/Libraries/Inspector/ReactDevToolsOverlay.js +171 -0
  169. package/Libraries/Inspector/getInspectorDataForViewAtPoint.js +20 -8
  170. package/Libraries/Interaction/FrameRateLogger.js +8 -18
  171. package/Libraries/Interaction/NativeFrameRateLogger.js +4 -16
  172. package/Libraries/IntersectionObserver/IntersectionObserver.js +1 -1
  173. package/Libraries/IntersectionObserver/IntersectionObserverEntry.js +20 -19
  174. package/Libraries/IntersectionObserver/IntersectionObserverManager.js +84 -6
  175. package/Libraries/IntersectionObserver/NativeIntersectionObserver.js +3 -31
  176. package/Libraries/IntersectionObserver/__mocks__/NativeIntersectionObserver.js +12 -2
  177. package/Libraries/LayoutAnimation/LayoutAnimation.js +1 -2
  178. package/Libraries/Linking/NativeIntentAndroid.js +3 -20
  179. package/Libraries/Linking/NativeLinkingManager.js +3 -17
  180. package/Libraries/Lists/FillRateHelper.js +1 -1
  181. package/Libraries/Lists/FlatList.d.ts +2 -2
  182. package/Libraries/Lists/FlatList.js +6 -1
  183. package/Libraries/Lists/SectionList.d.ts +6 -1
  184. package/Libraries/Lists/ViewabilityHelper.js +1 -1
  185. package/Libraries/Lists/VirtualizeUtils.js +1 -1
  186. package/Libraries/Lists/VirtualizedList.js +1 -1
  187. package/Libraries/Lists/VirtualizedListContext.js +1 -1
  188. package/Libraries/Lists/VirtualizedSectionList.js +1 -1
  189. package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
  190. package/Libraries/LogBox/LogBoxInspectorContainer.js +1 -1
  191. package/Libraries/Modal/Modal.js +43 -11
  192. package/Libraries/Modal/NativeModalManager.js +3 -11
  193. package/Libraries/Modal/RCTModalHostViewNativeComponent.js +3 -129
  194. package/Libraries/MutationObserver/MutationObserver.js +1 -1
  195. package/Libraries/MutationObserver/MutationObserverManager.js +2 -2
  196. package/Libraries/MutationObserver/MutationRecord.js +12 -10
  197. package/Libraries/MutationObserver/NativeMutationObserver.js +3 -48
  198. package/Libraries/MutationObserver/__mocks__/NativeMutationObserver.js +1 -1
  199. package/Libraries/NativeComponent/BaseViewConfig.android.js +1 -0
  200. package/Libraries/NativeComponent/NativeComponentRegistry.js +1 -1
  201. package/Libraries/NativeModules/specs/NativeAnimationsDebugModule.js +3 -10
  202. package/Libraries/NativeModules/specs/NativeDevMenu.js +3 -13
  203. package/Libraries/NativeModules/specs/NativeDevSettings.js +3 -23
  204. package/Libraries/NativeModules/specs/NativeDeviceEventManager.js +3 -9
  205. package/Libraries/NativeModules/specs/NativeDialogManagerAndroid.js +3 -38
  206. package/Libraries/NativeModules/specs/NativeLogBox.js +3 -10
  207. package/Libraries/NativeModules/specs/NativeRedBox.js +4 -11
  208. package/Libraries/NativeModules/specs/NativeSourceCode.js +2 -25
  209. package/Libraries/Network/FormData.js +3 -1
  210. package/Libraries/Network/NativeNetworkingAndroid.js +4 -28
  211. package/Libraries/Network/NativeNetworkingIOS.js +4 -28
  212. package/Libraries/Performance/NativeJSCSamplingProfiler.js +3 -9
  213. package/Libraries/PermissionsAndroid/NativePermissionsAndroid.js +4 -68
  214. package/Libraries/PermissionsAndroid/PermissionsAndroid.js +3 -3
  215. package/Libraries/PersonaCoin/PersonaCoin.d.ts +3 -3
  216. package/Libraries/PersonaCoin/PersonaCoin.js +14 -14
  217. package/Libraries/PersonaCoin/PersonaCoin.js.map +1 -1
  218. package/Libraries/PersonaCoin/PersonaCoinPropTypes.d.ts +2 -2
  219. package/Libraries/PersonaCoin/PersonaCoinPropTypes.js +19 -19
  220. package/Libraries/PersonaCoin/PersonaCoinPropTypes.js.map +1 -1
  221. package/Libraries/PersonaCoin/PersonaCoinTypes.d.ts +33 -33
  222. package/Libraries/PersonaCoin/PersonaCoinTypes.js +23 -23
  223. package/Libraries/PersonaCoin/PersonaCoinTypes.js.map +1 -1
  224. package/Libraries/Pressability/Pressability.js +12 -2
  225. package/Libraries/Pressability/Pressability.win32.js +12 -2
  226. package/Libraries/Pressability/usePressability.js +7 -0
  227. package/Libraries/PushNotificationIOS/NativePushNotificationManagerIOS.js +4 -70
  228. package/Libraries/PushNotificationIOS/PushNotificationIOS.js +45 -39
  229. package/Libraries/ReactNative/AppContainer-dev.js +192 -0
  230. package/Libraries/ReactNative/AppContainer-prod.js +53 -0
  231. package/Libraries/ReactNative/AppContainer.js +6 -149
  232. package/Libraries/ReactNative/AppRegistry.js +3 -1
  233. package/Libraries/ReactNative/BridgelessUIManager.js +375 -128
  234. package/Libraries/ReactNative/FabricUIManager.js +6 -0
  235. package/Libraries/ReactNative/NativeHeadlessJsTaskSupport.js +3 -10
  236. package/Libraries/ReactNative/NativeI18nManager.js +3 -18
  237. package/Libraries/ReactNative/NativeUIManager.js +4 -112
  238. package/Libraries/ReactNative/PaperUIManager.js +8 -7
  239. package/Libraries/ReactNative/PaperUIManager.win32.js +26 -7
  240. package/Libraries/ReactNative/ReactFabricInternals.js +1 -1
  241. package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricPublicInstance.js +24 -5
  242. package/Libraries/ReactNative/ReactNativeFeatureFlags.js +0 -45
  243. package/Libraries/ReactNative/RendererImplementation.js +11 -0
  244. package/Libraries/ReactNative/UIManager.d.ts +11 -34
  245. package/Libraries/ReactNative/UIManager.js +2 -23
  246. package/Libraries/ReactNative/UIManagerProperties.js +0 -2
  247. package/Libraries/ReactNative/__mocks__/FabricUIManager.js +23 -1
  248. package/Libraries/ReactNative/getNativeComponentAttributes.js +5 -1
  249. package/Libraries/ReactNative/renderApplication.js +9 -6
  250. package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +6 -1
  251. package/Libraries/Renderer/implementations/ReactFabric-dev.js +24771 -21123
  252. package/Libraries/Renderer/implementations/ReactFabric-prod.js +4160 -3109
  253. package/Libraries/Renderer/implementations/ReactFabric-profiling.js +4384 -3322
  254. package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +25194 -21398
  255. package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +3763 -2636
  256. package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +4027 -2867
  257. package/Libraries/Renderer/shims/ReactNativeTypes.js +8 -9
  258. package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -12
  259. package/Libraries/Settings/NativeSettingsManager.js +4 -16
  260. package/Libraries/Share/NativeShareModule.js +3 -13
  261. package/Libraries/StyleSheet/PlatformColorValueTypes.win32.js +1 -1
  262. package/Libraries/StyleSheet/PlatformColorValueTypesWin32.d.ts +1 -1
  263. package/Libraries/StyleSheet/PlatformColorValueTypesWin32.js +1 -1
  264. package/Libraries/StyleSheet/StyleSheet.d.ts +1 -20
  265. package/Libraries/StyleSheet/StyleSheet.js +5 -28
  266. package/Libraries/StyleSheet/StyleSheet.win32.js +5 -28
  267. package/Libraries/StyleSheet/StyleSheetTypes.d.ts +47 -7
  268. package/Libraries/StyleSheet/StyleSheetTypes.js +16 -11
  269. package/Libraries/StyleSheet/flattenStyle.js +2 -2
  270. package/Libraries/StyleSheet/normalizeColor.js +1 -1
  271. package/Libraries/StyleSheet/processAspectRatio.js +1 -1
  272. package/Libraries/StyleSheet/processFontVariant.js +1 -1
  273. package/Libraries/Text/Text.d.ts +5 -6
  274. package/Libraries/Text/Text.js +0 -6
  275. package/Libraries/Text/Text.win32.js +0 -6
  276. package/Libraries/Text/TextAncestor.js +2 -3
  277. package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +4 -41
  278. package/Libraries/Types/ReactDevToolsTypes.js +58 -0
  279. package/Libraries/Types/UIManagerJSInterface.js +16 -0
  280. package/Libraries/Utilities/DebugEnvironment.js +1 -4
  281. package/Libraries/Utilities/Dimensions.js +8 -16
  282. package/Libraries/Utilities/Dimensions.win32.js +8 -16
  283. package/Libraries/Utilities/FocusManager.win32.js +2 -0
  284. package/Libraries/Utilities/GlobalPerformanceLogger.js +1 -2
  285. package/Libraries/Utilities/NativeAppearance.js +3 -26
  286. package/Libraries/Utilities/NativeDevLoadingView.js +3 -14
  287. package/Libraries/Utilities/NativeDeviceInfo.js +2 -47
  288. package/Libraries/Utilities/NativePlatformConstantsAndroid.js +3 -34
  289. package/Libraries/Utilities/NativePlatformConstantsIOS.js +3 -26
  290. package/Libraries/Utilities/NativePlatformConstantsWin.js +3 -23
  291. package/Libraries/Utilities/PixelRatio.d.ts +4 -4
  292. package/Libraries/Utilities/Platform.android.js +4 -0
  293. package/Libraries/Utilities/Platform.d.ts +3 -0
  294. package/Libraries/Utilities/Platform.flow.js +7 -0
  295. package/Libraries/Utilities/Platform.flow.win32.js +18 -5
  296. package/Libraries/Utilities/Platform.ios.js +11 -0
  297. package/Libraries/Utilities/Platform.win32.js +9 -1
  298. package/Libraries/Utilities/binaryToBase64.js +1 -1
  299. package/Libraries/Utilities/codegenNativeComponent.js +4 -6
  300. package/Libraries/Utilities/createPerformanceLogger.js +2 -74
  301. package/Libraries/Utilities/useMergeRefs.js +5 -9
  302. package/Libraries/Vibration/NativeVibration.js +3 -14
  303. package/Libraries/WebSocket/NativeWebSocketModule.js +4 -25
  304. package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
  305. package/Libraries/platform-types.d.ts +2 -3
  306. package/Libraries/vendor/emitter/EventEmitter.js +1 -0
  307. package/babel.config.js +1 -1
  308. package/flow/jest.js +1 -1
  309. package/flow/react.js +15 -0
  310. package/index.js +66 -99
  311. package/index.win32.js +60 -101
  312. package/jest/assetFileTransformer.js +1 -1
  313. package/jest/local-setup.js +0 -5
  314. package/jest/mockModal.js +2 -1
  315. package/jest/mockScrollView.js +1 -2
  316. package/jest/renderer.js +1 -1
  317. package/jest/setup.js +6 -3
  318. package/jest.config.js +2 -1
  319. package/overrides.json +152 -131
  320. package/package.json +26 -26
  321. package/{Libraries/Core → src/private/core}/setUpDOM.js +2 -2
  322. package/src/private/featureflags/NativeReactNativeFeatureFlags.js +42 -0
  323. package/src/private/featureflags/ReactNativeFeatureFlags.js +140 -0
  324. package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +84 -0
  325. package/src/private/featureflags/__tests__/ReactNativeFeatureFlags-test.js +92 -0
  326. package/src/private/specs/components/ActivityIndicatorViewNativeComponent.js +53 -0
  327. package/src/private/specs/components/AndroidDrawerLayoutNativeComponent.js +124 -0
  328. package/src/private/specs/components/AndroidHorizontalScrollContentViewNativeComponent.js +26 -0
  329. package/src/private/specs/components/AndroidSwipeRefreshLayoutNativeComponent.js +74 -0
  330. package/src/private/specs/components/AndroidSwitchNativeComponent.js +62 -0
  331. package/src/private/specs/components/DebuggingOverlayNativeComponent.js +61 -0
  332. package/src/private/specs/components/PopupMenuAndroidNativeComponent.js +47 -0
  333. package/src/private/specs/components/ProgressBarAndroidNativeComponent.js +36 -0
  334. package/src/private/specs/components/PullToRefreshViewNativeComponent.js +71 -0
  335. package/src/private/specs/components/RCTInputAccessoryViewNativeComponent.js +26 -0
  336. package/src/private/specs/components/RCTModalHostViewNativeComponent.js +139 -0
  337. package/src/private/specs/components/RCTSafeAreaViewNativeComponent.js +25 -0
  338. package/src/private/specs/components/SwitchNativeComponent.js +61 -0
  339. package/src/private/specs/components/UnimplementedNativeViewNativeComponent.js +26 -0
  340. package/src/private/specs/modules/NativeAccessibilityInfo.js +33 -0
  341. package/src/private/specs/modules/NativeAccessibilityInfoWin32.js +39 -0
  342. package/src/private/specs/modules/NativeAccessibilityManager.js +66 -0
  343. package/src/private/specs/modules/NativeActionSheetManager.js +54 -0
  344. package/src/private/specs/modules/NativeAlertManager.js +35 -0
  345. package/src/private/specs/modules/NativeAnimatedModule.js +77 -0
  346. package/src/private/specs/modules/NativeAnimatedTurboModule.js +78 -0
  347. package/src/private/specs/modules/NativeAnimationsDebugModule.js +20 -0
  348. package/src/private/specs/modules/NativeAppState.js +33 -0
  349. package/src/private/specs/modules/NativeAppearance.js +36 -0
  350. package/src/private/specs/modules/NativeBlobModule.js +59 -0
  351. package/src/private/specs/modules/NativeBugReporting.js +20 -0
  352. package/src/private/specs/modules/NativeClipboard.js +21 -0
  353. package/src/private/specs/modules/NativeDevLoadingView.js +24 -0
  354. package/src/private/specs/modules/NativeDevMenu.js +23 -0
  355. package/src/private/specs/modules/NativeDevSettings.js +33 -0
  356. package/src/private/specs/modules/NativeDevToolsSettingsManager.js +24 -0
  357. package/src/private/specs/modules/NativeDeviceEventManager.js +19 -0
  358. package/src/private/specs/modules/NativeDeviceInfo.js +58 -0
  359. package/src/private/specs/modules/NativeDialogManagerAndroid.js +48 -0
  360. package/src/private/specs/modules/NativeExceptionsManager.js +103 -0
  361. package/src/private/specs/modules/NativeFileReaderModule.js +22 -0
  362. package/src/private/specs/modules/NativeFrameRateLogger.js +22 -0
  363. package/src/private/specs/modules/NativeHeadlessJsTaskSupport.js +20 -0
  364. package/src/private/specs/modules/NativeI18nManager.js +28 -0
  365. package/src/private/specs/modules/NativeImageEditor.js +52 -0
  366. package/src/private/specs/modules/NativeImageLoaderAndroid.js +30 -0
  367. package/src/private/specs/modules/NativeImageLoaderIOS.js +37 -0
  368. package/src/private/specs/modules/NativeImageLoaderWin32.js +45 -0
  369. package/src/private/specs/modules/NativeImageStoreAndroid.js +26 -0
  370. package/src/private/specs/modules/NativeImageStoreIOS.js +33 -0
  371. package/src/private/specs/modules/NativeIntentAndroid.js +30 -0
  372. package/src/private/specs/modules/NativeIntersectionObserver.js +41 -0
  373. package/src/private/specs/modules/NativeJSCHeapCapture.js +19 -0
  374. package/src/private/specs/modules/NativeJSCSamplingProfiler.js +19 -0
  375. package/src/private/specs/modules/NativeKeyboardObserver.js +20 -0
  376. package/src/private/specs/modules/NativeLinkingManager.js +27 -0
  377. package/src/private/specs/modules/NativeLogBox.js +20 -0
  378. package/src/private/specs/modules/NativeModalManager.js +21 -0
  379. package/src/private/specs/modules/NativeMutationObserver.js +58 -0
  380. package/src/private/specs/modules/NativeNetworkingAndroid.js +37 -0
  381. package/src/private/specs/modules/NativeNetworkingIOS.js +37 -0
  382. package/src/private/specs/modules/NativePermissionsAndroid.js +77 -0
  383. package/src/private/specs/modules/NativePlatformConstantsAndroid.js +44 -0
  384. package/src/private/specs/modules/NativePlatformConstantsIOS.js +37 -0
  385. package/src/private/specs/modules/NativePlatformConstantsWin.js +37 -0
  386. package/src/private/specs/modules/NativePushNotificationManagerIOS.js +107 -0
  387. package/src/private/specs/modules/NativeRedBox.js +20 -0
  388. package/src/private/specs/modules/NativeSampleTurboModule.js +53 -0
  389. package/src/private/specs/modules/NativeSegmentFetcher.js +28 -0
  390. package/src/private/specs/modules/NativeSettingsManager.js +25 -0
  391. package/src/private/specs/modules/NativeShareModule.js +23 -0
  392. package/src/private/specs/modules/NativeSoundManager.js +22 -0
  393. package/src/private/specs/modules/NativeSourceCode.js +36 -0
  394. package/src/private/specs/modules/NativeStatusBarManagerAndroid.js +68 -0
  395. package/src/private/specs/modules/NativeStatusBarManagerIOS.js +89 -0
  396. package/src/private/specs/modules/NativeTiming.js +26 -0
  397. package/src/private/specs/modules/NativeToastAndroid.js +38 -0
  398. package/src/private/specs/modules/NativeUIManager.js +118 -0
  399. package/src/private/specs/modules/NativeVibration.js +24 -0
  400. package/src/private/specs/modules/NativeWebSocketModule.js +34 -0
  401. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReactNativeElement.js +6 -6
  402. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyCharacterData.js +2 -2
  403. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyElement.js +5 -5
  404. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyNode.js +19 -10
  405. package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/DOMRectList.js +1 -1
  406. package/src/private/webapis/dom/oldstylecollections/__tests__/DOMRectList-test.js +85 -0
  407. package/src/private/webapis/dom/oldstylecollections/__tests__/HTMLCollection-test.js +80 -0
  408. package/src/private/webapis/dom/oldstylecollections/__tests__/NodeList-test.js +161 -0
  409. package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformance.js +2 -2
  410. package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformanceObserver.js +3 -2
  411. package/{Libraries/WebPerformance → src/private/webapis/performance}/Performance.js +2 -2
  412. package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEventTiming.js +1 -1
  413. package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceObserver.js +21 -2
  414. package/{Libraries/WebPerformance → src/private/webapis/performance}/RawPerformanceEntry.js +1 -1
  415. package/{Libraries/WebPerformance → src/private/webapis/performance}/__mocks__/NativePerformanceObserver.js +9 -0
  416. package/src/private/webapis/performance/__tests__/EventCounts-test.js +116 -0
  417. package/src/private/webapis/performance/__tests__/NativePerformanceMock-test.js +82 -0
  418. package/src/private/webapis/performance/__tests__/NativePerformanceObserverMock-test.js +108 -0
  419. package/src/private/webapis/performance/__tests__/Performance-test.js +117 -0
  420. package/src/private/webapis/performance/__tests__/PerformanceObserver-test.js +208 -0
  421. package/src-win/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +161 -0
  422. package/{src → src-win}/Libraries/Components/Button/ButtonWin32.tsx +3 -3
  423. package/{src → src-win}/Libraries/Components/Touchable/Tests/TouchableWin32Test.tsx +9 -10
  424. package/{src → src-win}/Libraries/Components/View/ViewAccessibility.d.ts +33 -17
  425. package/{src → src-win}/Libraries/Components/View/ViewPropTypes.d.ts +28 -17
  426. package/{src → src-win}/Libraries/StyleSheet/PlatformColorValueTypesWin32.d.ts +1 -1
  427. package/{src → src-win}/Libraries/Text/Text.d.ts +5 -6
  428. package/{src → src-win}/Libraries/platform-types.d.ts +2 -3
  429. package/types/modules/globals.d.ts +1 -0
  430. package/Libraries/Components/Button.flow.js +0 -265
  431. package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +0 -85
  432. package/Libraries/Components/Text/TextWin32.Props.d.ts +0 -63
  433. package/Libraries/Components/Text/TextWin32.Props.js +0 -3
  434. package/Libraries/Components/Text/TextWin32.Props.js.map +0 -1
  435. package/Libraries/Components/Text/TextWin32.d.ts +0 -6
  436. package/Libraries/Components/Text/TextWin32.js +0 -18
  437. package/Libraries/Components/Text/TextWin32.js.map +0 -1
  438. package/Libraries/Components/Touchable/Touchable.flow.js +0 -284
  439. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +0 -189
  440. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +0 -43
  441. package/Libraries/Image/Image.flow.js +0 -64
  442. package/Libraries/Inspector/DevtoolsOverlay.js +0 -223
  443. package/Libraries/Performance/QuickPerformanceLogger.js +0 -142
  444. package/src/Libraries/Components/Text/TextWin32.Props.ts +0 -82
  445. package/src/Libraries/Components/Text/TextWin32.tsx +0 -25
  446. /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRect.js +0 -0
  447. /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRectReadOnly.js +0 -0
  448. /package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyText.js +0 -0
  449. /package/{Libraries/DOM/Nodes/Utilities → src/private/webapis/dom/nodes/utilities}/Traversal.js +0 -0
  450. /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/ArrayLikeUtils.js +0 -0
  451. /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/HTMLCollection.js +0 -0
  452. /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/NodeList.js +0 -0
  453. /package/{Libraries/WebPerformance → src/private/webapis/performance}/EventCounts.js +0 -0
  454. /package/{Libraries/WebPerformance → src/private/webapis/performance}/MemoryInfo.js +0 -0
  455. /package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEntry.js +0 -0
  456. /package/{Libraries/WebPerformance → src/private/webapis/performance}/ReactNativeStartupTiming.js +0 -0
  457. /package/{Libraries/WebPerformance → src/private/webapis/performance}/__mocks__/NativePerformance.js +0 -0
  458. /package/{src → src-win}/Libraries/Components/Button/ButtonWin32.Props.ts +0 -0
  459. /package/{src → src-win}/Libraries/Components/EnterString.win32.tsx +0 -0
  460. /package/{src → src-win}/Libraries/Components/TextInput/Tests/TextInputTest.tsx +0 -0
  461. /package/{src → src-win}/Libraries/Components/Touchable/TouchableNativeFeedback.d.ts +0 -0
  462. /package/{src → src-win}/Libraries/Components/Touchable/TouchableWin32.Props.tsx +0 -0
  463. /package/{src → src-win}/Libraries/Components/Touchable/TouchableWin32.Types.tsx +0 -0
  464. /package/{src → src-win}/Libraries/Components/Touchable/TouchableWin32.tsx +0 -0
  465. /package/{src → src-win}/Libraries/Components/View/ViewWin32.d.ts +0 -0
  466. /package/{src → src-win}/Libraries/Image/ImageTypes.ts +0 -0
  467. /package/{src → src-win}/Libraries/Image/Tests/ImageWin32Test.tsx +0 -0
  468. /package/{src → src-win}/Libraries/Image/Tests/img/dpitest.png +0 -0
  469. /package/{src → src-win}/Libraries/Image/Tests/img/dpitest@1.5x.png +0 -0
  470. /package/{src → src-win}/Libraries/Image/Tests/img/dpitest@2x.png +0 -0
  471. /package/{src → src-win}/Libraries/Image/Tests/img/dpitest@3x.png +0 -0
  472. /package/{src → src-win}/Libraries/Image/Tests/img/en-us/dpitest.png +0 -0
  473. /package/{src → src-win}/Libraries/Image/Tests/img/en-us/dpitest@1.5x.png +0 -0
  474. /package/{src → src-win}/Libraries/Image/Tests/img/en-us/dpitest@3x.png +0 -0
  475. /package/{src → src-win}/Libraries/PersonaCoin/PersonaCoin.tsx +0 -0
  476. /package/{src → src-win}/Libraries/PersonaCoin/PersonaCoinPropTypes.ts +0 -0
  477. /package/{src → src-win}/Libraries/PersonaCoin/PersonaCoinTypes.ts +0 -0
  478. /package/{src → src-win}/Libraries/Utilities/FocusManager.win32.d.ts +0 -0
  479. /package/{src → src-win}/Libraries/__tests__/__snapshots__/ButtonWin32-test.js.snap +0 -0
@@ -1,345 +1,344 @@
1
- 'use strict';
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.examples = exports.description = exports.title = exports.displayName = void 0;
7
- const react_1 = __importDefault(require("react"));
8
- const react_native_1 = require("react-native");
9
- const TextWin32_1 = require("../../Text/TextWin32");
10
- const ViewWin32_1 = require("../../View/ViewWin32");
11
- const TouchableWin32_1 = require("../TouchableWin32");
12
- /**
13
- * Styles used across both examples
14
- */
15
- const styles = react_native_1.StyleSheet.create({
16
- largeContainer: {
17
- height: 200,
18
- width: 600,
19
- justifyContent: 'space-between',
20
- alignItems: 'center',
21
- flexDirection: 'row',
22
- },
23
- smallContainer: {
24
- height: 90,
25
- width: 90,
26
- justifyContent: 'center',
27
- alignContent: 'center',
28
- },
29
- highlight: {
30
- height: 150,
31
- width: 150,
32
- justifyContent: 'space-around',
33
- alignContent: 'center',
34
- alignItems: 'center',
35
- flexDirection: 'row',
36
- },
37
- outerTouch: {
38
- height: 150,
39
- width: 150,
40
- justifyContent: 'space-around',
41
- alignContent: 'center',
42
- alignItems: 'center',
43
- flexDirection: 'row',
44
- },
45
- innerTouch: {
46
- height: 90,
47
- width: 90,
48
- alignItems: 'center',
49
- justifyContent: 'center',
50
- },
51
- });
52
- /**
53
- * Constant press rect offset, used to demonstrate press geometry
54
- */
55
- const PRESS_RETENTION_OFFSET = {
56
- top: 100,
57
- left: 100,
58
- right: 100,
59
- bottom: 100,
60
- };
61
- /**
62
- * Example implementation of TouchableWithoutFeedback - not meant for use outside these examples
63
- * This is mainly there to show the ability to respond to touches without providing visual feedback,
64
- * though we do show a red border on focus to know where starts start and end and whether press rect
65
- * offsets are respected.
66
- */
67
- class TouchableWin32WithoutFeedback extends react_1.default.Component {
68
- constructor(props) {
69
- super(props);
70
- this._touchableHandlePress = (e) => {
71
- this.props.onPress && this.props.onPress(e);
72
- };
73
- this._touchableHandleActivePressIn = (e) => {
74
- this.props.onPressIn && this.props.onPressIn(e);
75
- };
76
- this._touchableHandleActivePressOut = (e) => {
77
- this.props.onPressOut && this.props.onPressOut(e);
78
- };
79
- this._touchableHandleLongPress = (e) => {
80
- this.props.onLongPress && this.props.onLongPress(e);
81
- };
82
- this._touchableGetPressRectOffset = () => {
83
- return this.props.pressRetentionOffset || PRESS_RETENTION_OFFSET;
84
- };
85
- this._touchableGetHitSlop = () => {
86
- return this.props.hitSlop;
87
- };
88
- this._touchableGetHighlightDelayMS = () => {
89
- return this.props.delayPressIn || 0;
90
- };
91
- this._touchableGetLongPressDelayMS = () => {
92
- return this.props.delayLongPress === 0 ? 0 : this.props.delayLongPress || 500;
93
- };
94
- this._touchableGetPressOutDelayMS = () => {
95
- return this.props.delayPressOut || 0;
96
- };
97
- this._onFocus = () => {
98
- this.setState({ isFocused: true });
99
- };
100
- this._onBlur = () => {
101
- this.setState({ isFocused: false });
102
- };
103
- /**
104
- * The generated style uses hard-coded border width values
105
- */
106
- this._generateStyle = (state) => {
107
- const finalStyle = {
108
- borderWidth: state.isFocused ? 5 : 0,
109
- borderColor: 'red',
110
- };
111
- return Object.assign({}, this.props.style, finalStyle);
112
- };
113
- this.state = { isFocused: false };
114
- }
115
- render() {
116
- return (react_1.default.createElement(TouchableWin32_1.TouchableWin32, { focusable: true, rejectResponderTermination: true, disabled: false, touchableHandleActivePressIn: this._touchableHandleActivePressIn, touchableHandleActivePressOut: this._touchableHandleActivePressOut, touchableHandlePress: this._touchableHandlePress, touchableHandleLongPress: this._touchableHandleLongPress, touchableGetHighlightDelayMS: this._touchableGetHighlightDelayMS, touchableGetPressRectOffset: this._touchableGetPressRectOffset, touchableGetLongPressDelayMS: this._touchableGetLongPressDelayMS, touchableGetPressOutDelayMS: this._touchableGetPressOutDelayMS, touchableGetHitSlop: this._touchableGetHitSlop, onFocus: this._onFocus, onBlur: this._onBlur, renderStyle: this._generateStyle }, react_1.default.Children.only(this.props.children)));
117
- }
118
- }
119
- /**
120
- * Example implementation of TouchableHighlight - not meant for use outside these examples
121
- * The main difference between a full TouchableHighlight implementation and this example is that
122
- * TouchableHighlight should manipulate the opacity of the wrapped view to display the underlay color.
123
- * This example merely uses hard coded color values to distinguish between different control states
124
- */
125
- class TouchableWin32HighlightComponent extends react_1.default.Component {
126
- constructor() {
127
- super(...arguments);
128
- this._touchableHandlePress = (e) => {
129
- this.props.onPress && this.props.onPress(e);
130
- this.setState({ isPressed: false });
131
- };
132
- this._touchableHandleActivePressIn = (e) => {
133
- this.props.onPressIn && this.props.onPressIn(e);
134
- this.setState({ isPressed: true });
135
- };
136
- this._touchableHandleActivePressOut = (e) => {
137
- this.props.onPressOut && this.props.onPressOut(e);
138
- this.setState({ isPressed: false });
139
- };
140
- this._touchableHandleLongPress = (e) => {
141
- this.props.onLongPress && this.props.onLongPress(e);
142
- };
143
- this._touchableGetPressRectOffset = () => {
144
- return this.props.pressRetentionOffset || PRESS_RETENTION_OFFSET;
145
- };
146
- this._touchableGetHitSlop = () => {
147
- return { left: 100, right: 100, top: 100, bottom: 100 };
148
- };
149
- this._touchableGetHighlightDelayMS = () => {
150
- return this.props.delayLongPressIn || 0;
151
- };
152
- this._touchableGetLongPressDelayMS = () => {
153
- return this.props.delayLongPress || 500;
154
- };
155
- this._touchableGetPressOutDelayMS = () => {
156
- return this.props.delayPressOut || 0;
157
- };
158
- this._touchableHandleKeyPress = (ev) => {
159
- this.props.onKeyPress && this.props.onKeyPress(ev);
160
- };
161
- this._touchableHandleKeyPressDown = (ev) => {
162
- this.props.onKeyPressDown && this.props.onKeyPressDown(ev);
163
- };
164
- this._mouseEnter = (mouseEvent) => {
165
- this.props.onMouseEnter && this.props.onMouseEnter(mouseEvent);
166
- this.setState({ isMouseIn: true });
167
- };
168
- this._mouseLeave = (mouseEvent) => {
169
- this.props.onMouseLeave && this.props.onMouseLeave(mouseEvent);
170
- this.setState({ isMouseIn: false });
171
- };
172
- this._onFocus = (ev) => {
173
- this.props.onFocus && this.props.onFocus(ev);
174
- this.setState({ isFocused: true });
175
- };
176
- this._onBlur = (ev) => {
177
- this.props.onBlur && this.props.onBlur(ev);
178
- this.setState({ isFocused: false });
179
- };
180
- /**
181
- * The generated style uses hard-coded color values,
182
- * though it is trivial to pass these values as props.
183
- * This is an example of a render style (one that is a
184
- * function passed on to TouchableWin32 and resolved according
185
- * to the internal state of TouchableWin32).
186
- */
187
- this._generateStyle = (state) => {
188
- const finalStyle = {};
189
- finalStyle.borderColor = state.isFocused ? 'red' : 'blue';
190
- finalStyle.borderWidth = state.isFocused ? 10 : 5;
191
- if (state.isHovered) {
192
- if (state.isPressed) {
193
- finalStyle.backgroundColor = 'black';
194
- }
195
- else {
196
- finalStyle.backgroundColor = 'gray';
197
- }
198
- }
199
- else {
200
- if (state.isPressed) {
201
- finalStyle.backgroundColor = 'green';
202
- }
203
- else {
204
- finalStyle.backgroundColor = 'white';
205
- }
206
- }
207
- return Object.assign({}, this.props.style, finalStyle);
208
- };
209
- }
210
- render() {
211
- return (react_1.default.createElement(TouchableWin32_1.TouchableWin32, { focusable: true, rejectResponderTermination: this.props.rejectResponderTermination, disabled: false, touchableHandleActivePressIn: this._touchableHandleActivePressIn, touchableHandleActivePressOut: this._touchableHandleActivePressOut, touchableHandlePress: this._touchableHandlePress, touchableHandleLongPress: this._touchableHandleLongPress, touchableGetHighlightDelayMS: this._touchableGetHighlightDelayMS, touchableGetPressRectOffset: this._touchableGetPressRectOffset, touchableGetLongPressDelayMS: this._touchableGetLongPressDelayMS, touchableGetPressOutDelayMS: this._touchableGetPressOutDelayMS, touchableGetHitSlop: this._touchableGetHitSlop, touchableHandleKeyPress: this._touchableHandleKeyPress, touchableHandleKeyPressDown: this._touchableHandleKeyPressDown, onFocus: this._onFocus, onBlur: this._onBlur, onMouseEnter: this._mouseEnter, onMouseLeave: this._mouseLeave, renderStyle: this._generateStyle, children: this.props.children, ref: this.props.innerRef }));
212
- }
213
- }
214
- // Demonstrating ref forwarding - forwarding a ref using an innerRef prop on a class component
215
- const TouchableWin32Highlight = react_1.default.forwardRef((props, ref) => {
216
- return (react_1.default.createElement(TouchableWin32HighlightComponent, { innerRef: ref, ...props }));
217
- });
218
- /**
219
- * TouchableHighlightExamples
220
- */
221
- class TouchableWithoutFeedbackExample extends react_1.default.Component {
222
- constructor(props) {
223
- super(props);
224
- this._onPress = () => {
225
- this.setState({ numberOfPresses: this.state.numberOfPresses + 1 });
226
- };
227
- this.state = { numberOfPresses: 0 };
228
- }
229
- render() {
230
- return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.largeContainer },
231
- react_1.default.createElement(TouchableWin32WithoutFeedback, { style: styles.outerTouch, onPress: this._onPress },
232
- react_1.default.createElement(ViewWin32_1.ViewWin32, null,
233
- react_1.default.createElement(TextWin32_1.TextWin32, null, "Press me"))),
234
- react_1.default.createElement(TouchableWin32WithoutFeedback, { style: styles.outerTouch, onPress: this._onPress },
235
- react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.smallContainer },
236
- react_1.default.createElement(TouchableWin32WithoutFeedback, { style: styles.innerTouch, onPress: this._onPress },
237
- react_1.default.createElement(ViewWin32_1.ViewWin32, null,
238
- react_1.default.createElement(TextWin32_1.TextWin32, null, "You can also have nested Touchables"))))),
239
- react_1.default.createElement(TextWin32_1.TextWin32, null, 'Number of Recognized Presses: ' + this.state.numberOfPresses)));
240
- }
241
- }
242
- /**
243
- * TouchableHighlightExamples
244
- */
245
- class TouchableHighlightExample extends react_1.default.Component {
246
- constructor(props) {
247
- super(props);
248
- /**
249
- * This is primarily to demonstrate render children as a function
250
- * of state, here we change text color depending on interaction state.
251
- */
252
- this._getChildrenOfInnerTouchable = (state) => {
253
- return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: {
254
- borderColor: state.isFocused ? 'green' : 'pink',
255
- borderWidth: state.isHovered ? 10 : 5,
256
- height: 70,
257
- width: 70,
258
- } },
259
- react_1.default.createElement(TextWin32_1.TextWin32, { style: {
260
- color: this._pickColor(state.isHovered, state.isPressed),
261
- fontSize: state.isFocused ? 8 : 10,
262
- }, textStyle: "None" }, "Press Me!")));
263
- };
264
- this._onPress = () => {
265
- this.setState({ numberOfPresses: this.state.numberOfPresses + 1 });
266
- };
267
- this.state = { numberOfPresses: 0 };
268
- }
269
- render() {
270
- return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.largeContainer },
271
- react_1.default.createElement(TouchableWin32Highlight, { style: styles.outerTouch, onPress: this._onPress },
272
- react_1.default.createElement(ViewWin32_1.ViewWin32, null,
273
- react_1.default.createElement(TextWin32_1.TextWin32, null, "Press me"))),
274
- react_1.default.createElement(TouchableWin32Highlight, { style: styles.outerTouch, onPress: this._onPress },
275
- react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.smallContainer },
276
- react_1.default.createElement(TouchableWin32Highlight, { style: styles.innerTouch, onPress: this._onPress, children: this._getChildrenOfInnerTouchable }))),
277
- react_1.default.createElement(TextWin32_1.TextWin32, { style: { color: 'red' }, textStyle: "None" }, 'Number of Recognized Presses: ' + this.state.numberOfPresses)));
278
- }
279
- _pickColor(hovered, pressed) {
280
- if (hovered) {
281
- if (pressed) {
282
- return 'white';
283
- }
284
- else {
285
- return 'red';
286
- }
287
- }
288
- else {
289
- if (pressed) {
290
- return 'purple';
291
- }
292
- else {
293
- return 'black';
294
- }
295
- }
296
- }
297
- }
298
- const TouchableFocusExample = () => {
299
- const [focused, setFocused] = react_1.default.useState(false);
300
- const focusableRef = react_1.default.useRef(null);
301
- // onPress callback
302
- const focusOnPress = react_1.default.useCallback(() => {
303
- focusableRef.current && focusableRef.current.focus();
304
- focused || setFocused(true);
305
- }, [focused]);
306
- // onFocus and onBlur callbacks
307
- const onFocus = react_1.default.useCallback(() => {
308
- setFocused(true);
309
- }, []);
310
- const onBlur = react_1.default.useCallback(() => {
311
- setFocused(false);
312
- }, []);
313
- return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.largeContainer },
314
- react_1.default.createElement(TouchableWin32Highlight, { onPress: focusOnPress },
315
- react_1.default.createElement(react_native_1.Text, null, "Press me to focus my friend")),
316
- react_1.default.createElement(TouchableWin32Highlight, { ref: focusableRef, onFocus: onFocus, onBlur: onBlur },
317
- react_1.default.createElement(react_native_1.Text, null, 'Focused: ' + focused))));
318
- };
319
- exports.displayName = 'TouchableWin32 Examples';
320
- exports.title = 'TouchableWin32';
321
- exports.description = 'Demonstration of touchable + focus + hover behavior all in one component';
322
- exports.examples = [
323
- {
324
- title: 'TouchableWithoutFeedback Example',
325
- description: 'A simple example implementation of without feedback behavior',
326
- render() {
327
- return react_1.default.createElement(TouchableWithoutFeedbackExample, null);
328
- },
329
- },
330
- {
331
- title: 'TouchableHighlight Example',
332
- description: 'A simple example implementation of highlight behavior',
333
- render() {
334
- return react_1.default.createElement(TouchableHighlightExample, null);
335
- },
336
- },
337
- {
338
- title: 'Imperative Focus on TouchableWin32 Example',
339
- description: 'A simple example implementation of imperative focus behavior',
340
- render() {
341
- return react_1.default.createElement(TouchableFocusExample, null);
342
- },
343
- }
344
- ];
1
+ 'use strict';
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.examples = exports.description = exports.title = exports.displayName = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const react_native_1 = require("react-native");
9
+ const ViewWin32_1 = require("../../View/ViewWin32");
10
+ const TouchableWin32_1 = require("../TouchableWin32");
11
+ /**
12
+ * Styles used across both examples
13
+ */
14
+ const styles = react_native_1.StyleSheet.create({
15
+ largeContainer: {
16
+ height: 200,
17
+ width: 600,
18
+ justifyContent: 'space-between',
19
+ alignItems: 'center',
20
+ flexDirection: 'row',
21
+ },
22
+ smallContainer: {
23
+ height: 90,
24
+ width: 90,
25
+ justifyContent: 'center',
26
+ alignContent: 'center',
27
+ },
28
+ highlight: {
29
+ height: 150,
30
+ width: 150,
31
+ justifyContent: 'space-around',
32
+ alignContent: 'center',
33
+ alignItems: 'center',
34
+ flexDirection: 'row',
35
+ },
36
+ outerTouch: {
37
+ height: 150,
38
+ width: 150,
39
+ justifyContent: 'space-around',
40
+ alignContent: 'center',
41
+ alignItems: 'center',
42
+ flexDirection: 'row',
43
+ },
44
+ innerTouch: {
45
+ height: 90,
46
+ width: 90,
47
+ alignItems: 'center',
48
+ justifyContent: 'center',
49
+ },
50
+ });
51
+ /**
52
+ * Constant press rect offset, used to demonstrate press geometry
53
+ */
54
+ const PRESS_RETENTION_OFFSET = {
55
+ top: 100,
56
+ left: 100,
57
+ right: 100,
58
+ bottom: 100,
59
+ };
60
+ /**
61
+ * Example implementation of TouchableWithoutFeedback - not meant for use outside these examples
62
+ * This is mainly there to show the ability to respond to touches without providing visual feedback,
63
+ * though we do show a red border on focus to know where starts start and end and whether press rect
64
+ * offsets are respected.
65
+ */
66
+ class TouchableWin32WithoutFeedback extends react_1.default.Component {
67
+ constructor(props) {
68
+ super(props);
69
+ this._touchableHandlePress = (e) => {
70
+ this.props.onPress && this.props.onPress(e);
71
+ };
72
+ this._touchableHandleActivePressIn = (e) => {
73
+ this.props.onPressIn && this.props.onPressIn(e);
74
+ };
75
+ this._touchableHandleActivePressOut = (e) => {
76
+ this.props.onPressOut && this.props.onPressOut(e);
77
+ };
78
+ this._touchableHandleLongPress = (e) => {
79
+ this.props.onLongPress && this.props.onLongPress(e);
80
+ };
81
+ this._touchableGetPressRectOffset = () => {
82
+ return this.props.pressRetentionOffset || PRESS_RETENTION_OFFSET;
83
+ };
84
+ this._touchableGetHitSlop = () => {
85
+ return this.props.hitSlop;
86
+ };
87
+ this._touchableGetHighlightDelayMS = () => {
88
+ return this.props.delayPressIn || 0;
89
+ };
90
+ this._touchableGetLongPressDelayMS = () => {
91
+ return this.props.delayLongPress === 0 ? 0 : this.props.delayLongPress || 500;
92
+ };
93
+ this._touchableGetPressOutDelayMS = () => {
94
+ return this.props.delayPressOut || 0;
95
+ };
96
+ this._onFocus = () => {
97
+ this.setState({ isFocused: true });
98
+ };
99
+ this._onBlur = () => {
100
+ this.setState({ isFocused: false });
101
+ };
102
+ /**
103
+ * The generated style uses hard-coded border width values
104
+ */
105
+ this._generateStyle = (state) => {
106
+ const finalStyle = {
107
+ borderWidth: state.isFocused ? 5 : 0,
108
+ borderColor: 'red',
109
+ };
110
+ return Object.assign({}, this.props.style, finalStyle);
111
+ };
112
+ this.state = { isFocused: false };
113
+ }
114
+ render() {
115
+ return (react_1.default.createElement(TouchableWin32_1.TouchableWin32, { focusable: true, rejectResponderTermination: true, disabled: false, touchableHandleActivePressIn: this._touchableHandleActivePressIn, touchableHandleActivePressOut: this._touchableHandleActivePressOut, touchableHandlePress: this._touchableHandlePress, touchableHandleLongPress: this._touchableHandleLongPress, touchableGetHighlightDelayMS: this._touchableGetHighlightDelayMS, touchableGetPressRectOffset: this._touchableGetPressRectOffset, touchableGetLongPressDelayMS: this._touchableGetLongPressDelayMS, touchableGetPressOutDelayMS: this._touchableGetPressOutDelayMS, touchableGetHitSlop: this._touchableGetHitSlop, onFocus: this._onFocus, onBlur: this._onBlur, renderStyle: this._generateStyle }, react_1.default.Children.only(this.props.children)));
116
+ }
117
+ }
118
+ /**
119
+ * Example implementation of TouchableHighlight - not meant for use outside these examples
120
+ * The main difference between a full TouchableHighlight implementation and this example is that
121
+ * TouchableHighlight should manipulate the opacity of the wrapped view to display the underlay color.
122
+ * This example merely uses hard coded color values to distinguish between different control states
123
+ */
124
+ class TouchableWin32HighlightComponent extends react_1.default.Component {
125
+ constructor() {
126
+ super(...arguments);
127
+ this._touchableHandlePress = (e) => {
128
+ this.props.onPress && this.props.onPress(e);
129
+ this.setState({ isPressed: false });
130
+ };
131
+ this._touchableHandleActivePressIn = (e) => {
132
+ this.props.onPressIn && this.props.onPressIn(e);
133
+ this.setState({ isPressed: true });
134
+ };
135
+ this._touchableHandleActivePressOut = (e) => {
136
+ this.props.onPressOut && this.props.onPressOut(e);
137
+ this.setState({ isPressed: false });
138
+ };
139
+ this._touchableHandleLongPress = (e) => {
140
+ this.props.onLongPress && this.props.onLongPress(e);
141
+ };
142
+ this._touchableGetPressRectOffset = () => {
143
+ return this.props.pressRetentionOffset || PRESS_RETENTION_OFFSET;
144
+ };
145
+ this._touchableGetHitSlop = () => {
146
+ return { left: 100, right: 100, top: 100, bottom: 100 };
147
+ };
148
+ this._touchableGetHighlightDelayMS = () => {
149
+ return this.props.delayLongPressIn || 0;
150
+ };
151
+ this._touchableGetLongPressDelayMS = () => {
152
+ return this.props.delayLongPress || 500;
153
+ };
154
+ this._touchableGetPressOutDelayMS = () => {
155
+ return this.props.delayPressOut || 0;
156
+ };
157
+ this._touchableHandleKeyPress = (ev) => {
158
+ this.props.onKeyPress && this.props.onKeyPress(ev);
159
+ };
160
+ this._touchableHandleKeyPressDown = (ev) => {
161
+ this.props.onKeyPressDown && this.props.onKeyPressDown(ev);
162
+ };
163
+ this._mouseEnter = (mouseEvent) => {
164
+ this.props.onMouseEnter && this.props.onMouseEnter(mouseEvent);
165
+ this.setState({ isMouseIn: true });
166
+ };
167
+ this._mouseLeave = (mouseEvent) => {
168
+ this.props.onMouseLeave && this.props.onMouseLeave(mouseEvent);
169
+ this.setState({ isMouseIn: false });
170
+ };
171
+ this._onFocus = (ev) => {
172
+ this.props.onFocus && this.props.onFocus(ev);
173
+ this.setState({ isFocused: true });
174
+ };
175
+ this._onBlur = (ev) => {
176
+ this.props.onBlur && this.props.onBlur(ev);
177
+ this.setState({ isFocused: false });
178
+ };
179
+ /**
180
+ * The generated style uses hard-coded color values,
181
+ * though it is trivial to pass these values as props.
182
+ * This is an example of a render style (one that is a
183
+ * function passed on to TouchableWin32 and resolved according
184
+ * to the internal state of TouchableWin32).
185
+ */
186
+ this._generateStyle = (state) => {
187
+ const finalStyle = {};
188
+ finalStyle.borderColor = state.isFocused ? 'red' : 'blue';
189
+ finalStyle.borderWidth = state.isFocused ? 10 : 5;
190
+ if (state.isHovered) {
191
+ if (state.isPressed) {
192
+ finalStyle.backgroundColor = 'black';
193
+ }
194
+ else {
195
+ finalStyle.backgroundColor = 'gray';
196
+ }
197
+ }
198
+ else {
199
+ if (state.isPressed) {
200
+ finalStyle.backgroundColor = 'green';
201
+ }
202
+ else {
203
+ finalStyle.backgroundColor = 'white';
204
+ }
205
+ }
206
+ return Object.assign({}, this.props.style, finalStyle);
207
+ };
208
+ }
209
+ render() {
210
+ return (react_1.default.createElement(TouchableWin32_1.TouchableWin32, { focusable: true, rejectResponderTermination: this.props.rejectResponderTermination, disabled: false, touchableHandleActivePressIn: this._touchableHandleActivePressIn, touchableHandleActivePressOut: this._touchableHandleActivePressOut, touchableHandlePress: this._touchableHandlePress, touchableHandleLongPress: this._touchableHandleLongPress, touchableGetHighlightDelayMS: this._touchableGetHighlightDelayMS, touchableGetPressRectOffset: this._touchableGetPressRectOffset, touchableGetLongPressDelayMS: this._touchableGetLongPressDelayMS, touchableGetPressOutDelayMS: this._touchableGetPressOutDelayMS, touchableGetHitSlop: this._touchableGetHitSlop, touchableHandleKeyPress: this._touchableHandleKeyPress, touchableHandleKeyPressDown: this._touchableHandleKeyPressDown, onFocus: this._onFocus, onBlur: this._onBlur, onMouseEnter: this._mouseEnter, onMouseLeave: this._mouseLeave, renderStyle: this._generateStyle, children: this.props.children, ref: this.props.innerRef }));
211
+ }
212
+ }
213
+ // Demonstrating ref forwarding - forwarding a ref using an innerRef prop on a class component
214
+ const TouchableWin32Highlight = react_1.default.forwardRef((props, ref) => {
215
+ return (react_1.default.createElement(TouchableWin32HighlightComponent, { innerRef: ref, ...props }));
216
+ });
217
+ /**
218
+ * TouchableHighlightExamples
219
+ */
220
+ class TouchableWithoutFeedbackExample extends react_1.default.Component {
221
+ constructor(props) {
222
+ super(props);
223
+ this._onPress = () => {
224
+ this.setState({ numberOfPresses: this.state.numberOfPresses + 1 });
225
+ };
226
+ this.state = { numberOfPresses: 0 };
227
+ }
228
+ render() {
229
+ return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.largeContainer },
230
+ react_1.default.createElement(TouchableWin32WithoutFeedback, { style: styles.outerTouch, onPress: this._onPress },
231
+ react_1.default.createElement(ViewWin32_1.ViewWin32, null,
232
+ react_1.default.createElement(react_native_1.Text, null, "Press me"))),
233
+ react_1.default.createElement(TouchableWin32WithoutFeedback, { style: styles.outerTouch, onPress: this._onPress },
234
+ react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.smallContainer },
235
+ react_1.default.createElement(TouchableWin32WithoutFeedback, { style: styles.innerTouch, onPress: this._onPress },
236
+ react_1.default.createElement(ViewWin32_1.ViewWin32, null,
237
+ react_1.default.createElement(react_native_1.Text, null, "You can also have nested Touchables"))))),
238
+ react_1.default.createElement(react_native_1.Text, null, 'Number of Recognized Presses: ' + this.state.numberOfPresses)));
239
+ }
240
+ }
241
+ /**
242
+ * TouchableHighlightExamples
243
+ */
244
+ class TouchableHighlightExample extends react_1.default.Component {
245
+ constructor(props) {
246
+ super(props);
247
+ /**
248
+ * This is primarily to demonstrate render children as a function
249
+ * of state, here we change text color depending on interaction state.
250
+ */
251
+ this._getChildrenOfInnerTouchable = (state) => {
252
+ return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: {
253
+ borderColor: state.isFocused ? 'green' : 'pink',
254
+ borderWidth: state.isHovered ? 10 : 5,
255
+ height: 70,
256
+ width: 70,
257
+ } },
258
+ react_1.default.createElement(react_native_1.Text, { style: {
259
+ color: this._pickColor(state.isHovered, state.isPressed),
260
+ fontSize: state.isFocused ? 8 : 10,
261
+ }, textStyle: "None" }, "Press Me!")));
262
+ };
263
+ this._onPress = () => {
264
+ this.setState({ numberOfPresses: this.state.numberOfPresses + 1 });
265
+ };
266
+ this.state = { numberOfPresses: 0 };
267
+ }
268
+ render() {
269
+ return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.largeContainer },
270
+ react_1.default.createElement(TouchableWin32Highlight, { style: styles.outerTouch, onPress: this._onPress },
271
+ react_1.default.createElement(ViewWin32_1.ViewWin32, null,
272
+ react_1.default.createElement(react_native_1.Text, null, "Press me"))),
273
+ react_1.default.createElement(TouchableWin32Highlight, { style: styles.outerTouch, onPress: this._onPress },
274
+ react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.smallContainer },
275
+ react_1.default.createElement(TouchableWin32Highlight, { style: styles.innerTouch, onPress: this._onPress, children: this._getChildrenOfInnerTouchable }))),
276
+ react_1.default.createElement(react_native_1.Text, { style: { color: 'red' }, textStyle: "None" }, 'Number of Recognized Presses: ' + this.state.numberOfPresses)));
277
+ }
278
+ _pickColor(hovered, pressed) {
279
+ if (hovered) {
280
+ if (pressed) {
281
+ return 'white';
282
+ }
283
+ else {
284
+ return 'red';
285
+ }
286
+ }
287
+ else {
288
+ if (pressed) {
289
+ return 'purple';
290
+ }
291
+ else {
292
+ return 'black';
293
+ }
294
+ }
295
+ }
296
+ }
297
+ const TouchableFocusExample = () => {
298
+ const [focused, setFocused] = react_1.default.useState(false);
299
+ const focusableRef = react_1.default.useRef(null);
300
+ // onPress callback
301
+ const focusOnPress = react_1.default.useCallback(() => {
302
+ focusableRef.current && focusableRef.current.focus();
303
+ focused || setFocused(true);
304
+ }, [focused]);
305
+ // onFocus and onBlur callbacks
306
+ const onFocus = react_1.default.useCallback(() => {
307
+ setFocused(true);
308
+ }, []);
309
+ const onBlur = react_1.default.useCallback(() => {
310
+ setFocused(false);
311
+ }, []);
312
+ return (react_1.default.createElement(ViewWin32_1.ViewWin32, { style: styles.largeContainer },
313
+ react_1.default.createElement(TouchableWin32Highlight, { onPress: focusOnPress },
314
+ react_1.default.createElement(react_native_1.Text, null, "Press me to focus my friend")),
315
+ react_1.default.createElement(TouchableWin32Highlight, { ref: focusableRef, onFocus: onFocus, onBlur: onBlur },
316
+ react_1.default.createElement(react_native_1.Text, null, 'Focused: ' + focused))));
317
+ };
318
+ exports.displayName = 'TouchableWin32 Examples';
319
+ exports.title = 'TouchableWin32';
320
+ exports.description = 'Demonstration of touchable + focus + hover behavior all in one component';
321
+ exports.examples = [
322
+ {
323
+ title: 'TouchableWithoutFeedback Example',
324
+ description: 'A simple example implementation of without feedback behavior',
325
+ render() {
326
+ return react_1.default.createElement(TouchableWithoutFeedbackExample, null);
327
+ },
328
+ },
329
+ {
330
+ title: 'TouchableHighlight Example',
331
+ description: 'A simple example implementation of highlight behavior',
332
+ render() {
333
+ return react_1.default.createElement(TouchableHighlightExample, null);
334
+ },
335
+ },
336
+ {
337
+ title: 'Imperative Focus on TouchableWin32 Example',
338
+ description: 'A simple example implementation of imperative focus behavior',
339
+ render() {
340
+ return react_1.default.createElement(TouchableFocusExample, null);
341
+ },
342
+ }
343
+ ];
345
344
  //# sourceMappingURL=TouchableWin32Test.js.map