react-native-windows 0.73.11 → 0.74.0-preview.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (767) hide show
  1. package/.flowconfig +12 -7
  2. package/Chakra/ChakraUtils.cpp +5 -10
  3. package/Chakra/ChakraUtils.h +2 -2
  4. package/Common/packages.lock.json +3 -3
  5. package/Directory.Build.props +5 -5
  6. package/Folly/Folly.vcxproj +2 -2
  7. package/Folly/Folly.vcxproj.filters +7 -0
  8. package/Folly/TEMP_UntilFollyUpdate/dynamic-inl.h +22 -1
  9. package/Folly/TEMP_UntilFollyUpdate/lang/SafeAssert.h +4 -1
  10. package/Folly/cgmanifest.json +1 -1
  11. package/Libraries/ActionSheetIOS/ActionSheetIOS.d.ts +6 -0
  12. package/Libraries/ActionSheetIOS/ActionSheetIOS.js +6 -0
  13. package/Libraries/ActionSheetIOS/NativeActionSheetManager.js +4 -45
  14. package/Libraries/Alert/Alert.windows.js +2 -3
  15. package/Libraries/Alert/NativeAlertManager.js +4 -26
  16. package/Libraries/Animated/Animated.js +2 -2
  17. package/Libraries/Animated/AnimatedPlatformConfig.js +1 -1
  18. package/Libraries/Animated/NativeAnimatedHelper.js +14 -11
  19. package/Libraries/Animated/NativeAnimatedModule.js +4 -68
  20. package/Libraries/Animated/NativeAnimatedTurboModule.js +4 -69
  21. package/Libraries/Animated/animations/Animation.js +6 -22
  22. package/Libraries/Animated/components/AnimatedFlatList.js +1 -16
  23. package/Libraries/Animated/components/AnimatedScrollView.js +36 -31
  24. package/Libraries/Animated/components/AnimatedSectionList.js +1 -20
  25. package/Libraries/Animated/createAnimatedComponent.js +45 -40
  26. package/Libraries/Animated/nodes/AnimatedStyle.js +1 -1
  27. package/Libraries/Animated/shouldUseTurboAnimatedModule.js +1 -1
  28. package/Libraries/Animated/useAnimatedProps.js +21 -1
  29. package/Libraries/AppState/NativeAppState.js +4 -24
  30. package/Libraries/AppTheme/NativeAppTheme.js +4 -25
  31. package/Libraries/BatchedBridge/NativeModules.js +1 -1
  32. package/Libraries/Blob/Blob.js +1 -4
  33. package/Libraries/Blob/BlobManager.js +6 -8
  34. package/Libraries/Blob/File.js +1 -1
  35. package/Libraries/Blob/NativeBlobModule.js +4 -50
  36. package/Libraries/Blob/NativeFileReaderModule.js +4 -13
  37. package/Libraries/BugReporting/NativeBugReporting.js +4 -12
  38. package/Libraries/Components/AccessibilityInfo/NativeAccessibilityInfo.js +3 -23
  39. package/Libraries/Components/AccessibilityInfo/NativeAccessibilityManager.js +4 -57
  40. package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.android.js +3 -2
  41. package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.windows.js +3 -2
  42. package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +9 -40
  43. package/Libraries/Components/ActivityIndicator/ActivityIndicatorViewNativeComponent.js +3 -43
  44. package/Libraries/Components/Button.js +103 -107
  45. package/Libraries/Components/Button.windows.js +199 -206
  46. package/Libraries/Components/Clipboard/NativeClipboard.js +3 -11
  47. package/Libraries/Components/DrawerAndroid/AndroidDrawerLayoutNativeComponent.js +3 -114
  48. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +1 -5
  49. package/Libraries/Components/Keyboard/KeyboardExt.d.ts +8 -8
  50. package/Libraries/Components/Keyboard/KeyboardExt.js +27 -27
  51. package/Libraries/Components/Keyboard/KeyboardExt.js.map +1 -1
  52. package/Libraries/Components/Keyboard/KeyboardExtProps.d.ts +17 -17
  53. package/Libraries/Components/Keyboard/KeyboardExtProps.js +7 -7
  54. package/Libraries/Components/Keyboard/KeyboardExtProps.js.map +1 -1
  55. package/Libraries/Components/Keyboard/NativeKeyboardObserver.js +3 -10
  56. package/Libraries/Components/Pressable/Pressable.js +1 -1
  57. package/Libraries/Components/Pressable/Pressable.windows.js +1 -2
  58. package/Libraries/Components/Pressable/useAndroidRippleForView.js +5 -4
  59. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroidNativeComponent.js +4 -24
  60. package/Libraries/Components/RefreshControl/AndroidSwipeRefreshLayoutNativeComponent.js +3 -64
  61. package/Libraries/Components/RefreshControl/PullToRefreshViewNativeComponent.js +3 -61
  62. package/Libraries/Components/RefreshControl/RefreshControl.js +1 -1
  63. package/Libraries/Components/RefreshControl/RefreshControl.windows.js +1 -1
  64. package/Libraries/Components/SafeAreaView/RCTSafeAreaViewNativeComponent.js +3 -15
  65. package/Libraries/Components/ScrollView/AndroidHorizontalScrollContentViewNativeComponent.js +3 -16
  66. package/Libraries/Components/ScrollView/ScrollContentViewNativeComponent.js +1 -1
  67. package/Libraries/Components/ScrollView/ScrollView.d.ts +5 -6
  68. package/Libraries/Components/ScrollView/ScrollView.js +12 -38
  69. package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +1 -2
  70. package/Libraries/Components/Sound/NativeSoundManager.js +3 -12
  71. package/Libraries/Components/StatusBar/NativeStatusBarManagerAndroid.js +3 -58
  72. package/Libraries/Components/StatusBar/NativeStatusBarManagerIOS.js +3 -79
  73. package/Libraries/Components/Switch/AndroidSwitchNativeComponent.js +4 -53
  74. package/Libraries/Components/Switch/Switch.js +0 -2
  75. package/Libraries/Components/Switch/Switch.windows.js +0 -2
  76. package/Libraries/Components/Switch/SwitchNativeComponent.js +4 -52
  77. package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +8 -0
  78. package/Libraries/Components/TextInput/InputAccessoryView.js +18 -20
  79. package/Libraries/Components/TextInput/RCTInputAccessoryViewNativeComponent.js +4 -17
  80. package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +3 -6
  81. package/Libraries/Components/TextInput/TextInput.d.ts +16 -0
  82. package/Libraries/Components/TextInput/TextInput.flow.js +16 -0
  83. package/Libraries/Components/TextInput/TextInput.js +65 -32
  84. package/Libraries/Components/TextInput/TextInput.windows.js +87 -38
  85. package/Libraries/Components/TextInput/WindowsTextInputNativeComponent.js +773 -9
  86. package/Libraries/Components/ToastAndroid/NativeToastAndroid.js +3 -28
  87. package/Libraries/Components/Touchable/PooledClass.js +1 -1
  88. package/Libraries/Components/Touchable/Touchable.js +2 -3
  89. package/Libraries/Components/Touchable/Touchable.windows.js +2 -3
  90. package/Libraries/Components/Touchable/TouchableHighlight.js +4 -4
  91. package/Libraries/Components/Touchable/TouchableHighlight.windows.js +4 -4
  92. package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -1
  93. package/Libraries/Components/Touchable/TouchableOpacity.js +5 -2
  94. package/Libraries/Components/Touchable/TouchableOpacity.windows.js +5 -2
  95. package/Libraries/Components/UnimplementedViews/UnimplementedNativeViewNativeComponent.js +3 -16
  96. package/Libraries/Components/View/ReactNativeStyleAttributes.js +2 -1
  97. package/Libraries/Components/View/View.js +0 -11
  98. package/Libraries/Components/View/View.windows.js +19 -18
  99. package/Libraries/Components/View/ViewAccessibility.d.ts +33 -17
  100. package/Libraries/Components/View/ViewPropTypes.d.ts +28 -17
  101. package/Libraries/Components/View/ViewPropTypes.js +36 -36
  102. package/Libraries/Components/View/ViewPropTypes.windows.js +36 -36
  103. package/Libraries/Core/InitializeCore.js +1 -1
  104. package/Libraries/Core/NativeExceptionsManager.js +3 -93
  105. package/Libraries/Core/ReactNativeVersion.js +12 -6
  106. package/Libraries/Core/ReactNativeVersionCheck.js +6 -6
  107. package/Libraries/Core/SegmentFetcher/NativeSegmentFetcher.js +3 -18
  108. package/Libraries/Core/Timers/NativeTiming.js +3 -16
  109. package/Libraries/Core/registerCallableModule.d.ts +16 -0
  110. package/Libraries/Core/registerCallableModule.js +42 -0
  111. package/Libraries/Core/setUpPerformance.js +2 -2
  112. package/Libraries/Core/setUpPerformanceObserver.js +3 -1
  113. package/Libraries/Debugging/DebuggingOverlay.js +111 -0
  114. package/Libraries/Debugging/DebuggingOverlayNativeComponent.js +13 -0
  115. package/Libraries/Debugging/DebuggingOverlayRegistry.js +513 -0
  116. package/Libraries/Debugging/useSubscribeToDebuggingOverlayRegistry.js +32 -0
  117. package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +3 -14
  118. package/Libraries/HeapCapture/NativeJSCHeapCapture.js +3 -9
  119. package/Libraries/Image/AssetSourceResolver.js +5 -5
  120. package/Libraries/Image/AssetUtils.js +4 -5
  121. package/Libraries/Image/Image.android.js +146 -174
  122. package/Libraries/Image/Image.d.ts +1 -1
  123. package/Libraries/Image/Image.ios.js +53 -79
  124. package/Libraries/Image/Image.windows.js +53 -79
  125. package/Libraries/Image/ImageBackground.js +2 -2
  126. package/Libraries/Image/ImageInjection.js +76 -18
  127. package/Libraries/Image/ImageTypes.flow.js +71 -0
  128. package/Libraries/Image/ImageUtils.js +1 -1
  129. package/Libraries/Image/ImageViewNativeComponent.js +18 -0
  130. package/Libraries/Image/NativeImageEditor.js +3 -42
  131. package/Libraries/Image/NativeImageLoaderAndroid.js +4 -28
  132. package/Libraries/Image/NativeImageLoaderIOS.js +4 -28
  133. package/Libraries/Image/NativeImageStoreAndroid.js +3 -16
  134. package/Libraries/Image/NativeImageStoreIOS.js +3 -23
  135. package/Libraries/Image/resolveAssetSource.js +59 -26
  136. package/Libraries/Image/resolveAssetSource.windows.js +148 -0
  137. package/Libraries/Inspector/ElementProperties.js +26 -52
  138. package/Libraries/Inspector/Inspector.js +122 -186
  139. package/Libraries/Inspector/InspectorOverlay.js +21 -33
  140. package/Libraries/Inspector/InspectorPanel.js +3 -17
  141. package/Libraries/Inspector/ReactDevToolsOverlay.js +171 -0
  142. package/Libraries/Inspector/getInspectorDataForViewAtPoint.js +20 -8
  143. package/Libraries/Interaction/FrameRateLogger.js +8 -18
  144. package/Libraries/Interaction/NativeFrameRateLogger.js +4 -16
  145. package/Libraries/IntersectionObserver/IntersectionObserver.js +1 -1
  146. package/Libraries/IntersectionObserver/IntersectionObserverEntry.js +20 -19
  147. package/Libraries/IntersectionObserver/IntersectionObserverManager.js +84 -6
  148. package/Libraries/IntersectionObserver/NativeIntersectionObserver.js +3 -31
  149. package/Libraries/IntersectionObserver/__mocks__/NativeIntersectionObserver.js +12 -2
  150. package/Libraries/LayoutAnimation/LayoutAnimation.js +1 -2
  151. package/Libraries/Linking/NativeIntentAndroid.js +3 -20
  152. package/Libraries/Linking/NativeLinkingManager.js +3 -17
  153. package/Libraries/Lists/FillRateHelper.js +1 -1
  154. package/Libraries/Lists/FlatList.d.ts +2 -2
  155. package/Libraries/Lists/FlatList.js +6 -2
  156. package/Libraries/Lists/FlatList.windows.js +717 -0
  157. package/Libraries/Lists/SectionList.d.ts +6 -1
  158. package/Libraries/Lists/ViewabilityHelper.js +1 -1
  159. package/Libraries/Lists/VirtualizeUtils.js +1 -1
  160. package/Libraries/Lists/VirtualizedList.js +1 -1
  161. package/Libraries/Lists/VirtualizedListContext.js +1 -1
  162. package/Libraries/Lists/VirtualizedSectionList.js +1 -1
  163. package/Libraries/LogBox/LogBoxInspectorContainer.js +1 -1
  164. package/Libraries/Modal/Modal.js +43 -11
  165. package/Libraries/Modal/NativeModalManager.js +3 -11
  166. package/Libraries/Modal/RCTModalHostViewNativeComponent.js +3 -129
  167. package/Libraries/MutationObserver/MutationObserver.js +1 -1
  168. package/Libraries/MutationObserver/MutationObserverManager.js +2 -2
  169. package/Libraries/MutationObserver/MutationRecord.js +12 -10
  170. package/Libraries/MutationObserver/NativeMutationObserver.js +3 -48
  171. package/Libraries/MutationObserver/__mocks__/NativeMutationObserver.js +1 -1
  172. package/Libraries/NativeComponent/BaseViewConfig.android.js +1 -0
  173. package/Libraries/NativeComponent/BaseViewConfig.windows.js +3 -0
  174. package/Libraries/NativeComponent/NativeComponentRegistry.js +1 -1
  175. package/Libraries/NativeModules/specs/NativeAnimationsDebugModule.js +3 -10
  176. package/Libraries/NativeModules/specs/NativeDevMenu.js +3 -13
  177. package/Libraries/NativeModules/specs/NativeDevSettings.js +3 -23
  178. package/Libraries/NativeModules/specs/NativeDeviceEventManager.js +3 -9
  179. package/Libraries/NativeModules/specs/NativeDialogManagerAndroid.js +3 -38
  180. package/Libraries/NativeModules/specs/NativeDialogManagerWindows.js +11 -0
  181. package/Libraries/NativeModules/specs/NativeLogBox.js +3 -10
  182. package/Libraries/NativeModules/specs/NativeRedBox.js +4 -11
  183. package/Libraries/NativeModules/specs/NativeSourceCode.js +2 -25
  184. package/Libraries/Network/FormData.js +3 -1
  185. package/Libraries/Network/NativeNetworkingAndroid.js +4 -28
  186. package/Libraries/Network/NativeNetworkingIOS.js +4 -28
  187. package/Libraries/NewAppScreen/components/DebugInstructions.windows.js +4 -2
  188. package/Libraries/NewAppScreen/components/ReloadInstructions.windows.js +3 -1
  189. package/Libraries/Performance/NativeJSCSamplingProfiler.js +3 -9
  190. package/Libraries/PermissionsAndroid/NativePermissionsAndroid.js +4 -68
  191. package/Libraries/PermissionsAndroid/PermissionsAndroid.js +3 -3
  192. package/Libraries/Pressability/Pressability.js +12 -2
  193. package/Libraries/Pressability/Pressability.windows.js +13 -3
  194. package/Libraries/Pressability/usePressability.js +7 -0
  195. package/Libraries/PushNotificationIOS/NativePushNotificationManagerIOS.js +4 -70
  196. package/Libraries/PushNotificationIOS/PushNotificationIOS.js +45 -39
  197. package/Libraries/ReactNative/AppContainer-dev.js +211 -0
  198. package/Libraries/ReactNative/AppContainer-prod.js +53 -0
  199. package/Libraries/ReactNative/AppContainer.js +6 -149
  200. package/Libraries/ReactNative/AppRegistry.js +3 -1
  201. package/Libraries/ReactNative/BridgelessUIManager.js +375 -128
  202. package/Libraries/ReactNative/FabricUIManager.js +6 -0
  203. package/Libraries/ReactNative/NativeHeadlessJsTaskSupport.js +3 -10
  204. package/Libraries/ReactNative/NativeI18nManager.js +3 -18
  205. package/Libraries/ReactNative/NativeUIManager.js +4 -112
  206. package/Libraries/ReactNative/PaperUIManager.js +8 -7
  207. package/Libraries/ReactNative/PaperUIManager.windows.js +29 -8
  208. package/Libraries/ReactNative/ReactFabricInternals.js +1 -1
  209. package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricPublicInstance.js +24 -5
  210. package/Libraries/ReactNative/ReactNativeFeatureFlags.js +0 -45
  211. package/Libraries/ReactNative/RendererImplementation.js +11 -0
  212. package/Libraries/ReactNative/UIManager.d.ts +11 -34
  213. package/Libraries/ReactNative/UIManager.js +2 -23
  214. package/Libraries/ReactNative/UIManagerProperties.js +0 -2
  215. package/Libraries/ReactNative/__mocks__/FabricUIManager.js +23 -1
  216. package/Libraries/ReactNative/getNativeComponentAttributes.js +5 -1
  217. package/Libraries/ReactNative/renderApplication.js +9 -6
  218. package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +6 -1
  219. package/Libraries/Renderer/implementations/ReactFabric-dev.js +24771 -21123
  220. package/Libraries/Renderer/implementations/ReactFabric-prod.js +4160 -3109
  221. package/Libraries/Renderer/implementations/ReactFabric-profiling.js +4384 -3322
  222. package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +25194 -21398
  223. package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +3763 -2636
  224. package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +4027 -2867
  225. package/Libraries/Renderer/shims/ReactNativeTypes.js +8 -9
  226. package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -12
  227. package/Libraries/Settings/NativeSettingsManager.js +4 -16
  228. package/Libraries/Share/NativeShareModule.js +3 -13
  229. package/Libraries/StyleSheet/PlatformColorValueTypes.windows.js +1 -1
  230. package/Libraries/StyleSheet/StyleSheet.d.ts +1 -20
  231. package/Libraries/StyleSheet/StyleSheet.js +5 -28
  232. package/Libraries/StyleSheet/StyleSheetTypes.d.ts +51 -7
  233. package/Libraries/StyleSheet/StyleSheetTypes.js +19 -11
  234. package/Libraries/StyleSheet/flattenStyle.js +2 -2
  235. package/Libraries/StyleSheet/normalizeColor.js +1 -1
  236. package/Libraries/StyleSheet/processAspectRatio.js +1 -1
  237. package/Libraries/StyleSheet/processFontVariant.js +1 -1
  238. package/Libraries/Text/Text.js +0 -6
  239. package/Libraries/Text/Text.windows.js +0 -6
  240. package/Libraries/Text/TextAncestor.js +2 -3
  241. package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +4 -41
  242. package/Libraries/Types/ReactDevToolsTypes.js +58 -0
  243. package/Libraries/Types/UIManagerJSInterface.js +16 -0
  244. package/Libraries/Utilities/DebugEnvironment.js +1 -4
  245. package/Libraries/Utilities/Dimensions.js +8 -16
  246. package/Libraries/Utilities/GlobalPerformanceLogger.js +1 -2
  247. package/Libraries/Utilities/NativeAppearance.js +3 -26
  248. package/Libraries/Utilities/NativeDevLoadingView.js +3 -14
  249. package/Libraries/Utilities/NativeDeviceInfo.js +2 -47
  250. package/Libraries/Utilities/NativePlatformConstantsAndroid.js +3 -34
  251. package/Libraries/Utilities/NativePlatformConstantsIOS.js +3 -26
  252. package/Libraries/Utilities/NativePlatformConstantsWin.js +3 -23
  253. package/Libraries/Utilities/PixelRatio.d.ts +4 -4
  254. package/Libraries/Utilities/Platform.android.js +4 -0
  255. package/Libraries/Utilities/Platform.d.ts +3 -0
  256. package/Libraries/Utilities/Platform.flow.js +7 -0
  257. package/Libraries/Utilities/Platform.flow.windows.js +9 -0
  258. package/Libraries/Utilities/Platform.ios.js +11 -0
  259. package/Libraries/Utilities/Platform.windows.js +6 -0
  260. package/Libraries/Utilities/binaryToBase64.js +1 -1
  261. package/Libraries/Utilities/codegenNativeComponent.js +4 -6
  262. package/Libraries/Utilities/createPerformanceLogger.js +2 -74
  263. package/Libraries/Utilities/useMergeRefs.js +5 -9
  264. package/Libraries/Vibration/NativeVibration.js +3 -14
  265. package/Libraries/WebSocket/NativeWebSocketModule.js +4 -25
  266. package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
  267. package/Libraries/vendor/emitter/EventEmitter.js +1 -0
  268. package/Microsoft.ReactNative/AsynchronousEventBeat.cpp +50 -0
  269. package/Microsoft.ReactNative/AsynchronousEventBeat.h +23 -0
  270. package/Microsoft.ReactNative/Base/CoreUIManagers.cpp +4 -0
  271. package/Microsoft.ReactNative/Base/CxxReactIncludes.h +1 -1
  272. package/Microsoft.ReactNative/Base/FollyIncludes.h +2 -2
  273. package/Microsoft.ReactNative/ComponentView.idl +106 -0
  274. package/Microsoft.ReactNative/Composition.Input.idl +16 -2
  275. package/Microsoft.ReactNative/CompositionComponentView.idl +117 -0
  276. package/Microsoft.ReactNative/CompositionContext.idl +1 -1
  277. package/Microsoft.ReactNative/CompositionRootView.idl +8 -0
  278. package/Microsoft.ReactNative/CompositionSwitcher.idl +25 -14
  279. package/Microsoft.ReactNative/DevMenuControl.idl +0 -3
  280. package/Microsoft.ReactNative/DevMenuControl.xaml +0 -15
  281. package/Microsoft.ReactNative/Fabric/AbiComponentDescriptor.cpp +189 -0
  282. package/Microsoft.ReactNative/Fabric/AbiComponentDescriptor.h +80 -0
  283. package/Microsoft.ReactNative/Fabric/AbiShadowNode.cpp +83 -0
  284. package/Microsoft.ReactNative/Fabric/AbiShadowNode.h +83 -0
  285. package/Microsoft.ReactNative/Fabric/AbiState.cpp +71 -0
  286. package/Microsoft.ReactNative/Fabric/AbiState.h +38 -0
  287. package/Microsoft.ReactNative/Fabric/AbiViewComponentDescriptor.cpp +48 -19
  288. package/Microsoft.ReactNative/Fabric/AbiViewComponentDescriptor.h +8 -16
  289. package/Microsoft.ReactNative/Fabric/AbiViewProps.cpp +97 -0
  290. package/Microsoft.ReactNative/Fabric/AbiViewProps.h +39 -0
  291. package/Microsoft.ReactNative/Fabric/AbiViewShadowNode.cpp +90 -0
  292. package/Microsoft.ReactNative/Fabric/AbiViewShadowNode.h +87 -0
  293. package/Microsoft.ReactNative/Fabric/ComponentView.cpp +340 -0
  294. package/Microsoft.ReactNative/Fabric/ComponentView.h +130 -64
  295. package/Microsoft.ReactNative/Fabric/Composition/ActivityIndicatorComponentView.cpp +48 -24
  296. package/Microsoft.ReactNative/Fabric/Composition/ActivityIndicatorComponentView.h +18 -14
  297. package/Microsoft.ReactNative/Fabric/Composition/ComponentViewRegistry.cpp +42 -27
  298. package/Microsoft.ReactNative/Fabric/Composition/ComponentViewRegistry.h +3 -1
  299. package/Microsoft.ReactNative/Fabric/Composition/Composition.Input.cpp +123 -28
  300. package/Microsoft.ReactNative/Fabric/Composition/Composition.Input.h +69 -13
  301. package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper.cpp +651 -284
  302. package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper.h +7 -7
  303. package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper_emptyimpl.cpp +9 -9
  304. package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.cpp +120 -31
  305. package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.h +12 -2
  306. package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.cpp +308 -129
  307. package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.h +34 -6
  308. package/Microsoft.ReactNative/Fabric/Composition/CompositionHelpers.h +2 -1
  309. package/Microsoft.ReactNative/Fabric/Composition/CompositionHwndHost.cpp +61 -54
  310. package/Microsoft.ReactNative/Fabric/Composition/CompositionHwndHost.h +0 -9
  311. package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.cpp +99 -30
  312. package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.h +4 -3
  313. package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView.cpp +273 -28
  314. package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView.h +28 -3
  315. package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView_emptyimpl.cpp +7 -3
  316. package/Microsoft.ReactNative/Fabric/Composition/CompositionUIService.cpp +4 -0
  317. package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.cpp +479 -280
  318. package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.h +133 -79
  319. package/Microsoft.ReactNative/Fabric/Composition/DebuggingOverlayComponentView.cpp +113 -0
  320. package/Microsoft.ReactNative/Fabric/Composition/DebuggingOverlayComponentView.h +39 -0
  321. package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.cpp +61 -41
  322. package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.h +19 -14
  323. package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewComponentDescriptor.h +39 -0
  324. package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewComponentView.cpp +343 -0
  325. package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewComponentView.h +67 -0
  326. package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewShadowNode.cpp +18 -0
  327. package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewShadowNode.h +39 -0
  328. package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.cpp +53 -186
  329. package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.h +20 -12
  330. package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.cpp +59 -150
  331. package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.h +27 -76
  332. package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.cpp +81 -32
  333. package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.h +27 -14
  334. package/Microsoft.ReactNative/Fabric/Composition/ScrollViewComponentView.cpp +707 -64
  335. package/Microsoft.ReactNative/Fabric/Composition/ScrollViewComponentView.h +47 -26
  336. package/Microsoft.ReactNative/Fabric/Composition/SwitchComponentView.cpp +225 -125
  337. package/Microsoft.ReactNative/Fabric/Composition/SwitchComponentView.h +34 -21
  338. package/Microsoft.ReactNative/Fabric/Composition/TextDrawing.cpp +179 -0
  339. package/Microsoft.ReactNative/Fabric/Composition/TextDrawing.h +25 -0
  340. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentDescriptor.h +110 -115
  341. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.cpp +228 -79
  342. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.h +43 -22
  343. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputEventEmitter.cpp +18 -0
  344. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputEventEmitter.h +12 -0
  345. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputProps.h +5 -5
  346. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputShadowNode.cpp +5 -1
  347. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputShadowNode.h +1 -2
  348. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputState.cpp +4 -44
  349. package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputState.h +11 -9
  350. package/Microsoft.ReactNative/Fabric/Composition/Theme.cpp +550 -0
  351. package/Microsoft.ReactNative/Fabric/Composition/Theme.h +73 -0
  352. package/Microsoft.ReactNative/Fabric/Composition/Theme_emptyimpl.cpp +85 -0
  353. package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.cpp +48 -26
  354. package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.h +6 -2
  355. package/Microsoft.ReactNative/Fabric/Composition/UnimplementedNativeViewComponentView.cpp +30 -65
  356. package/Microsoft.ReactNative/Fabric/Composition/UnimplementedNativeViewComponentView.h +16 -25
  357. package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.cpp +72 -88
  358. package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.h +5 -2
  359. package/Microsoft.ReactNative/Fabric/IComponentViewRegistry.h +3 -2
  360. package/Microsoft.ReactNative/Fabric/ReactNativeConfigProperties.cpp +6 -6
  361. package/Microsoft.ReactNative/Fabric/ReactNativeConfigProperties.h +2 -2
  362. package/Microsoft.ReactNative/Fabric/ReactTaggedView.h +12 -7
  363. package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.cpp +28 -19
  364. package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.h +5 -0
  365. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/HostPlatformViewEventEmitter.cpp +0 -2
  366. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/HostPlatformViewTraitsInitializer.h +5 -1
  367. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/WindowsViewEvents.h +2 -4
  368. package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Float.h +20 -0
  369. package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/HostPlatformColor.h +86 -0
  370. package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/PlatformColorParser.h +38 -0
  371. package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/{Color.cpp → PlatformColorUtils.cpp} +7 -77
  372. package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/PlatformColorUtils.h +12 -0
  373. package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.cpp +1 -0
  374. package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.h +2 -0
  375. package/Microsoft.ReactNative/IReactCompositionViewComponentBuilder.idl +6 -87
  376. package/Microsoft.ReactNative/IReactContext.idl +3 -0
  377. package/Microsoft.ReactNative/IReactViewComponentBuilder.idl +71 -1
  378. package/Microsoft.ReactNative/JsiApi.cpp +17 -7
  379. package/Microsoft.ReactNative/JsiApi.h +2 -2
  380. package/Microsoft.ReactNative/JsiApi.idl +5 -4
  381. package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj +13 -22
  382. package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj.filters +6 -2
  383. package/Microsoft.ReactNative/Modules/AccessibilityInfoModule.h +1 -1
  384. package/Microsoft.ReactNative/Modules/AlertModule.h +2 -2
  385. package/Microsoft.ReactNative/Modules/Animated/PropsAnimatedNode.cpp +12 -8
  386. package/Microsoft.ReactNative/Modules/Animated/PropsAnimatedNode.h +1 -1
  387. package/Microsoft.ReactNative/Modules/AppStateModule.h +2 -2
  388. package/Microsoft.ReactNative/Modules/AppThemeModuleUwp.cpp +5 -3
  389. package/Microsoft.ReactNative/Modules/AppThemeModuleUwp.h +4 -4
  390. package/Microsoft.ReactNative/Modules/AppearanceModule.cpp +10 -1
  391. package/Microsoft.ReactNative/Modules/ClipboardModule.h +1 -1
  392. package/Microsoft.ReactNative/Modules/DeviceInfoModule.cpp +71 -38
  393. package/Microsoft.ReactNative/Modules/DeviceInfoModule.h +5 -5
  394. package/Microsoft.ReactNative/Modules/ExceptionsManager.cpp +110 -0
  395. package/Microsoft.ReactNative/Modules/ExceptionsManager.h +54 -0
  396. package/Microsoft.ReactNative/Modules/ImageViewManagerModule.h +11 -10
  397. package/Microsoft.ReactNative/Modules/LinkingManagerModule.h +8 -6
  398. package/Microsoft.ReactNative/Modules/LogBoxModule.h +3 -3
  399. package/Microsoft.ReactNative/Modules/NativeUIManager.cpp +5 -28
  400. package/Microsoft.ReactNative/Modules/NativeUIManager.h +1 -1
  401. package/Microsoft.ReactNative/Modules/PaperUIManagerModule.cpp +8 -5
  402. package/Microsoft.ReactNative/Modules/PaperUIManagerModule.h +3 -3
  403. package/Microsoft.ReactNative/Modules/PlatformConstantsWinModule.cpp +49 -0
  404. package/Microsoft.ReactNative/Modules/PlatformConstantsWinModule.h +18 -0
  405. package/Microsoft.ReactNative/Modules/SourceCode.cpp +31 -0
  406. package/Microsoft.ReactNative/Modules/SourceCode.h +28 -0
  407. package/Microsoft.ReactNative/Modules/StatusBarManager.h +12 -0
  408. package/Microsoft.ReactNative/Modules/Timing.cpp +325 -0
  409. package/Microsoft.ReactNative/Modules/Timing.h +121 -0
  410. package/Microsoft.ReactNative/QuirkSettings.cpp +32 -0
  411. package/Microsoft.ReactNative/QuirkSettings.h +9 -0
  412. package/Microsoft.ReactNative/QuirkSettings.idl +6 -0
  413. package/Microsoft.ReactNative/ReactCoreInjection.cpp +15 -0
  414. package/Microsoft.ReactNative/ReactCoreInjection.h +4 -0
  415. package/Microsoft.ReactNative/ReactCoreInjection.idl +8 -0
  416. package/Microsoft.ReactNative/ReactHost/IReactInstance.h +1 -1
  417. package/Microsoft.ReactNative/ReactHost/MsoReactContext.cpp +1 -1
  418. package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.cpp +556 -234
  419. package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.h +36 -9
  420. package/Microsoft.ReactNative/ReactInstanceSettings.idl +3 -0
  421. package/Microsoft.ReactNative/ReactPointerEventArgs.cpp +8 -0
  422. package/Microsoft.ReactNative/ReactPointerEventArgs.h +4 -0
  423. package/Microsoft.ReactNative/ReactPointerEventArgs.idl +12 -0
  424. package/Microsoft.ReactNative/SchedulerSettings.cpp +23 -0
  425. package/Microsoft.ReactNative/SchedulerSettings.h +9 -1
  426. package/Microsoft.ReactNative/SynchronousEventBeat.cpp +41 -0
  427. package/Microsoft.ReactNative/SynchronousEventBeat.h +29 -0
  428. package/Microsoft.ReactNative/Theme.idl +57 -0
  429. package/Microsoft.ReactNative/Timer.cpp +63 -0
  430. package/Microsoft.ReactNative/{CoreAppPage.h → Timer.h} +12 -5
  431. package/Microsoft.ReactNative/Timer.idl +34 -0
  432. package/Microsoft.ReactNative/TurboModulesProvider.cpp +4 -0
  433. package/Microsoft.ReactNative/Utils/ImageUtils.cpp +37 -3
  434. package/Microsoft.ReactNative/Utils/ImageUtils.h +0 -1
  435. package/Microsoft.ReactNative/Utils/LocalBundleReader.cpp +11 -12
  436. package/Microsoft.ReactNative/Utils/LocalBundleReader.h +3 -3
  437. package/Microsoft.ReactNative/Utils/ThemeUtils.cpp +33 -0
  438. package/Microsoft.ReactNative/Utils/ThemeUtils.h +13 -0
  439. package/Microsoft.ReactNative/Utils/ValueUtils.cpp +0 -5
  440. package/Microsoft.ReactNative/Utils/ValueUtils.h +0 -3
  441. package/Microsoft.ReactNative/ViewProps.idl +17 -0
  442. package/Microsoft.ReactNative/Views/ActivityIndicatorViewManager.cpp +1 -0
  443. package/Microsoft.ReactNative/Views/DebuggingOverlayViewManager.cpp +54 -0
  444. package/Microsoft.ReactNative/Views/DebuggingOverlayViewManager.h +30 -0
  445. package/Microsoft.ReactNative/Views/DevMenu.cpp +1 -20
  446. package/Microsoft.ReactNative/Views/DynamicAutomationPeer.cpp +157 -0
  447. package/Microsoft.ReactNative/Views/DynamicAutomationPeer.h +5 -0
  448. package/Microsoft.ReactNative/Views/DynamicAutomationProperties.cpp +20 -0
  449. package/Microsoft.ReactNative/Views/DynamicAutomationProperties.h +4 -0
  450. package/Microsoft.ReactNative/Views/FlyoutViewManager.cpp +1 -5
  451. package/Microsoft.ReactNative/Views/FrameworkElementViewManager.cpp +137 -0
  452. package/Microsoft.ReactNative/Views/ICompositionRootView.h +0 -1
  453. package/Microsoft.ReactNative/Views/Image/ImageViewManager.cpp +0 -5
  454. package/Microsoft.ReactNative/Views/PopupViewManager.cpp +1 -5
  455. package/Microsoft.ReactNative/Views/ShadowNodeBase.cpp +11 -0
  456. package/Microsoft.ReactNative/Views/ShadowNodeBase.h +3 -4
  457. package/Microsoft.ReactNative/Views/TextInputViewManager.cpp +0 -6
  458. package/Microsoft.ReactNative/Views/TextViewManager.cpp +0 -11
  459. package/Microsoft.ReactNative/Views/TouchEventHandler.cpp +1 -1
  460. package/Microsoft.ReactNative/Views/UnimplementedViewManager.cpp +79 -0
  461. package/Microsoft.ReactNative/Views/UnimplementedViewManager.h +27 -0
  462. package/Microsoft.ReactNative/Views/ViewManagerBase.cpp +46 -0
  463. package/Microsoft.ReactNative/Views/ViewManagerBase.h +1 -1
  464. package/Microsoft.ReactNative/Views/cppwinrt/DynamicAutomationPeer.idl +77 -2
  465. package/Microsoft.ReactNative/microsoft.reactnative.def +0 -3
  466. package/Microsoft.ReactNative/packages.lock.json +9 -6
  467. package/{Shared/Composition → Microsoft.ReactNative.Cxx}/AutoDraw.h +2 -0
  468. package/{Shared/Composition → Microsoft.ReactNative.Cxx}/CompositionSwitcher.interop.h +4 -10
  469. package/Microsoft.ReactNative.Cxx/CppWinRTIncludes.h +0 -5
  470. package/Microsoft.ReactNative.Cxx/DesktopWindowBridge.h +5 -0
  471. package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.cpp +19 -10
  472. package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.h +2 -0
  473. package/Microsoft.ReactNative.Cxx/JSValueComposition.h +22 -0
  474. package/Microsoft.ReactNative.Cxx/JSValueReader.h +19 -0
  475. package/Microsoft.ReactNative.Cxx/JSValueXaml.h +1 -1
  476. package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems +6 -4
  477. package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems.filters +0 -1
  478. package/Microsoft.ReactNative.Cxx/NativeModules.h +15 -15
  479. package/Microsoft.ReactNative.Cxx/TurboModuleProvider.cpp +1 -1
  480. package/Microsoft.ReactNative.Managed/ReactSettingsSnapshot.cs +2 -0
  481. package/Microsoft.ReactNative.Managed/packages.lock.json +6 -3
  482. package/Microsoft.ReactNative.Managed.CodeGen/Microsoft.ReactNative.Managed.CodeGen.csproj +0 -1
  483. package/Mso/future/details/executor.h +1 -1
  484. package/Mso/src/debugAssertApi/debugAssertApi.cpp +1 -1
  485. package/PropertySheets/External/Microsoft.ReactNative.Composition.Common.props +8 -0
  486. package/PropertySheets/External/Microsoft.ReactNative.Composition.CppLib.props +24 -0
  487. package/PropertySheets/External/Microsoft.ReactNative.Composition.CppLib.targets +20 -0
  488. package/PropertySheets/External/Microsoft.ReactNative.Cpp.Dependencies.props +1 -1
  489. package/PropertySheets/External/Microsoft.ReactNative.WindowsSdk.Default.props +2 -0
  490. package/PropertySheets/Generated/PackageVersion.g.props +4 -4
  491. package/PropertySheets/JSEngine.props +0 -8
  492. package/PropertySheets/React.Cpp.props +14 -3
  493. package/PropertySheets/ReactCommunity.cpp.props +2 -2
  494. package/PropertySheets/Release.props +0 -1
  495. package/PropertySheets/WinUI.props +21 -1
  496. package/PropertySheets/x64.props +3 -0
  497. package/PropertySheets/x86.props +3 -0
  498. package/ReactCommon/ReactCommon.vcxproj +13 -8
  499. package/ReactCommon/ReactCommon.vcxproj.filters +12 -1
  500. package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/jsi/test/testlib.cpp +114 -19
  501. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModule.cpp +66 -0
  502. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleBinding.cpp +114 -52
  503. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleUtils.h +13 -15
  504. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/scrollview/ScrollViewProps.cpp +535 -0
  505. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/runtime/ReactInstance.cpp +437 -0
  506. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/utils/jsi-utils.cpp +39 -0
  507. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/utils/jsi-utils.h +31 -0
  508. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/YGEnums.h +19 -24
  509. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/algorithm/CalculateLayout.cpp +600 -980
  510. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/enums/ExperimentalFeature.h +5 -11
  511. package/ReactCommon/cgmanifest.json +1 -1
  512. package/Scripts/EnableInternalWinAppSDKFeed.ps1 +21 -0
  513. package/Scripts/IntegrationTests.ps1 +26 -15
  514. package/Scripts/Microsoft.ReactNative.targets +0 -6
  515. package/Scripts/OfficeReact.Win32.nuspec +1 -2
  516. package/Scripts/TestServers.ps1 +2 -28
  517. package/Scripts/Tfs/Start-TestServers.ps1 +1 -21
  518. package/Scripts/Tfs/Stop-TestServers.ps1 +0 -5
  519. package/Scripts/rnw-dependencies.ps1 +38 -67
  520. package/Shared/CreateInstance.h +25 -0
  521. package/Shared/DevServerHelper.h +0 -3
  522. package/Shared/DevSettings.h +9 -0
  523. package/Shared/HermesRuntimeHolder.cpp +17 -0
  524. package/Shared/HermesRuntimeHolder.h +17 -0
  525. package/Shared/HermesSamplingProfiler.cpp +12 -10
  526. package/Shared/HermesSamplingProfiler.h +5 -4
  527. package/Shared/IDevSupportManager.h +4 -2
  528. package/Shared/InstanceManager.cpp +13 -11
  529. package/Shared/InstanceManager.h +8 -18
  530. package/Shared/JSI/ChakraRuntime.cpp +66 -9
  531. package/Shared/JSI/ChakraRuntime.h +8 -0
  532. package/Shared/JSI/JSExecutorFactoryDelegate.h +12 -0
  533. package/Shared/JSI/JSExecutorFactorySettings.cpp +30 -0
  534. package/Shared/JSI/JSExecutorFactorySettings.h +21 -0
  535. package/Shared/Modules/BlobModule.h +1 -1
  536. package/Shared/Modules/FileReaderModule.h +1 -1
  537. package/Shared/Modules/HttpModule.h +1 -1
  538. package/Shared/Modules/WebSocketTurboModule.h +1 -1
  539. package/Shared/OInstance.cpp +212 -165
  540. package/Shared/OInstance.h +19 -0
  541. package/Shared/Shared.vcxitems +134 -50
  542. package/Shared/Shared.vcxitems.filters +81 -24
  543. package/Shared/Utils.cpp +12 -10
  544. package/Shared/Utils.h +2 -2
  545. package/Shared/WebSocketJSExecutorFactory.h +1 -0
  546. package/codegen/NativeBugReportingSpec.g.h +0 -6
  547. package/codegen/NativeFrameRateLoggerSpec.g.h +0 -2
  548. package/codegen/NativeImageLoaderAndroidSpec.g.h +10 -23
  549. package/codegen/NativePerformanceObserverSpec.g.h +6 -0
  550. package/codegen/NativePlatformConstantsIOSSpec.g.h +2 -0
  551. package/codegen/NativePlatformConstantsWinSpec.g.h +17 -0
  552. package/codegen/NativePushNotificationManagerIOSSpec.g.h +8 -6
  553. package/codegen/NativeReactNativeFeatureFlagsSpec.g.h +88 -0
  554. package/codegen/NativeUIManagerSpec.g.h +83 -95
  555. package/codegen/react/components/rnwcore/ComponentDescriptors.h +9 -7
  556. package/codegen/react/components/rnwcore/EventEmitters.cpp +35 -56
  557. package/codegen/react/components/rnwcore/EventEmitters.h +58 -85
  558. package/codegen/react/components/rnwcore/Props.cpp +53 -95
  559. package/codegen/react/components/rnwcore/Props.h +188 -239
  560. package/codegen/react/components/rnwcore/ShadowNodes.cpp +5 -7
  561. package/codegen/react/components/rnwcore/ShadowNodes.h +27 -29
  562. package/codegen/react/components/rnwcore/States.cpp +3 -5
  563. package/codegen/react/components/rnwcore/States.h +17 -19
  564. package/codegen/rnwcoreJSI-generated.cpp +1442 -1398
  565. package/codegen/rnwcoreJSI.h +6066 -3593
  566. package/index.js +61 -99
  567. package/index.windows.js +60 -102
  568. package/jest/assetFileTransformer.js +1 -1
  569. package/jest/local-setup.js +0 -5
  570. package/jest/mockModal.js +2 -1
  571. package/jest/mockScrollView.js +1 -2
  572. package/jest/renderer.js +1 -1
  573. package/jest/setup.js +6 -3
  574. package/just-task.js +1 -1
  575. package/package.json +31 -29
  576. package/{Libraries/Core → src/private/core}/setUpDOM.js +2 -2
  577. package/src/private/featureflags/NativeReactNativeFeatureFlags.js +42 -0
  578. package/src/private/featureflags/ReactNativeFeatureFlags.js +140 -0
  579. package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +84 -0
  580. package/src/private/featureflags/__tests__/ReactNativeFeatureFlags-test.js +92 -0
  581. package/src/private/specs/components/ActivityIndicatorViewNativeComponent.js +53 -0
  582. package/src/private/specs/components/AndroidDrawerLayoutNativeComponent.js +124 -0
  583. package/src/private/specs/components/AndroidHorizontalScrollContentViewNativeComponent.js +26 -0
  584. package/src/private/specs/components/AndroidSwipeRefreshLayoutNativeComponent.js +74 -0
  585. package/src/private/specs/components/AndroidSwitchNativeComponent.js +62 -0
  586. package/src/private/specs/components/DebuggingOverlayNativeComponent.js +61 -0
  587. package/src/private/specs/components/ProgressBarAndroidNativeComponent.js +36 -0
  588. package/src/private/specs/components/PullToRefreshViewNativeComponent.js +71 -0
  589. package/src/private/specs/components/RCTInputAccessoryViewNativeComponent.js +26 -0
  590. package/src/private/specs/components/RCTModalHostViewNativeComponent.js +139 -0
  591. package/src/private/specs/components/RCTSafeAreaViewNativeComponent.js +25 -0
  592. package/src/private/specs/components/SwitchNativeComponent.js +61 -0
  593. package/src/private/specs/components/UnimplementedNativeViewNativeComponent.js +26 -0
  594. package/src/private/specs/modules/NativeAccessibilityInfo.js +33 -0
  595. package/src/private/specs/modules/NativeAccessibilityManager.js +66 -0
  596. package/src/private/specs/modules/NativeActionSheetManager.js +54 -0
  597. package/src/private/specs/modules/NativeAlertManager.js +35 -0
  598. package/src/private/specs/modules/NativeAnimatedModule.js +77 -0
  599. package/src/private/specs/modules/NativeAnimatedTurboModule.js +78 -0
  600. package/src/private/specs/modules/NativeAnimationsDebugModule.js +20 -0
  601. package/src/private/specs/modules/NativeAppState.js +33 -0
  602. package/src/private/specs/modules/NativeAppTheme.js +33 -0
  603. package/src/private/specs/modules/NativeAppearance.js +36 -0
  604. package/src/private/specs/modules/NativeBlobModule.js +59 -0
  605. package/src/private/specs/modules/NativeBugReporting.js +20 -0
  606. package/src/private/specs/modules/NativeClipboard.js +21 -0
  607. package/src/private/specs/modules/NativeDevLoadingView.js +24 -0
  608. package/src/private/specs/modules/NativeDevMenu.js +23 -0
  609. package/src/private/specs/modules/NativeDevSettings.js +33 -0
  610. package/src/private/specs/modules/NativeDevToolsSettingsManager.js +24 -0
  611. package/src/private/specs/modules/NativeDeviceEventManager.js +19 -0
  612. package/src/private/specs/modules/NativeDeviceInfo.js +58 -0
  613. package/src/private/specs/modules/NativeDialogManagerAndroid.js +48 -0
  614. package/{Libraries/Alert → src/private/specs/modules}/NativeDialogManagerWindows.js +5 -4
  615. package/src/private/specs/modules/NativeExceptionsManager.js +103 -0
  616. package/src/private/specs/modules/NativeFileReaderModule.js +22 -0
  617. package/src/private/specs/modules/NativeFrameRateLogger.js +22 -0
  618. package/src/private/specs/modules/NativeHeadlessJsTaskSupport.js +20 -0
  619. package/src/private/specs/modules/NativeI18nManager.js +28 -0
  620. package/src/private/specs/modules/NativeImageEditor.js +52 -0
  621. package/src/private/specs/modules/NativeImageLoaderAndroid.js +30 -0
  622. package/src/private/specs/modules/NativeImageLoaderIOS.js +37 -0
  623. package/src/private/specs/modules/NativeImageStoreAndroid.js +26 -0
  624. package/src/private/specs/modules/NativeImageStoreIOS.js +33 -0
  625. package/src/private/specs/modules/NativeIntentAndroid.js +30 -0
  626. package/src/private/specs/modules/NativeIntersectionObserver.js +41 -0
  627. package/src/private/specs/modules/NativeJSCHeapCapture.js +19 -0
  628. package/src/private/specs/modules/NativeJSCSamplingProfiler.js +19 -0
  629. package/src/private/specs/modules/NativeKeyboardObserver.js +20 -0
  630. package/src/private/specs/modules/NativeLinkingManager.js +27 -0
  631. package/src/private/specs/modules/NativeLogBox.js +20 -0
  632. package/src/private/specs/modules/NativeModalManager.js +21 -0
  633. package/src/private/specs/modules/NativeMutationObserver.js +58 -0
  634. package/src/private/specs/modules/NativeNetworkingAndroid.js +37 -0
  635. package/src/private/specs/modules/NativeNetworkingIOS.js +37 -0
  636. package/src/private/specs/modules/NativePermissionsAndroid.js +77 -0
  637. package/src/private/specs/modules/NativePlatformConstantsAndroid.js +44 -0
  638. package/src/private/specs/modules/NativePlatformConstantsIOS.js +37 -0
  639. package/src/private/specs/modules/NativePlatformConstantsWin.js +38 -0
  640. package/src/private/specs/modules/NativePushNotificationManagerIOS.js +107 -0
  641. package/src/private/specs/modules/NativeRedBox.js +20 -0
  642. package/src/private/specs/modules/NativeSampleTurboModule.js +53 -0
  643. package/src/private/specs/modules/NativeSegmentFetcher.js +28 -0
  644. package/src/private/specs/modules/NativeSettingsManager.js +25 -0
  645. package/src/private/specs/modules/NativeShareModule.js +23 -0
  646. package/src/private/specs/modules/NativeSoundManager.js +22 -0
  647. package/src/private/specs/modules/NativeSourceCode.js +36 -0
  648. package/src/private/specs/modules/NativeStatusBarManagerAndroid.js +68 -0
  649. package/src/private/specs/modules/NativeStatusBarManagerIOS.js +89 -0
  650. package/src/private/specs/modules/NativeTiming.js +26 -0
  651. package/src/private/specs/modules/NativeToastAndroid.js +38 -0
  652. package/src/private/specs/modules/NativeUIManager.js +118 -0
  653. package/src/private/specs/modules/NativeVibration.js +24 -0
  654. package/src/private/specs/modules/NativeWebSocketModule.js +34 -0
  655. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReactNativeElement.js +6 -6
  656. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyCharacterData.js +2 -2
  657. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyElement.js +5 -5
  658. package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyNode.js +19 -10
  659. package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/DOMRectList.js +1 -1
  660. package/src/private/webapis/dom/oldstylecollections/__tests__/DOMRectList-test.js +85 -0
  661. package/src/private/webapis/dom/oldstylecollections/__tests__/HTMLCollection-test.js +80 -0
  662. package/src/private/webapis/dom/oldstylecollections/__tests__/NodeList-test.js +161 -0
  663. package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformance.js +2 -2
  664. package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformanceObserver.js +3 -2
  665. package/{Libraries/WebPerformance → src/private/webapis/performance}/Performance.js +2 -2
  666. package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEventTiming.js +1 -1
  667. package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceObserver.js +21 -2
  668. package/{Libraries/WebPerformance → src/private/webapis/performance}/RawPerformanceEntry.js +1 -1
  669. package/{Libraries/WebPerformance → src/private/webapis/performance}/__mocks__/NativePerformanceObserver.js +9 -0
  670. package/src/private/webapis/performance/__tests__/EventCounts-test.js +116 -0
  671. package/src/private/webapis/performance/__tests__/NativePerformanceMock-test.js +82 -0
  672. package/src/private/webapis/performance/__tests__/NativePerformanceObserverMock-test.js +108 -0
  673. package/src/private/webapis/performance/__tests__/Performance-test.js +117 -0
  674. package/src/private/webapis/performance/__tests__/PerformanceObserver-test.js +208 -0
  675. package/template/cpp-app/src/App.cpp +2 -2
  676. package/template/cs-app/src/App.xaml.cs +2 -2
  677. package/templates/cpp-app/jest.config.windows.js +3 -0
  678. package/templates/cpp-app/metro.config.js +0 -2
  679. package/templates/cpp-app/template.config.js +24 -9
  680. package/templates/cpp-app/windows/ExperimentalFeatures.props +1 -1
  681. package/templates/cpp-app/windows/MyApp/AutolinkedNativeModules.g.cpp +13 -0
  682. package/templates/cpp-app/windows/MyApp/AutolinkedNativeModules.g.h +10 -0
  683. package/templates/cpp-app/windows/MyApp/MyApp.cpp +134 -249
  684. package/templates/cpp-app/windows/MyApp/MyApp.vcxproj +12 -11
  685. package/templates/cpp-app/windows/MyApp/MyApp.vcxproj.filters +6 -3
  686. package/templates/cpp-app/windows/MyApp/pch.h +12 -9
  687. package/templates/cpp-app/windows/MyApp/resource.h +0 -1
  688. package/templates/cpp-app/windows/MyApp.sln +26 -26
  689. package/templates/cpp-lib/example/metro.config.js +74 -0
  690. package/templates/cpp-lib/template.config.js +235 -0
  691. package/templates/cpp-lib/windows/ExperimentalFeatures.props +11 -0
  692. package/templates/cpp-lib/windows/MyLib/MyLib.cpp +18 -0
  693. package/templates/cpp-lib/windows/MyLib/MyLib.def +3 -0
  694. package/templates/cpp-lib/windows/MyLib/MyLib.h +31 -0
  695. package/templates/cpp-lib/windows/MyLib/MyLib.rc +0 -0
  696. package/templates/cpp-lib/windows/MyLib/MyLib.vcxproj +148 -0
  697. package/templates/cpp-lib/windows/MyLib/MyLib.vcxproj.filters +44 -0
  698. package/templates/cpp-lib/windows/MyLib/ReactPackageProvider.cpp +20 -0
  699. package/templates/cpp-lib/windows/MyLib/ReactPackageProvider.h +24 -0
  700. package/templates/cpp-lib/windows/MyLib/ReactPackageProvider.idl +9 -0
  701. package/templates/cpp-lib/windows/MyLib/pch.cpp +1 -0
  702. package/templates/cpp-lib/windows/MyLib/pch.h +30 -0
  703. package/templates/cpp-lib/windows/MyLib/resource.h +5 -0
  704. package/templates/cpp-lib/windows/MyLib/targetver.h +8 -0
  705. package/templates/cpp-lib/windows/MyLib.sln +156 -0
  706. package/templates/cpp-lib/windows/_gitignore +41 -0
  707. package/templates/templateUtils.js +137 -0
  708. package/types/index.d.ts +1 -0
  709. package/types/modules/globals.d.ts +1 -0
  710. package/Folly/TEMP_UntilFollyUpdate/hash/Hash.h +0 -1016
  711. package/Libraries/Components/Button.flow.js +0 -265
  712. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.windows.js +0 -8
  713. package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.windows.js +0 -14
  714. package/Libraries/Components/SafeAreaView/SafeAreaView.windows.js +0 -34
  715. package/Libraries/Components/ScrollView/ScrollView.windows.js +0 -1941
  716. package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +0 -85
  717. package/Libraries/Components/ToastAndroid/ToastAndroid.windows.js +0 -45
  718. package/Libraries/Components/Touchable/Touchable.flow.js +0 -284
  719. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +0 -189
  720. package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +0 -43
  721. package/Libraries/Image/Image.flow.js +0 -64
  722. package/Libraries/Inspector/DevtoolsOverlay.js +0 -223
  723. package/Libraries/Performance/QuickPerformanceLogger.js +0 -142
  724. package/Libraries/Settings/Settings.windows.js +0 -28
  725. package/Microsoft.ReactNative/CoreApp.cpp +0 -303
  726. package/Microsoft.ReactNative/CoreAppPage.cpp +0 -21
  727. package/Microsoft.ReactNative/CoreAppPage.idl +0 -12
  728. package/Microsoft.ReactNative/CoreAppPage.xaml +0 -14
  729. package/Microsoft.ReactNative/Fabric/Composition/AbiCompositionViewComponentView.cpp +0 -197
  730. package/Microsoft.ReactNative/Fabric/Composition/AbiCompositionViewComponentView.h +0 -84
  731. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/EventEmitters.h +0 -5
  732. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/Props.h +0 -5
  733. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/ShadowNodes.h +0 -5
  734. package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/States.h +0 -5
  735. package/Microsoft.ReactNative/Fabric/platform/react/renderer/core/graphicsConversions.h +0 -245
  736. package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Color.h +0 -134
  737. package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/conversions.h +0 -27
  738. package/Microsoft.ReactNative/Modules/TimingModule.cpp +0 -229
  739. package/Microsoft.ReactNative/Modules/TimingModule.h +0 -88
  740. package/Microsoft.ReactNative.Cxx/CoreApp.h +0 -60
  741. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/LongLivedObject.cpp +0 -60
  742. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/LongLivedObject.h +0 -60
  743. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleBinding.h +0 -63
  744. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/YogaLayoutableShadowNode.cpp +0 -1038
  745. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/YogaStylableProps.cpp +0 -503
  746. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/conversions.h +0 -895
  747. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/mapbuffer/MapBufferBuilder.cpp +0 -182
  748. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/mounting/ShadowTree.cpp +0 -543
  749. package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/uimanager/UIManagerBinding.cpp +0 -1505
  750. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/bits/NumericBitfield.h +0 -67
  751. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/config/Config.h +0 -93
  752. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/node/LayoutResults.h +0 -88
  753. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/node/Node.cpp +0 -606
  754. package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/node/Node.h +0 -344
  755. package/ReactCommon/Yoga.cpp +0 -961
  756. /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRect.js +0 -0
  757. /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRectReadOnly.js +0 -0
  758. /package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyText.js +0 -0
  759. /package/{Libraries/DOM/Nodes/Utilities → src/private/webapis/dom/nodes/utilities}/Traversal.js +0 -0
  760. /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/ArrayLikeUtils.js +0 -0
  761. /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/HTMLCollection.js +0 -0
  762. /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/NodeList.js +0 -0
  763. /package/{Libraries/WebPerformance → src/private/webapis/performance}/EventCounts.js +0 -0
  764. /package/{Libraries/WebPerformance → src/private/webapis/performance}/MemoryInfo.js +0 -0
  765. /package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEntry.js +0 -0
  766. /package/{Libraries/WebPerformance → src/private/webapis/performance}/ReactNativeStartupTiming.js +0 -0
  767. /package/{Libraries/WebPerformance → src/private/webapis/performance}/__mocks__/NativePerformance.js +0 -0
@@ -16,23 +16,578 @@
16
16
 
17
17
  #include <windows.ui.composition.interop.h>
18
18
 
19
+ #include <AutoDraw.h>
20
+ #include <Fabric/DWriteHelpers.h>
19
21
  #include <unicode.h>
20
22
  #include "CompositionDynamicAutomationProvider.h"
23
+ #include "JSValueReader.h"
24
+ #include "RootComponentView.h"
21
25
 
22
- namespace Microsoft::ReactNative {
26
+ namespace winrt::Microsoft::ReactNative::Composition::implementation {
23
27
 
24
28
  constexpr float c_scrollerLineDelta = 16.0f;
25
29
 
26
- std::shared_ptr<ScrollViewComponentView> ScrollViewComponentView::Create(
30
+ enum class ScrollbarHitRegion : int {
31
+ Unknown = -1,
32
+ ArrowFirst = 0,
33
+ PageUp = 1,
34
+ Thumb = 2,
35
+ PageDown = 3,
36
+ ArrowLast = 4,
37
+ };
38
+
39
+ struct ScrollBarComponent {
40
+ ScrollBarComponent(
41
+ const winrt::Microsoft::ReactNative::Composition::ScrollViewComponentView &outer,
42
+ const winrt::Microsoft::ReactNative::Composition::ICompositionContext &compContext,
43
+ winrt::Microsoft::ReactNative::ReactContext const &reactContext,
44
+ bool vertical)
45
+ : m_outer(outer), m_compContext(compContext), m_reactContext(reactContext), m_vertical(vertical) {
46
+ m_rootVisual = m_compContext.CreateSpriteVisual();
47
+ m_trackVisual = m_compContext.CreateRoundedRectangleVisual();
48
+ m_thumbVisual = m_compContext.CreateRoundedRectangleVisual();
49
+ m_arrowVisualFirst = m_compContext.CreateSpriteVisual();
50
+ m_arrowVisualLast = m_compContext.CreateSpriteVisual();
51
+
52
+ m_rootVisual.InsertAt(m_trackVisual, 0);
53
+ m_rootVisual.InsertAt(m_arrowVisualFirst, 1);
54
+ m_rootVisual.InsertAt(m_arrowVisualLast, 2);
55
+ m_rootVisual.InsertAt(m_thumbVisual, 3);
56
+
57
+ m_trackVisual.AnimationClass(winrt::Microsoft::ReactNative::Composition::AnimationClass::ScrollBar);
58
+ m_arrowVisualFirst.AnimationClass(winrt::Microsoft::ReactNative::Composition::AnimationClass::ScrollBar);
59
+ m_arrowVisualLast.AnimationClass(winrt::Microsoft::ReactNative::Composition::AnimationClass::ScrollBar);
60
+ m_thumbVisual.AnimationClass(
61
+ vertical ? winrt::Microsoft::ReactNative::Composition::AnimationClass::ScrollBarThumbVertical
62
+ : winrt::Microsoft::ReactNative::Composition::AnimationClass::ScrollBarThumbHorizontal);
63
+
64
+ updateShy(true);
65
+ onScaleChanged();
66
+ OnThemeChanged();
67
+ }
68
+
69
+ void OnThemeChanged() noexcept {
70
+ updateHighlight(ScrollbarHitRegion::ArrowFirst);
71
+ updateHighlight(ScrollbarHitRegion::ArrowLast);
72
+ updateHighlight(ScrollbarHitRegion::Thumb);
73
+ m_trackVisual.Brush(m_outer.Theme().PlatformBrush(L"ScrollBarTrackFill"));
74
+ }
75
+
76
+ void ContentSize(winrt::Windows::Foundation::Size contentSize) noexcept {
77
+ m_contentSize = contentSize;
78
+ updateThumb();
79
+ updateVisibility();
80
+ }
81
+
82
+ void updateTrack() noexcept {
83
+ if (m_vertical) {
84
+ m_trackVisual.Size({m_arrowSize, std::max(m_size.Height - (m_trackMargin * 2), 0.0f)});
85
+ m_trackVisual.Offset({-m_arrowSize, m_trackMargin, 0.0f}, {1.0f, 0.0f, 0.0f});
86
+ } else {
87
+ m_trackVisual.Size({std::max(m_size.Width - (m_trackMargin * 2), 0.0f), m_arrowSize});
88
+ m_trackVisual.Offset({m_trackMargin, -m_arrowSize, 0.0f}, {0.0f, 1.0f, 0.0f});
89
+ }
90
+ }
91
+
92
+ void updateLayoutMetrics(facebook::react::LayoutMetrics const &layoutMetrics) noexcept {
93
+ m_size = {
94
+ layoutMetrics.frame.size.width * layoutMetrics.pointScaleFactor,
95
+ layoutMetrics.frame.size.height * layoutMetrics.pointScaleFactor};
96
+
97
+ if (m_scaleFactor != layoutMetrics.pointScaleFactor) {
98
+ m_scaleFactor = layoutMetrics.pointScaleFactor;
99
+ onScaleChanged();
100
+ }
101
+
102
+ updateTrack();
103
+ updateThumb();
104
+ updateVisibility();
105
+ }
106
+
107
+ void updateVisibility() noexcept {
108
+ bool newVisibility = false;
109
+ if (m_vertical) {
110
+ newVisibility = (m_contentSize.Height > m_size.Height);
111
+ } else {
112
+ newVisibility = (m_contentSize.Width > m_size.Width);
113
+ }
114
+
115
+ if (newVisibility != m_visible) {
116
+ m_visible = newVisibility;
117
+ m_rootVisual.IsVisible(m_visible);
118
+ }
119
+ }
120
+
121
+ void updateRootAndArrowVisualOffsets() noexcept {
122
+ if (m_vertical) {
123
+ m_rootVisual.RelativeSizeWithOffset({m_arrowSize, 0.0f}, {0.0f, 1.0f});
124
+ m_rootVisual.Offset({-(m_arrowSize + m_trackEdgeMargin), 0.0f, 0.0f}, {1.0f, 0.0f, 0.0f});
125
+ m_arrowVisualFirst.Offset({0.0f, m_arrowMargin, 0.0f});
126
+ m_arrowVisualLast.Offset({0.0f, -(m_arrowSize + m_arrowMargin), 0.0f}, {0.0f, 1.0f, 0.0f});
127
+ } else {
128
+ m_rootVisual.RelativeSizeWithOffset({0.0f, m_arrowSize}, {1.0f, 0.0f});
129
+ m_rootVisual.Offset({0.0f, -(m_arrowSize + m_trackEdgeMargin), 0.0f}, {0.0f, 1.0f, 0.0f});
130
+ m_arrowVisualFirst.Offset({m_arrowMargin, 0.0f, 0.0f});
131
+ m_arrowVisualLast.Offset({-(m_arrowSize + m_arrowMargin), 0.0f, 0.0f}, {1.0f, 0.0f, 0.0f});
132
+ }
133
+ }
134
+
135
+ void onScaleChanged() noexcept {
136
+ m_arrowSize = 12 * m_scaleFactor; // From Xaml resource: ScrollBarSize
137
+ m_thumbWidth = 6 * m_scaleFactor; // From Xaml resource: ScrollBarThumbStrokeThickness
138
+ m_thumbShyWidth = 2 * m_scaleFactor;
139
+ m_arrowMargin = 4 * m_scaleFactor; // From Xaml resource: ScrollBar(Vertical|Horizontal)(Increase|Decrease)Margin
140
+ m_trackEdgeMargin = 1 * m_scaleFactor; // From Xaml resource: ScrollViewerScrollBarMargin
141
+ m_trackMargin =
142
+ (2 + 1) * m_scaleFactor; // From Xaml template VerticalPanningThumb.Margin + ScrollViewerScrollBarMargin
143
+ m_minThumbSize = static_cast<int>(
144
+ 30 * m_scaleFactor); // From Xaml resource: ScrollBarVerticalThumbMinHeight / ScrollBarHorizontalThumbMinWidth
145
+
146
+ m_thumbVisual.CornerRadius({m_thumbWidth / 2.0f, m_thumbWidth / 2.0f});
147
+ m_trackVisual.CornerRadius({m_arrowSize / 2.0f, m_arrowSize / 2.0f});
148
+
149
+ m_arrowVisualFirst.Size({m_arrowSize, m_arrowSize});
150
+ m_arrowVisualLast.Size({m_arrowSize, m_arrowSize});
151
+ m_arrowFirstDrawingSurface = nullptr; // Reset arrow textures when scale changes
152
+ m_arrowLastDrawingSurface = nullptr;
153
+ updateRootAndArrowVisualOffsets();
154
+ }
155
+
156
+ void ContentOffset(const winrt::Windows::Foundation::Numerics::float3 &offset) noexcept {
157
+ m_offset = offset;
158
+ updateThumb();
159
+ }
160
+
161
+ ScrollbarHitRegion HitTest(winrt::Windows::Foundation::Point pt) noexcept {
162
+ pt = {pt.X * m_scaleFactor, pt.Y * m_scaleFactor};
163
+ if (m_vertical) {
164
+ if (pt.X < m_size.Width - (m_arrowSize + m_trackEdgeMargin)) {
165
+ return ScrollbarHitRegion::Unknown;
166
+ }
167
+
168
+ if (pt.Y < (m_arrowSize + m_arrowMargin)) {
169
+ return ScrollbarHitRegion::ArrowFirst;
170
+ }
171
+
172
+ if (pt.Y < (m_arrowSize + m_arrowMargin) + m_thumbPos) {
173
+ return ScrollbarHitRegion::PageUp;
174
+ }
175
+
176
+ if (pt.Y < (m_arrowSize + m_arrowMargin) + m_thumbPos + m_thumbSize) {
177
+ return ScrollbarHitRegion::Thumb;
178
+ }
179
+
180
+ if (pt.Y < m_size.Height - (m_arrowSize + m_arrowMargin)) {
181
+ return ScrollbarHitRegion::PageDown;
182
+ }
183
+
184
+ return ScrollbarHitRegion::ArrowLast;
185
+ } else {
186
+ if (pt.Y < m_size.Height - (m_arrowSize + m_trackEdgeMargin)) {
187
+ return ScrollbarHitRegion::Unknown;
188
+ }
189
+
190
+ if (pt.X < (m_arrowSize + m_arrowMargin)) {
191
+ return ScrollbarHitRegion::ArrowFirst;
192
+ }
193
+
194
+ if (pt.X < (m_arrowSize + m_arrowMargin) + m_thumbPos) {
195
+ return ScrollbarHitRegion::PageUp;
196
+ }
197
+
198
+ if (pt.X < (m_arrowSize + m_arrowMargin) + m_thumbPos + m_thumbSize) {
199
+ return ScrollbarHitRegion::Thumb;
200
+ }
201
+
202
+ if (pt.X < m_size.Width - (m_arrowSize + m_arrowMargin)) {
203
+ return ScrollbarHitRegion::PageDown;
204
+ }
205
+
206
+ return ScrollbarHitRegion::ArrowLast;
207
+ }
208
+
209
+ return ScrollbarHitRegion::Unknown;
210
+ }
211
+
212
+ int getViewportSize() const noexcept {
213
+ return static_cast<int>(m_vertical ? m_size.Height : m_size.Width);
214
+ }
215
+
216
+ int calulateMaxThumbLength() const noexcept {
217
+ return std::max(static_cast<int>(getViewportSize() - (2 * (m_arrowSize + m_arrowMargin))), 0);
218
+ }
219
+
220
+ int getScrollRange() const noexcept {
221
+ return static_cast<int>(m_vertical ? m_contentSize.Height : m_contentSize.Width);
222
+ }
223
+
224
+ int getComputedPixelThumbSize() const noexcept {
225
+ auto maxThumbLength = calulateMaxThumbLength();
226
+ auto scrollRange = getScrollRange();
227
+ auto viewportSize = getViewportSize();
228
+ return std::max(::MulDiv(std::min(scrollRange, viewportSize), maxThumbLength, scrollRange), 0);
229
+ }
230
+
231
+ float scrollOffsetFromThumbPos(int thumbPos) const noexcept {
232
+ auto maxThumbLength = calulateMaxThumbLength();
233
+ auto scrollRange = getScrollRange();
234
+
235
+ const int computedPixelThumbSize = getComputedPixelThumbSize();
236
+
237
+ int thumbCorrection = 0;
238
+ if (!(m_minThumbSize <= computedPixelThumbSize || maxThumbLength < 2 * m_minThumbSize)) {
239
+ thumbCorrection = m_minThumbSize - computedPixelThumbSize;
240
+ }
241
+ return std::clamp(
242
+ static_cast<float>(::MulDiv(thumbPos, scrollRange, (maxThumbLength - thumbCorrection))),
243
+ 0.0f,
244
+ static_cast<float>(scrollRange));
245
+ }
246
+
247
+ void updateThumb() noexcept {
248
+ auto maxThumbLength = calulateMaxThumbLength();
249
+ auto scrollRange = getScrollRange();
250
+ auto scrollOffset = static_cast<int>(m_vertical ? m_offset.y : m_offset.x);
251
+
252
+ const int computedPixelThumbSize = getComputedPixelThumbSize();
253
+
254
+ m_thumbSize = 0;
255
+ int thumbCorrection = 0;
256
+
257
+ if (m_minThumbSize <= computedPixelThumbSize || maxThumbLength < 2 * m_minThumbSize)
258
+ m_thumbSize = computedPixelThumbSize;
259
+ else {
260
+ thumbCorrection = m_minThumbSize - computedPixelThumbSize;
261
+ m_thumbSize = m_minThumbSize;
262
+ }
263
+
264
+ // Position is relative to available area for thumb
265
+ m_thumbPos = (scrollRange > 0 ? ::MulDiv(scrollOffset, maxThumbLength - thumbCorrection, scrollRange) : 0);
266
+
267
+ auto thumbOffset = (m_arrowSize - m_thumbWidth) / 2.0f;
268
+ auto shyOffset = m_shy ? (m_thumbWidth - m_thumbShyWidth) : 0.0f;
269
+ auto thumbScale = m_shy ? (m_thumbShyWidth / m_thumbWidth) : 1.0f;
270
+
271
+ if (m_vertical) {
272
+ m_thumbVisual.Size({m_thumbWidth, static_cast<float>(m_thumbSize)});
273
+ m_thumbVisual.Offset(
274
+ {-m_arrowSize + thumbOffset + shyOffset, m_arrowSize + m_arrowMargin + static_cast<float>(m_thumbPos), 0.0f},
275
+ {1.0f, 0.0f, 0.0f});
276
+ m_thumbVisual.Scale({thumbScale, 1.0f, 1.0f});
277
+ } else {
278
+ m_thumbVisual.Size({static_cast<float>(m_thumbSize), m_thumbWidth});
279
+ m_thumbVisual.Offset(
280
+ {m_arrowSize + m_arrowMargin + static_cast<float>(m_thumbPos), -m_arrowSize + thumbOffset + shyOffset, 0.0f},
281
+ {0.0f, 1.0f, 0.0f});
282
+ m_thumbVisual.Scale({1.0f, thumbScale, 1.0f});
283
+ }
284
+ }
285
+
286
+ winrt::Microsoft::ReactNative::Composition::IVisual Visual() const noexcept {
287
+ return m_rootVisual;
288
+ }
289
+
290
+ void OnPointerReleased(const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) {
291
+ if (!m_visible)
292
+ return;
293
+ auto pt = args.GetCurrentPoint(m_outer.Tag());
294
+ if (m_nTrackInputOffset != -1 &&
295
+ pt.PointerDeviceType() == winrt::Microsoft::ReactNative::Composition::Input::PointerDeviceType::Mouse &&
296
+ pt.Properties().PointerUpdateKind() ==
297
+ winrt::Microsoft::ReactNative::Composition::Input::PointerUpdateKind::LeftButtonReleased) {
298
+ handleMoveThumb(args);
299
+ stopTrackingThumb();
300
+ m_outer.ReleasePointerCapture(args.Pointer());
301
+
302
+ auto reg = HitTest(pt.Position());
303
+ updateShy(reg == ScrollbarHitRegion::Unknown);
304
+ }
305
+ }
306
+
307
+ void stopTrackingThumb() noexcept {
308
+ m_nTrackInputOffset = -1;
309
+ m_thumbVisual.AnimationClass(
310
+ m_vertical ? winrt::Microsoft::ReactNative::Composition::AnimationClass::ScrollBarThumbVertical
311
+ : winrt::Microsoft::ReactNative::Composition::AnimationClass::ScrollBarThumbHorizontal);
312
+ }
313
+
314
+ void handleMoveThumb(const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) {
315
+ auto pt = args.GetCurrentPoint(m_outer.Tag());
316
+ auto pos = pt.Position();
317
+
318
+ auto newTrackingPosition = static_cast<int>((m_vertical ? pos.Y : pos.X) * m_scaleFactor) - m_nTrackInputOffset;
319
+ winrt::get_self<ScrollViewComponentView>(m_outer)->scrollTo(
320
+ m_vertical ? winrt::Windows::Foundation::Numerics::
321
+ float3{m_offset.x, scrollOffsetFromThumbPos(newTrackingPosition), m_offset.z}
322
+ : winrt::Windows::Foundation::Numerics::
323
+ float3{scrollOffsetFromThumbPos(newTrackingPosition), m_offset.y, m_offset.z},
324
+ false);
325
+ args.Handled(true);
326
+ }
327
+
328
+ void OnPointerPressed(const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) {
329
+ if (!m_visible)
330
+ return;
331
+ auto pt = args.GetCurrentPoint(m_outer.Tag());
332
+ if (pt.PointerDeviceType() == winrt::Microsoft::ReactNative::Composition::Input::PointerDeviceType::Mouse) {
333
+ auto pos = pt.Position();
334
+ auto reg = HitTest(pos);
335
+
336
+ switch (reg) {
337
+ case ScrollbarHitRegion::ArrowFirst:
338
+ if (m_vertical) {
339
+ winrt::get_self<ScrollViewComponentView>(m_outer)->lineUp(false);
340
+ } else {
341
+ winrt::get_self<ScrollViewComponentView>(m_outer)->lineLeft(false);
342
+ }
343
+ args.Handled(true);
344
+ break;
345
+ case ScrollbarHitRegion::ArrowLast:
346
+ if (m_vertical) {
347
+ winrt::get_self<ScrollViewComponentView>(m_outer)->lineDown(false);
348
+ } else {
349
+ winrt::get_self<ScrollViewComponentView>(m_outer)->lineRight(false);
350
+ }
351
+ args.Handled(true);
352
+ break;
353
+ case ScrollbarHitRegion::PageUp:
354
+ if (m_vertical) {
355
+ winrt::get_self<ScrollViewComponentView>(m_outer)->pageUp(false);
356
+ }
357
+ args.Handled(true);
358
+ break;
359
+ case ScrollbarHitRegion::PageDown:
360
+ if (m_vertical) {
361
+ winrt::get_self<ScrollViewComponentView>(m_outer)->pageDown(false);
362
+ }
363
+ args.Handled(true);
364
+ break;
365
+ case ScrollbarHitRegion::Thumb: {
366
+ m_outer.CapturePointer(args.Pointer());
367
+ m_nTrackInputOffset = static_cast<int>((m_vertical ? pos.Y : pos.X) * m_scaleFactor) - m_thumbPos;
368
+ m_thumbVisual.AnimationClass(winrt::Microsoft::ReactNative::Composition::AnimationClass::None);
369
+ handleMoveThumb(args);
370
+ }
371
+ }
372
+ }
373
+ }
374
+
375
+ void OnPointerMoved(const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) {
376
+ if (!m_visible)
377
+ return;
378
+ auto pt = args.GetCurrentPoint(m_outer.Tag());
379
+ if (pt.PointerDeviceType() == winrt::Microsoft::ReactNative::Composition::Input::PointerDeviceType::Mouse) {
380
+ if (m_nTrackInputOffset != -1) {
381
+ handleMoveThumb(args);
382
+ } else {
383
+ auto pos = pt.Position();
384
+ auto reg = HitTest(pos);
385
+ updateShy(reg == ScrollbarHitRegion::Unknown);
386
+ setHighlightedRegion(reg);
387
+ }
388
+ }
389
+ }
390
+
391
+ void OnPointerCaptureLost() {
392
+ if (!m_visible)
393
+ return;
394
+
395
+ stopTrackingThumb();
396
+ updateShy(true);
397
+ }
398
+
399
+ void updateShy(bool shy) {
400
+ if (shy == m_shy)
401
+ return;
402
+
403
+ m_shy = shy;
404
+
405
+ m_trackVisual.Opacity(m_shy ? 0.0f : 1.0f);
406
+ m_arrowVisualFirst.Opacity(m_shy ? 0.0f : 1.0f);
407
+ m_arrowVisualLast.Opacity(m_shy ? 0.0f : 1.0f);
408
+
409
+ updateThumb();
410
+ }
411
+
412
+ void setHighlightedRegion(ScrollbarHitRegion region) noexcept {
413
+ if (m_highlightedRegion == region)
414
+ return;
415
+
416
+ auto oldRegion = m_highlightedRegion;
417
+ m_highlightedRegion = region;
418
+ updateHighlight(oldRegion);
419
+ updateHighlight(m_highlightedRegion);
420
+ }
421
+
422
+ // Renders the text into our composition surface
423
+ void drawArrow(ScrollbarHitRegion region, bool disabled, bool hovered) noexcept {
424
+ auto &drawingSurface =
425
+ (region == ScrollbarHitRegion::ArrowFirst) ? m_arrowFirstDrawingSurface : m_arrowLastDrawingSurface;
426
+ if (!drawingSurface) {
427
+ drawingSurface = m_compContext.CreateDrawingSurfaceBrush(
428
+ {m_arrowSize, m_arrowSize},
429
+ winrt::Windows::Graphics::DirectX::DirectXPixelFormat::B8G8R8A8UIntNormalized,
430
+ winrt::Windows::Graphics::DirectX::DirectXAlphaMode::Premultiplied);
431
+ }
432
+
433
+ if (winrt::get_self<ScrollViewComponentView>(m_outer)->theme()->IsEmpty()) {
434
+ return;
435
+ }
436
+
437
+ winrt::com_ptr<IDWriteTextFormat> spTextFormat;
438
+ winrt::check_hresult(::Microsoft::ReactNative::DWriteFactory()->CreateTextFormat(
439
+ L"Segoe Fluent Icons",
440
+ nullptr, // Font collection (nullptr sets it to use the system font collection).
441
+ DWRITE_FONT_WEIGHT_REGULAR,
442
+ DWRITE_FONT_STYLE_NORMAL,
443
+ DWRITE_FONT_STRETCH_NORMAL,
444
+ 8, // Xaml resource: ScrollBarButtonArrowIconFontSize
445
+ L"",
446
+ spTextFormat.put()));
447
+
448
+ winrt::check_hresult(spTextFormat->SetTextAlignment(DWRITE_TEXT_ALIGNMENT_CENTER));
449
+
450
+ winrt::com_ptr<IDWriteTextLayout> spTextLayout;
451
+ winrt::check_hresult(::Microsoft::ReactNative::DWriteFactory()->CreateTextLayout(
452
+ m_vertical ? ((region == ScrollbarHitRegion::ArrowFirst) ? L"\uEDDB" : L"\uEDDC")
453
+ : ((region == ScrollbarHitRegion::ArrowFirst) ? L"\uEDD9" : L"\uEDDA"),
454
+ 1, // The length of the string.
455
+ spTextFormat.get(), // The text format to apply to the string (contains font information, etc).
456
+ (m_arrowSize / m_scaleFactor), // The width of the layout box.
457
+ (m_arrowSize / m_scaleFactor), // The height of the layout box.
458
+ spTextLayout.put() // The IDWriteTextLayout interface pointer.
459
+ ));
460
+
461
+ POINT offset;
462
+ {
463
+ ::Microsoft::ReactNative::Composition::AutoDrawDrawingSurface autoDraw(drawingSurface, &offset);
464
+ if (auto d2dDeviceContext = autoDraw.GetRenderTarget()) {
465
+ d2dDeviceContext->Clear(D2D1::ColorF(D2D1::ColorF::Black, 0.0f));
466
+ assert(d2dDeviceContext->GetUnitMode() == D2D1_UNIT_MODE_DIPS);
467
+ const auto dpi = m_scaleFactor * 96.0f;
468
+ float oldDpiX, oldDpiY;
469
+ d2dDeviceContext->GetDpi(&oldDpiX, &oldDpiY);
470
+ d2dDeviceContext->SetDpi(dpi, dpi);
471
+
472
+ // Create a solid color brush for the text. A more sophisticated application might want
473
+ // to cache and reuse a brush across all text elements instead, taking care to recreate
474
+ // it in the event of device removed.
475
+ winrt::com_ptr<ID2D1SolidColorBrush> brush;
476
+
477
+ D2D1::ColorF color{0};
478
+ if (disabled) {
479
+ color = winrt::get_self<ScrollViewComponentView>(m_outer)->theme()->D2DPlatformColor(
480
+ "ScrollBarButtonArrowForegroundDisabled");
481
+ } else if (hovered) {
482
+ color = winrt::get_self<ScrollViewComponentView>(m_outer)->theme()->D2DPlatformColor(
483
+ "ScrollBarButtonArrowForegroundPointerOver");
484
+ } else {
485
+ color = winrt::get_self<ScrollViewComponentView>(m_outer)->theme()->D2DPlatformColor(
486
+ "ScrollBarButtonArrowForeground");
487
+ }
488
+ winrt::check_hresult(d2dDeviceContext->CreateSolidColorBrush(color, brush.put()));
489
+
490
+ {
491
+ DWRITE_TEXT_METRICS dtm{};
492
+ winrt::check_hresult(spTextLayout->GetMetrics(&dtm));
493
+ offset.y += static_cast<int>((m_arrowSize - dtm.height) / 2.0f);
494
+ }
495
+
496
+ // Draw the line of text at the specified offset, which corresponds to the top-left
497
+ // corner of our drawing surface. Notice we don't call BeginDraw on the D2D device
498
+ // context; this has already been done for us by the composition API.
499
+ d2dDeviceContext->DrawTextLayout(
500
+ D2D1::Point2F(
501
+ static_cast<FLOAT>((offset.x) / m_scaleFactor), static_cast<FLOAT>((offset.y) / m_scaleFactor)),
502
+ spTextLayout.get(),
503
+ brush.get(),
504
+ D2D1_DRAW_TEXT_OPTIONS_ENABLE_COLOR_FONT);
505
+
506
+ // restore dpi to old state
507
+ d2dDeviceContext->SetDpi(oldDpiX, oldDpiY);
508
+ }
509
+ }
510
+ if (drawingSurface) {
511
+ drawingSurface.HorizontalAlignmentRatio(0.0f);
512
+ drawingSurface.VerticalAlignmentRatio(0.0f);
513
+ drawingSurface.Stretch(winrt::Microsoft::ReactNative::Composition::CompositionStretch::None);
514
+ }
515
+
516
+ auto &arrowVisual = (region == ScrollbarHitRegion::ArrowFirst) ? m_arrowVisualFirst : m_arrowVisualLast;
517
+ arrowVisual.Brush(drawingSurface);
518
+ }
519
+
520
+ void updateHighlight(ScrollbarHitRegion region) noexcept {
521
+ switch (region) {
522
+ case ScrollbarHitRegion::ArrowFirst:
523
+ case ScrollbarHitRegion::ArrowLast: {
524
+ auto disabled = !std::static_pointer_cast<const facebook::react::ScrollViewProps>(
525
+ winrt::get_self<ScrollViewComponentView>(m_outer)->viewProps())
526
+ ->scrollEnabled;
527
+ drawArrow(region, disabled, m_highlightedRegion == region);
528
+ }
529
+ case ScrollbarHitRegion::Thumb: {
530
+ if (!std::static_pointer_cast<const facebook::react::ScrollViewProps>(
531
+ winrt::get_self<ScrollViewComponentView>(m_outer)->viewProps())
532
+ ->scrollEnabled) {
533
+ m_thumbVisual.Brush(m_outer.Theme().PlatformBrush(L"ScrollBarThumbFillDisabled"));
534
+ } else if (m_highlightedRegion == region) {
535
+ m_thumbVisual.Brush(m_outer.Theme().PlatformBrush(L"ScrollBarThumbFillPointerOver"));
536
+ } else {
537
+ m_thumbVisual.Brush(m_outer.Theme().PlatformBrush(L"ScrollBarThumbFill"));
538
+ }
539
+ }
540
+ }
541
+ }
542
+
543
+ private:
544
+ winrt::Microsoft::ReactNative::Composition::ScrollViewComponentView m_outer;
545
+ winrt::Microsoft::ReactNative::Composition::ICompositionContext m_compContext;
546
+ winrt::Microsoft::ReactNative::ReactContext m_reactContext;
547
+ const bool m_vertical;
548
+ bool m_visible{false};
549
+ bool m_shy{false};
550
+ int m_thumbSize{0};
551
+ float m_arrowSize{0};
552
+ float m_arrowMargin{0}; // margin on outside end of arrow buttons
553
+ float m_trackEdgeMargin{0}; // margin between track and edge of component
554
+ float m_trackMargin{0}; // margin of track background to ends of scrollbar
555
+ float m_thumbWidth{0};
556
+ float m_thumbShyWidth{0};
557
+ int m_minThumbSize{0};
558
+ float m_scaleFactor{1};
559
+ int m_thumbPos{0};
560
+ int m_nTrackInputOffset{-1};
561
+ ScrollbarHitRegion m_highlightedRegion{ScrollbarHitRegion::Unknown};
562
+ winrt::Windows::Foundation::Numerics::float3 m_offset{0};
563
+ winrt::Windows::Foundation::Size m_contentSize{0, 0};
564
+ winrt::Windows::Foundation::Size m_size{0, 0};
565
+ winrt::Microsoft::ReactNative::Composition::ISpriteVisual m_rootVisual{nullptr};
566
+ winrt::Microsoft::ReactNative::Composition::IRoundedRectangleVisual m_thumbVisual{nullptr};
567
+ winrt::Microsoft::ReactNative::Composition::ISpriteVisual m_arrowVisualFirst{nullptr};
568
+ winrt::Microsoft::ReactNative::Composition::ISpriteVisual m_arrowVisualLast{nullptr};
569
+ winrt::Microsoft::ReactNative::Composition::IDrawingSurfaceBrush m_arrowFirstDrawingSurface{nullptr};
570
+ winrt::Microsoft::ReactNative::Composition::IDrawingSurfaceBrush m_arrowLastDrawingSurface{nullptr};
571
+ winrt::Microsoft::ReactNative::Composition::IRoundedRectangleVisual m_trackVisual{nullptr};
572
+ };
573
+
574
+ winrt::Microsoft::ReactNative::ComponentView ScrollViewComponentView::Create(
27
575
  const winrt::Microsoft::ReactNative::Composition::ICompositionContext &compContext,
28
- facebook::react::Tag tag) noexcept {
29
- return std::shared_ptr<ScrollViewComponentView>(new ScrollViewComponentView(compContext, tag));
576
+ facebook::react::Tag tag,
577
+ winrt::Microsoft::ReactNative::ReactContext const &reactContext) noexcept {
578
+ return winrt::make<ScrollViewComponentView>(compContext, tag, reactContext);
30
579
  }
31
580
 
32
581
  ScrollViewComponentView::ScrollViewComponentView(
33
582
  const winrt::Microsoft::ReactNative::Composition::ICompositionContext &compContext,
34
- facebook::react::Tag tag)
35
- : Super(compContext, tag) {
583
+ facebook::react::Tag tag,
584
+ winrt::Microsoft::ReactNative::ReactContext const &reactContext)
585
+ : Super(
586
+ compContext,
587
+ tag,
588
+ reactContext,
589
+ ComponentViewFeatures::Default & ~ComponentViewFeatures::Background,
590
+ false) {
36
591
  static auto const defaultProps = std::make_shared<facebook::react::ScrollViewProps const>();
37
592
  m_props = defaultProps;
38
593
 
@@ -125,20 +680,30 @@ ScrollViewComponentView::ScrollViewComponentView(
125
680
  */
126
681
  }
127
682
 
128
- void ScrollViewComponentView::mountChildComponentView(IComponentView &childComponentView, uint32_t index) noexcept {
129
- ensureVisual();
130
-
131
- m_children.insert(std::next(m_children.begin(), index), &childComponentView);
132
- childComponentView.parent(this);
683
+ void ScrollViewComponentView::MountChildComponentView(
684
+ const winrt::Microsoft::ReactNative::ComponentView &childComponentView,
685
+ uint32_t index) noexcept {
686
+ base_type::MountChildComponentView(childComponentView, index);
133
687
 
134
- m_scrollVisual.InsertAt(static_cast<CompositionBaseComponentView &>(childComponentView).OuterVisual(), index);
688
+ ensureVisual();
689
+ m_scrollVisual.InsertAt(
690
+ childComponentView.as<winrt::Microsoft::ReactNative::Composition::implementation::ComponentView>()->OuterVisual(),
691
+ index);
135
692
  }
136
693
 
137
- void ScrollViewComponentView::unmountChildComponentView(IComponentView &childComponentView, uint32_t index) noexcept {
138
- m_children.erase(std::next(m_children.begin(), index));
694
+ void ScrollViewComponentView::UnmountChildComponentView(
695
+ const winrt::Microsoft::ReactNative::ComponentView &childComponentView,
696
+ uint32_t index) noexcept {
697
+ base_type::UnmountChildComponentView(childComponentView, index);
698
+ m_scrollVisual.Remove(childComponentView.as<ComponentView>()->OuterVisual());
699
+ }
139
700
 
140
- m_scrollVisual.Remove(static_cast<CompositionBaseComponentView &>(childComponentView).OuterVisual());
141
- childComponentView.parent(nullptr);
701
+ void ScrollViewComponentView::updateBackgroundColor(const facebook::react::SharedColor &color) noexcept {
702
+ if (color) {
703
+ m_scrollVisual.Brush(theme()->Brush(*color));
704
+ } else {
705
+ m_scrollVisual.Brush(m_compContext.CreateColorBrush({0, 0, 0, 0}));
706
+ }
142
707
  }
143
708
 
144
709
  void ScrollViewComponentView::updateProps(
@@ -150,17 +715,15 @@ void ScrollViewComponentView::updateProps(
150
715
  ensureVisual();
151
716
 
152
717
  if (!oldProps || oldViewProps.backgroundColor != newViewProps.backgroundColor) {
153
- if (newViewProps.backgroundColor) {
154
- m_scrollVisual.Brush(m_compContext.CreateColorBrush(newViewProps.backgroundColor.AsWindowsColor()));
155
- } else {
156
- m_scrollVisual.Brush(m_compContext.CreateColorBrush({0, 0, 0, 0}));
157
- }
718
+ updateBackgroundColor(newViewProps.backgroundColor);
719
+ }
720
+ if (oldViewProps.testId != newViewProps.testId) {
721
+ m_visual.Comment(winrt::to_hstring(newViewProps.testId));
158
722
  }
159
723
 
160
724
  // update BaseComponentView props
161
- updateShadowProps(oldViewProps, newViewProps, m_visual);
162
725
  updateTransformProps(oldViewProps, newViewProps, m_visual);
163
- updateBorderProps(oldViewProps, newViewProps);
726
+ Super::updateProps(props, oldProps);
164
727
 
165
728
  m_props = std::static_pointer_cast<facebook::react::ViewProps const>(props);
166
729
  }
@@ -168,12 +731,27 @@ void ScrollViewComponentView::updateProps(
168
731
  void ScrollViewComponentView::updateState(
169
732
  facebook::react::State::Shared const &state,
170
733
  facebook::react::State::Shared const &oldState) noexcept {
171
- const auto &newState = *std::static_pointer_cast<facebook::react::ScrollViewShadowNode::ConcreteState const>(state);
172
-
173
- m_contentSize = newState.getData().getContentSize();
734
+ m_state = std::static_pointer_cast<facebook::react::ScrollViewShadowNode::ConcreteState const>(state);
735
+ m_contentSize = m_state->getData().getContentSize();
174
736
  updateContentVisualSize();
175
737
  }
176
738
 
739
+ void ScrollViewComponentView::updateStateWithContentOffset() noexcept {
740
+ if (!m_state) {
741
+ return;
742
+ }
743
+
744
+ auto scrollPosition = m_scrollVisual.ScrollPosition();
745
+ m_verticalScrollbarComponent->ContentOffset(scrollPosition);
746
+ m_horizontalScrollbarComponent->ContentOffset(scrollPosition);
747
+
748
+ m_state->updateState([scrollPosition](const facebook::react::ScrollViewShadowNode::ConcreteState::Data &data) {
749
+ auto newData = data;
750
+ newData.contentOffset = {scrollPosition.x, scrollPosition.y};
751
+ return std::make_shared<facebook::react::ScrollViewShadowNode::ConcreteState::Data const>(newData);
752
+ });
753
+ }
754
+
177
755
  void ScrollViewComponentView::updateLayoutMetrics(
178
756
  facebook::react::LayoutMetrics const &layoutMetrics,
179
757
  facebook::react::LayoutMetrics const &oldLayoutMetrics) noexcept {
@@ -184,11 +762,9 @@ void ScrollViewComponentView::updateLayoutMetrics(
184
762
  OuterVisual().IsVisible(layoutMetrics.displayType != facebook::react::DisplayType::None);
185
763
  }
186
764
 
187
- // m_needsBorderUpdate = true;
188
- updateBorderLayoutMetrics(layoutMetrics, *m_props);
189
- m_layoutMetrics = layoutMetrics;
190
-
191
- UpdateCenterPropertySet();
765
+ m_verticalScrollbarComponent->updateLayoutMetrics(layoutMetrics);
766
+ m_horizontalScrollbarComponent->updateLayoutMetrics(layoutMetrics);
767
+ Super::updateLayoutMetrics(layoutMetrics, oldLayoutMetrics);
192
768
  m_visual.Size(
193
769
  {layoutMetrics.frame.size.width * layoutMetrics.pointScaleFactor,
194
770
  layoutMetrics.frame.size.height * layoutMetrics.pointScaleFactor});
@@ -199,17 +775,18 @@ void ScrollViewComponentView::updateLayoutMetrics(
199
775
  }
200
776
 
201
777
  void ScrollViewComponentView::updateContentVisualSize() noexcept {
202
- m_scrollVisual.ContentSize(
203
- {std::max(m_contentSize.width, m_layoutMetrics.frame.size.width) * m_layoutMetrics.pointScaleFactor,
204
- std::max(m_contentSize.height, m_layoutMetrics.frame.size.height) * m_layoutMetrics.pointScaleFactor});
778
+ winrt::Windows::Foundation::Size contentSize = {
779
+ std::max(m_contentSize.width, m_layoutMetrics.frame.size.width) * m_layoutMetrics.pointScaleFactor,
780
+ std::max(m_contentSize.height, m_layoutMetrics.frame.size.height) * m_layoutMetrics.pointScaleFactor};
781
+ m_verticalScrollbarComponent->ContentSize(contentSize);
782
+ m_horizontalScrollbarComponent->ContentSize(contentSize);
783
+ m_scrollVisual.ContentSize(contentSize);
205
784
  }
206
785
 
207
- void ScrollViewComponentView::finalizeUpdates(RNComponentViewUpdateMask updateMask) noexcept {
208
- // m_element.FinalizeProperties();
209
- }
210
786
  void ScrollViewComponentView::prepareForRecycle() noexcept {}
211
- facebook::react::Props::Shared ScrollViewComponentView::props() noexcept {
212
- return static_cast<facebook::react::Props::Shared>(m_props);
787
+
788
+ facebook::react::SharedViewProps ScrollViewComponentView::viewProps() noexcept {
789
+ return m_props;
213
790
  }
214
791
 
215
792
  /*
@@ -257,7 +834,14 @@ void ScrollViewComponentView::OnPointerDown(const winrt::Windows::UI::Input::Poi
257
834
  }
258
835
  */
259
836
 
260
- void ScrollViewComponentView::onPointerWheelChanged(
837
+ void ScrollViewComponentView::onThemeChanged() noexcept {
838
+ updateBackgroundColor(std::static_pointer_cast<const facebook::react::ScrollViewProps>(m_props)->backgroundColor);
839
+ m_verticalScrollbarComponent->OnThemeChanged();
840
+ m_horizontalScrollbarComponent->OnThemeChanged();
841
+ Super::onThemeChanged();
842
+ }
843
+
844
+ void ScrollViewComponentView::OnPointerWheelChanged(
261
845
  const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept {
262
846
  auto ppp = args.GetCurrentPoint(-1).Properties();
263
847
  auto delta = static_cast<float>(ppp.MouseWheelDelta());
@@ -284,7 +868,34 @@ void ScrollViewComponentView::onPointerWheelChanged(
284
868
  }
285
869
  }
286
870
 
287
- void ScrollViewComponentView::onKeyDown(
871
+ void ScrollViewComponentView::OnPointerPressed(
872
+ const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept {
873
+ m_verticalScrollbarComponent->OnPointerPressed(args);
874
+ m_horizontalScrollbarComponent->OnPointerPressed(args);
875
+ Super::OnPointerPressed(args);
876
+ }
877
+
878
+ void ScrollViewComponentView::OnPointerReleased(
879
+ const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept {
880
+ m_verticalScrollbarComponent->OnPointerReleased(args);
881
+ m_horizontalScrollbarComponent->OnPointerReleased(args);
882
+ Super::OnPointerReleased(args);
883
+ }
884
+
885
+ void ScrollViewComponentView::OnPointerMoved(
886
+ const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept {
887
+ m_verticalScrollbarComponent->OnPointerMoved(args);
888
+ m_horizontalScrollbarComponent->OnPointerMoved(args);
889
+ Super::OnPointerMoved(args);
890
+ }
891
+
892
+ void ScrollViewComponentView::OnPointerCaptureLost() noexcept {
893
+ m_verticalScrollbarComponent->OnPointerCaptureLost();
894
+ m_horizontalScrollbarComponent->OnPointerCaptureLost();
895
+ Super::OnPointerCaptureLost();
896
+ }
897
+
898
+ void ScrollViewComponentView::OnKeyDown(
288
899
  const winrt::Microsoft::ReactNative::Composition::Input::KeyboardSource &source,
289
900
  const winrt::Microsoft::ReactNative::Composition::Input::KeyRoutedEventArgs &args) noexcept {
290
901
  switch (args.Key()) {
@@ -396,25 +1007,37 @@ bool ScrollViewComponentView::scrollRight(float delta, bool animate) noexcept {
396
1007
  return true;
397
1008
  }
398
1009
 
399
- void ScrollViewComponentView::handleCommand(std::string const &commandName, folly::dynamic const &arg) noexcept {
400
- if (commandName == "scrollTo") {
401
- auto x = arg[0].asDouble() * m_layoutMetrics.pointScaleFactor;
402
- auto y = arg[1].asDouble() * m_layoutMetrics.pointScaleFactor;
403
- auto animate = arg[2].asBool();
404
- m_scrollVisual.TryUpdatePosition({static_cast<float>(x), static_cast<float>(y), 0.0f}, animate);
405
- } else if (commandName == "flashScrollIndicators") {
1010
+ void ScrollViewComponentView::HandleCommand(
1011
+ winrt::hstring commandName,
1012
+ const winrt::Microsoft::ReactNative::IJSValueReader &args) noexcept {
1013
+ if (commandName == L"scrollTo") {
1014
+ double x, y;
1015
+ bool animate;
1016
+ winrt::Microsoft::ReactNative::ReadArgs(args, x, y, animate);
1017
+ scrollTo(
1018
+ {static_cast<float>(x) * m_layoutMetrics.pointScaleFactor,
1019
+ static_cast<float>(y) * m_layoutMetrics.pointScaleFactor,
1020
+ 0.0f},
1021
+ animate);
1022
+ } else if (commandName == L"flashScrollIndicators") {
406
1023
  // No-op for now
407
- } else if (commandName == "scrollToEnd") {
408
- auto animate = arg[0].asBool();
1024
+ } else if (commandName == L"scrollToEnd") {
1025
+ bool animate;
1026
+ winrt::Microsoft::ReactNative::ReadArgs(args, animate);
409
1027
  scrollToEnd(animate);
410
- } else if (commandName == "zoomToRect") {
1028
+ } else if (commandName == L"zoomToRect") {
411
1029
  // No-op for now
412
1030
  } else {
413
- Super::handleCommand(commandName, arg);
1031
+ Super::HandleCommand(commandName, args);
414
1032
  }
415
1033
  }
416
1034
 
417
- void ScrollViewComponentView::StartBringIntoView(BringIntoViewOptions &&options) noexcept {
1035
+ void ScrollViewComponentView::scrollTo(winrt::Windows::Foundation::Numerics::float3 offset, bool animate) noexcept {
1036
+ m_scrollVisual.TryUpdatePosition(offset, animate);
1037
+ }
1038
+
1039
+ void ScrollViewComponentView::StartBringIntoView(
1040
+ winrt::Microsoft::ReactNative::implementation::BringIntoViewOptions &&options) noexcept {
418
1041
  RECT rc{getClientRect()};
419
1042
 
420
1043
  if (!options.TargetRect) {
@@ -502,7 +1125,8 @@ void ScrollViewComponentView::StartBringIntoView(BringIntoViewOptions &&options)
502
1125
 
503
1126
  options.TargetRect = facebook::react::Rect::intersect(viewerRect, options.TargetRect.value());
504
1127
 
505
- m_parent->StartBringIntoView(std::move(options));
1128
+ winrt::get_self<winrt::Microsoft::ReactNative::implementation::ComponentView>(m_parent)->StartBringIntoView(
1129
+ std::move(options));
506
1130
  }
507
1131
  }
508
1132
 
@@ -510,12 +1134,17 @@ void ScrollViewComponentView::ensureVisual() noexcept {
510
1134
  if (!m_visual) {
511
1135
  m_visual = m_compContext.CreateSpriteVisual();
512
1136
  m_scrollVisual = m_compContext.CreateScrollerVisual();
1137
+ m_verticalScrollbarComponent = std::make_shared<ScrollBarComponent>(*this, m_compContext, m_reactContext, true);
1138
+ m_horizontalScrollbarComponent = std::make_shared<ScrollBarComponent>(*this, m_compContext, m_reactContext, false);
513
1139
  m_visual.InsertAt(m_scrollVisual, 0);
1140
+ m_visual.InsertAt(m_verticalScrollbarComponent->Visual(), 1);
1141
+ m_visual.InsertAt(m_horizontalScrollbarComponent->Visual(), 2);
514
1142
  m_scrollPositionChangedRevoker = m_scrollVisual.ScrollPositionChanged(
515
1143
  winrt::auto_revoke,
516
1144
  [this](
517
1145
  winrt::IInspectable const & /*sender*/,
518
1146
  winrt::Microsoft::ReactNative::Composition::IScrollPositionChangedArgs const &args) {
1147
+ updateStateWithContentOffset();
519
1148
  auto eventEmitter = GetEventEmitter();
520
1149
  if (eventEmitter) {
521
1150
  facebook::react::ScrollViewMetrics scrollMetrics;
@@ -545,25 +1174,39 @@ facebook::react::Tag ScrollViewComponentView::hitTest(
545
1174
  ptViewport.y + m_scrollVisual.ScrollPosition().y / m_layoutMetrics.pointScaleFactor};
546
1175
 
547
1176
  facebook::react::Tag targetTag;
548
- if ((ignorePointerEvents || m_props->pointerEvents == facebook::react::PointerEventsMode::Auto ||
549
- m_props->pointerEvents == facebook::react::PointerEventsMode::BoxNone) &&
550
- std::any_of(m_children.rbegin(), m_children.rend(), [&targetTag, &ptContent, &localPt](auto child) {
551
- targetTag = static_cast<const CompositionBaseComponentView *>(child)->hitTest(ptContent, localPt);
552
- return targetTag != -1;
553
- }))
554
- return targetTag;
555
1177
 
556
1178
  if ((ignorePointerEvents || m_props->pointerEvents == facebook::react::PointerEventsMode::Auto ||
557
1179
  m_props->pointerEvents == facebook::react::PointerEventsMode::BoxOnly) &&
558
1180
  ptViewport.x >= 0 && ptViewport.x <= m_layoutMetrics.frame.size.width && ptViewport.y >= 0 &&
559
1181
  ptViewport.y <= m_layoutMetrics.frame.size.height) {
560
- localPt = ptViewport;
561
- return this->tag();
1182
+ if ((ignorePointerEvents || m_props->pointerEvents == facebook::react::PointerEventsMode::Auto ||
1183
+ m_props->pointerEvents == facebook::react::PointerEventsMode::BoxNone) &&
1184
+ anyHitTestHelper(targetTag, ptContent, localPt))
1185
+ return targetTag;
1186
+
1187
+ if (ignorePointerEvents || m_props->pointerEvents == facebook::react::PointerEventsMode::Auto ||
1188
+ m_props->pointerEvents == facebook::react::PointerEventsMode::BoxOnly) {
1189
+ return this->Tag();
1190
+ }
562
1191
  }
563
1192
 
564
1193
  return -1;
565
1194
  }
566
1195
 
1196
+ facebook::react::Point ScrollViewComponentView::getClientOffset() const noexcept {
1197
+ facebook::react::Point parentOffset{0};
1198
+ if (m_parent) {
1199
+ parentOffset =
1200
+ winrt::get_self<winrt::Microsoft::ReactNative::implementation::ComponentView>(m_parent)->getClientOffset();
1201
+ }
1202
+
1203
+ return {
1204
+ m_layoutMetrics.frame.origin.x * m_layoutMetrics.pointScaleFactor - m_scrollVisual.ScrollPosition().x +
1205
+ parentOffset.x,
1206
+ m_layoutMetrics.frame.origin.y * m_layoutMetrics.pointScaleFactor - m_scrollVisual.ScrollPosition().y +
1207
+ parentOffset.y};
1208
+ }
1209
+
567
1210
  winrt::Microsoft::ReactNative::Composition::IVisual ScrollViewComponentView::Visual() const noexcept {
568
1211
  return m_visual;
569
1212
  }
@@ -572,4 +1215,4 @@ std::string ScrollViewComponentView::DefaultControlType() const noexcept {
572
1215
  return "scrollbar";
573
1216
  }
574
1217
 
575
- } // namespace Microsoft::ReactNative
1218
+ } // namespace winrt::Microsoft::ReactNative::Composition::implementation