react-native-windows 0.73.11 → 0.74.0-preview.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.flowconfig +12 -7
- package/Chakra/ChakraUtils.cpp +5 -10
- package/Chakra/ChakraUtils.h +2 -2
- package/Common/packages.lock.json +3 -3
- package/Directory.Build.props +5 -5
- package/Folly/Folly.vcxproj +2 -2
- package/Folly/Folly.vcxproj.filters +7 -0
- package/Folly/TEMP_UntilFollyUpdate/dynamic-inl.h +22 -1
- package/Folly/TEMP_UntilFollyUpdate/lang/SafeAssert.h +4 -1
- package/Folly/cgmanifest.json +1 -1
- package/Libraries/ActionSheetIOS/ActionSheetIOS.d.ts +6 -0
- package/Libraries/ActionSheetIOS/ActionSheetIOS.js +6 -0
- package/Libraries/ActionSheetIOS/NativeActionSheetManager.js +4 -45
- package/Libraries/Alert/Alert.windows.js +2 -3
- package/Libraries/Alert/NativeAlertManager.js +4 -26
- package/Libraries/Animated/Animated.js +2 -2
- package/Libraries/Animated/AnimatedPlatformConfig.js +1 -1
- package/Libraries/Animated/NativeAnimatedHelper.js +14 -11
- package/Libraries/Animated/NativeAnimatedModule.js +4 -68
- package/Libraries/Animated/NativeAnimatedTurboModule.js +4 -69
- package/Libraries/Animated/animations/Animation.js +6 -22
- package/Libraries/Animated/components/AnimatedFlatList.js +1 -16
- package/Libraries/Animated/components/AnimatedScrollView.js +36 -31
- package/Libraries/Animated/components/AnimatedSectionList.js +1 -20
- package/Libraries/Animated/createAnimatedComponent.js +45 -40
- package/Libraries/Animated/nodes/AnimatedStyle.js +1 -1
- package/Libraries/Animated/shouldUseTurboAnimatedModule.js +1 -1
- package/Libraries/Animated/useAnimatedProps.js +21 -1
- package/Libraries/AppState/NativeAppState.js +4 -24
- package/Libraries/AppTheme/NativeAppTheme.js +4 -25
- package/Libraries/BatchedBridge/NativeModules.js +1 -1
- package/Libraries/Blob/Blob.js +1 -4
- package/Libraries/Blob/BlobManager.js +6 -8
- package/Libraries/Blob/File.js +1 -1
- package/Libraries/Blob/NativeBlobModule.js +4 -50
- package/Libraries/Blob/NativeFileReaderModule.js +4 -13
- package/Libraries/BugReporting/NativeBugReporting.js +4 -12
- package/Libraries/Components/AccessibilityInfo/NativeAccessibilityInfo.js +3 -23
- package/Libraries/Components/AccessibilityInfo/NativeAccessibilityManager.js +4 -57
- package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.android.js +3 -2
- package/Libraries/Components/AccessibilityInfo/legacySendAccessibilityEvent.windows.js +3 -2
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +9 -40
- package/Libraries/Components/ActivityIndicator/ActivityIndicatorViewNativeComponent.js +3 -43
- package/Libraries/Components/Button.js +103 -107
- package/Libraries/Components/Button.windows.js +199 -206
- package/Libraries/Components/Clipboard/NativeClipboard.js +3 -11
- package/Libraries/Components/DrawerAndroid/AndroidDrawerLayoutNativeComponent.js +3 -114
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +1 -5
- package/Libraries/Components/Keyboard/KeyboardExt.d.ts +8 -8
- package/Libraries/Components/Keyboard/KeyboardExt.js +27 -27
- package/Libraries/Components/Keyboard/KeyboardExt.js.map +1 -1
- package/Libraries/Components/Keyboard/KeyboardExtProps.d.ts +17 -17
- package/Libraries/Components/Keyboard/KeyboardExtProps.js +7 -7
- package/Libraries/Components/Keyboard/KeyboardExtProps.js.map +1 -1
- package/Libraries/Components/Keyboard/NativeKeyboardObserver.js +3 -10
- package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroid.android.js +69 -0
- package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroid.d.ts +24 -0
- package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroid.js +33 -0
- package/Libraries/Components/PopupMenuAndroid/PopupMenuAndroidNativeComponent.js +13 -0
- package/Libraries/Components/Pressable/Pressable.js +1 -1
- package/Libraries/Components/Pressable/Pressable.windows.js +1 -2
- package/Libraries/Components/Pressable/useAndroidRippleForView.js +5 -4
- package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroidNativeComponent.js +4 -24
- package/Libraries/Components/RefreshControl/AndroidSwipeRefreshLayoutNativeComponent.js +3 -64
- package/Libraries/Components/RefreshControl/PullToRefreshViewNativeComponent.js +3 -61
- package/Libraries/Components/RefreshControl/RefreshControl.js +1 -1
- package/Libraries/Components/RefreshControl/RefreshControl.windows.js +1 -1
- package/Libraries/Components/SafeAreaView/RCTSafeAreaViewNativeComponent.js +3 -15
- package/Libraries/Components/ScrollView/AndroidHorizontalScrollContentViewNativeComponent.js +3 -16
- package/Libraries/Components/ScrollView/ScrollContentViewNativeComponent.js +1 -1
- package/Libraries/Components/ScrollView/ScrollView.d.ts +5 -6
- package/Libraries/Components/ScrollView/ScrollView.js +12 -38
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +1 -2
- package/Libraries/Components/Sound/NativeSoundManager.js +3 -12
- package/Libraries/Components/StatusBar/NativeStatusBarManagerAndroid.js +3 -58
- package/Libraries/Components/StatusBar/NativeStatusBarManagerIOS.js +3 -79
- package/Libraries/Components/Switch/AndroidSwitchNativeComponent.js +4 -53
- package/Libraries/Components/Switch/Switch.js +0 -2
- package/Libraries/Components/Switch/Switch.windows.js +0 -2
- package/Libraries/Components/Switch/SwitchNativeComponent.js +4 -52
- package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +8 -0
- package/Libraries/Components/TextInput/InputAccessoryView.js +18 -20
- package/Libraries/Components/TextInput/RCTInputAccessoryViewNativeComponent.js +4 -17
- package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +3 -6
- package/Libraries/Components/TextInput/TextInput.d.ts +16 -0
- package/Libraries/Components/TextInput/TextInput.flow.js +16 -0
- package/Libraries/Components/TextInput/TextInput.js +65 -32
- package/Libraries/Components/TextInput/TextInput.windows.js +87 -38
- package/Libraries/Components/TextInput/WindowsTextInputNativeComponent.js +773 -9
- package/Libraries/Components/ToastAndroid/NativeToastAndroid.js +3 -28
- package/Libraries/Components/Touchable/PooledClass.js +1 -1
- package/Libraries/Components/Touchable/Touchable.js +2 -3
- package/Libraries/Components/Touchable/Touchable.windows.js +2 -3
- package/Libraries/Components/Touchable/TouchableHighlight.js +4 -4
- package/Libraries/Components/Touchable/TouchableHighlight.windows.js +4 -4
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -1
- package/Libraries/Components/Touchable/TouchableOpacity.js +5 -2
- package/Libraries/Components/Touchable/TouchableOpacity.windows.js +5 -2
- package/Libraries/Components/UnimplementedViews/UnimplementedNativeViewNativeComponent.js +3 -16
- package/Libraries/Components/View/ReactNativeStyleAttributes.js +1 -1
- package/Libraries/Components/View/View.js +0 -11
- package/Libraries/Components/View/View.windows.js +19 -18
- package/Libraries/Components/View/ViewAccessibility.d.ts +33 -17
- package/Libraries/Components/View/ViewPropTypes.d.ts +28 -17
- package/Libraries/Components/View/ViewPropTypes.js +36 -36
- package/Libraries/Components/View/ViewPropTypes.windows.js +36 -36
- package/Libraries/Core/InitializeCore.js +1 -1
- package/Libraries/Core/NativeExceptionsManager.js +3 -93
- package/Libraries/Core/ReactNativeVersion.js +12 -6
- package/Libraries/Core/ReactNativeVersionCheck.js +6 -6
- package/Libraries/Core/SegmentFetcher/NativeSegmentFetcher.js +3 -18
- package/Libraries/Core/Timers/NativeTiming.js +3 -16
- package/Libraries/Core/registerCallableModule.js +42 -0
- package/Libraries/Core/setUpPerformance.js +2 -2
- package/Libraries/Core/setUpPerformanceObserver.js +3 -1
- package/Libraries/Debugging/DebuggingOverlay.js +111 -0
- package/Libraries/Debugging/DebuggingOverlayNativeComponent.js +13 -0
- package/Libraries/Debugging/DebuggingOverlayRegistry.js +513 -0
- package/Libraries/Debugging/useSubscribeToDebuggingOverlayRegistry.js +32 -0
- package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +3 -14
- package/Libraries/HeapCapture/NativeJSCHeapCapture.js +3 -9
- package/Libraries/Image/AssetSourceResolver.js +5 -5
- package/Libraries/Image/AssetUtils.js +4 -5
- package/Libraries/Image/Image.android.js +146 -174
- package/Libraries/Image/Image.d.ts +1 -1
- package/Libraries/Image/Image.ios.js +53 -79
- package/Libraries/Image/Image.windows.js +53 -79
- package/Libraries/Image/ImageBackground.js +2 -2
- package/Libraries/Image/ImageInjection.js +76 -18
- package/Libraries/Image/ImageTypes.flow.js +71 -0
- package/Libraries/Image/ImageUtils.js +1 -1
- package/Libraries/Image/ImageViewNativeComponent.js +18 -0
- package/Libraries/Image/NativeImageEditor.js +3 -42
- package/Libraries/Image/NativeImageLoaderAndroid.js +4 -28
- package/Libraries/Image/NativeImageLoaderIOS.js +4 -28
- package/Libraries/Image/NativeImageStoreAndroid.js +3 -16
- package/Libraries/Image/NativeImageStoreIOS.js +3 -23
- package/Libraries/Image/resolveAssetSource.js +59 -26
- package/Libraries/Image/resolveAssetSource.windows.js +148 -0
- package/Libraries/Inspector/ElementProperties.js +26 -52
- package/Libraries/Inspector/Inspector.js +122 -186
- package/Libraries/Inspector/InspectorOverlay.js +21 -33
- package/Libraries/Inspector/InspectorPanel.js +3 -17
- package/Libraries/Inspector/ReactDevToolsOverlay.js +171 -0
- package/Libraries/Inspector/getInspectorDataForViewAtPoint.js +20 -8
- package/Libraries/Interaction/FrameRateLogger.js +8 -18
- package/Libraries/Interaction/NativeFrameRateLogger.js +4 -16
- package/Libraries/IntersectionObserver/IntersectionObserver.js +1 -1
- package/Libraries/IntersectionObserver/IntersectionObserverEntry.js +20 -19
- package/Libraries/IntersectionObserver/IntersectionObserverManager.js +84 -6
- package/Libraries/IntersectionObserver/NativeIntersectionObserver.js +3 -31
- package/Libraries/IntersectionObserver/__mocks__/NativeIntersectionObserver.js +12 -2
- package/Libraries/LayoutAnimation/LayoutAnimation.js +1 -2
- package/Libraries/Linking/NativeIntentAndroid.js +3 -20
- package/Libraries/Linking/NativeLinkingManager.js +3 -17
- package/Libraries/Lists/FillRateHelper.js +1 -1
- package/Libraries/Lists/FlatList.d.ts +2 -2
- package/Libraries/Lists/FlatList.js +6 -1
- package/Libraries/Lists/FlatList.windows.js +717 -0
- package/Libraries/Lists/SectionList.d.ts +6 -1
- package/Libraries/Lists/ViewabilityHelper.js +1 -1
- package/Libraries/Lists/VirtualizeUtils.js +1 -1
- package/Libraries/Lists/VirtualizedList.js +1 -1
- package/Libraries/Lists/VirtualizedListContext.js +1 -1
- package/Libraries/Lists/VirtualizedSectionList.js +1 -1
- package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
- package/Libraries/LogBox/LogBoxInspectorContainer.js +1 -1
- package/Libraries/Modal/Modal.js +43 -11
- package/Libraries/Modal/NativeModalManager.js +3 -11
- package/Libraries/Modal/RCTModalHostViewNativeComponent.js +3 -129
- package/Libraries/MutationObserver/MutationObserver.js +1 -1
- package/Libraries/MutationObserver/MutationObserverManager.js +2 -2
- package/Libraries/MutationObserver/MutationRecord.js +12 -10
- package/Libraries/MutationObserver/NativeMutationObserver.js +3 -48
- package/Libraries/MutationObserver/__mocks__/NativeMutationObserver.js +1 -1
- package/Libraries/NativeComponent/BaseViewConfig.android.js +1 -0
- package/Libraries/NativeComponent/BaseViewConfig.windows.js +3 -0
- package/Libraries/NativeComponent/NativeComponentRegistry.js +1 -1
- package/Libraries/NativeModules/specs/NativeAnimationsDebugModule.js +3 -10
- package/Libraries/NativeModules/specs/NativeDevMenu.js +3 -13
- package/Libraries/NativeModules/specs/NativeDevSettings.js +3 -23
- package/Libraries/NativeModules/specs/NativeDeviceEventManager.js +3 -9
- package/Libraries/NativeModules/specs/NativeDialogManagerAndroid.js +3 -38
- package/Libraries/NativeModules/specs/NativeDialogManagerWindows.js +11 -0
- package/Libraries/NativeModules/specs/NativeLogBox.js +3 -10
- package/Libraries/NativeModules/specs/NativeRedBox.js +4 -11
- package/Libraries/NativeModules/specs/NativeSourceCode.js +2 -25
- package/Libraries/Network/FormData.js +3 -1
- package/Libraries/Network/NativeNetworkingAndroid.js +4 -28
- package/Libraries/Network/NativeNetworkingIOS.js +4 -28
- package/Libraries/NewAppScreen/components/DebugInstructions.windows.js +4 -2
- package/Libraries/NewAppScreen/components/ReloadInstructions.windows.js +3 -1
- package/Libraries/Performance/NativeJSCSamplingProfiler.js +3 -9
- package/Libraries/PermissionsAndroid/NativePermissionsAndroid.js +4 -68
- package/Libraries/PermissionsAndroid/PermissionsAndroid.js +3 -3
- package/Libraries/Pressability/Pressability.js +12 -2
- package/Libraries/Pressability/Pressability.windows.js +13 -3
- package/Libraries/Pressability/usePressability.js +7 -0
- package/Libraries/PushNotificationIOS/NativePushNotificationManagerIOS.js +4 -70
- package/Libraries/PushNotificationIOS/PushNotificationIOS.js +45 -39
- package/Libraries/ReactNative/AppContainer-dev.js +192 -0
- package/Libraries/ReactNative/AppContainer-prod.js +53 -0
- package/Libraries/ReactNative/AppContainer.js +6 -149
- package/Libraries/ReactNative/AppRegistry.js +3 -1
- package/Libraries/ReactNative/BridgelessUIManager.js +375 -128
- package/Libraries/ReactNative/FabricUIManager.js +6 -0
- package/Libraries/ReactNative/NativeHeadlessJsTaskSupport.js +3 -10
- package/Libraries/ReactNative/NativeI18nManager.js +3 -18
- package/Libraries/ReactNative/NativeUIManager.js +4 -112
- package/Libraries/ReactNative/PaperUIManager.js +8 -7
- package/Libraries/ReactNative/PaperUIManager.windows.js +29 -8
- package/Libraries/ReactNative/ReactFabricInternals.js +1 -1
- package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricPublicInstance.js +24 -5
- package/Libraries/ReactNative/ReactNativeFeatureFlags.js +0 -45
- package/Libraries/ReactNative/RendererImplementation.js +11 -0
- package/Libraries/ReactNative/UIManager.d.ts +11 -34
- package/Libraries/ReactNative/UIManager.js +2 -23
- package/Libraries/ReactNative/UIManagerProperties.js +0 -2
- package/Libraries/ReactNative/__mocks__/FabricUIManager.js +23 -1
- package/Libraries/ReactNative/getNativeComponentAttributes.js +5 -1
- package/Libraries/ReactNative/renderApplication.js +9 -6
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +6 -1
- package/Libraries/Renderer/implementations/ReactFabric-dev.js +24771 -21123
- package/Libraries/Renderer/implementations/ReactFabric-prod.js +4160 -3109
- package/Libraries/Renderer/implementations/ReactFabric-profiling.js +4384 -3322
- package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +25194 -21398
- package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +3763 -2636
- package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +4027 -2867
- package/Libraries/Renderer/shims/ReactNativeTypes.js +8 -9
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -12
- package/Libraries/Settings/NativeSettingsManager.js +4 -16
- package/Libraries/Share/NativeShareModule.js +3 -13
- package/Libraries/StyleSheet/PlatformColorValueTypes.windows.js +1 -1
- package/Libraries/StyleSheet/StyleSheet.d.ts +1 -20
- package/Libraries/StyleSheet/StyleSheet.js +5 -28
- package/Libraries/StyleSheet/StyleSheetTypes.d.ts +47 -7
- package/Libraries/StyleSheet/StyleSheetTypes.js +16 -11
- package/Libraries/StyleSheet/flattenStyle.js +2 -2
- package/Libraries/StyleSheet/normalizeColor.js +1 -1
- package/Libraries/StyleSheet/processAspectRatio.js +1 -1
- package/Libraries/StyleSheet/processFontVariant.js +1 -1
- package/Libraries/Text/Text.js +0 -6
- package/Libraries/Text/Text.windows.js +0 -6
- package/Libraries/Text/TextAncestor.js +2 -3
- package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +4 -41
- package/Libraries/Types/ReactDevToolsTypes.js +58 -0
- package/Libraries/Types/UIManagerJSInterface.js +16 -0
- package/Libraries/Utilities/DebugEnvironment.js +1 -4
- package/Libraries/Utilities/Dimensions.js +8 -16
- package/Libraries/Utilities/GlobalPerformanceLogger.js +1 -2
- package/Libraries/Utilities/NativeAppearance.js +3 -26
- package/Libraries/Utilities/NativeDevLoadingView.js +3 -14
- package/Libraries/Utilities/NativeDeviceInfo.js +2 -47
- package/Libraries/Utilities/NativePlatformConstantsAndroid.js +3 -34
- package/Libraries/Utilities/NativePlatformConstantsIOS.js +3 -26
- package/Libraries/Utilities/NativePlatformConstantsWin.js +3 -23
- package/Libraries/Utilities/PixelRatio.d.ts +4 -4
- package/Libraries/Utilities/Platform.android.js +4 -0
- package/Libraries/Utilities/Platform.d.ts +3 -0
- package/Libraries/Utilities/Platform.flow.js +7 -0
- package/Libraries/Utilities/Platform.flow.windows.js +9 -0
- package/Libraries/Utilities/Platform.ios.js +11 -0
- package/Libraries/Utilities/Platform.windows.js +6 -0
- package/Libraries/Utilities/binaryToBase64.js +1 -1
- package/Libraries/Utilities/codegenNativeComponent.js +4 -6
- package/Libraries/Utilities/createPerformanceLogger.js +2 -74
- package/Libraries/Utilities/useMergeRefs.js +5 -9
- package/Libraries/Vibration/NativeVibration.js +3 -14
- package/Libraries/WebSocket/NativeWebSocketModule.js +4 -25
- package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
- package/Libraries/vendor/emitter/EventEmitter.js +1 -0
- package/Microsoft.ReactNative/AsynchronousEventBeat.cpp +50 -0
- package/Microsoft.ReactNative/AsynchronousEventBeat.h +23 -0
- package/Microsoft.ReactNative/Base/CoreUIManagers.cpp +4 -0
- package/Microsoft.ReactNative/Base/CxxReactIncludes.h +1 -1
- package/Microsoft.ReactNative/Base/FollyIncludes.h +2 -2
- package/Microsoft.ReactNative/ComponentView.idl +106 -0
- package/Microsoft.ReactNative/Composition.Input.idl +16 -2
- package/Microsoft.ReactNative/CompositionComponentView.idl +117 -0
- package/Microsoft.ReactNative/CompositionContext.idl +1 -1
- package/Microsoft.ReactNative/CompositionRootView.idl +8 -0
- package/Microsoft.ReactNative/CompositionSwitcher.idl +25 -14
- package/Microsoft.ReactNative/DevMenuControl.idl +0 -3
- package/Microsoft.ReactNative/DevMenuControl.xaml +0 -15
- package/Microsoft.ReactNative/Fabric/AbiComponentDescriptor.cpp +189 -0
- package/Microsoft.ReactNative/Fabric/AbiComponentDescriptor.h +80 -0
- package/Microsoft.ReactNative/Fabric/AbiShadowNode.cpp +83 -0
- package/Microsoft.ReactNative/Fabric/AbiShadowNode.h +83 -0
- package/Microsoft.ReactNative/Fabric/AbiState.cpp +71 -0
- package/Microsoft.ReactNative/Fabric/AbiState.h +38 -0
- package/Microsoft.ReactNative/Fabric/AbiViewComponentDescriptor.cpp +48 -19
- package/Microsoft.ReactNative/Fabric/AbiViewComponentDescriptor.h +8 -16
- package/Microsoft.ReactNative/Fabric/AbiViewProps.cpp +97 -0
- package/Microsoft.ReactNative/Fabric/AbiViewProps.h +39 -0
- package/Microsoft.ReactNative/Fabric/AbiViewShadowNode.cpp +90 -0
- package/Microsoft.ReactNative/Fabric/AbiViewShadowNode.h +87 -0
- package/Microsoft.ReactNative/Fabric/ComponentView.cpp +340 -0
- package/Microsoft.ReactNative/Fabric/ComponentView.h +130 -64
- package/Microsoft.ReactNative/Fabric/Composition/ActivityIndicatorComponentView.cpp +48 -24
- package/Microsoft.ReactNative/Fabric/Composition/ActivityIndicatorComponentView.h +18 -14
- package/Microsoft.ReactNative/Fabric/Composition/ComponentViewRegistry.cpp +42 -27
- package/Microsoft.ReactNative/Fabric/Composition/ComponentViewRegistry.h +3 -1
- package/Microsoft.ReactNative/Fabric/Composition/Composition.Input.cpp +123 -28
- package/Microsoft.ReactNative/Fabric/Composition/Composition.Input.h +69 -13
- package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper.cpp +651 -284
- package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper.h +7 -7
- package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper_emptyimpl.cpp +9 -9
- package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.cpp +120 -31
- package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.h +12 -2
- package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.cpp +308 -129
- package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.h +34 -6
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHelpers.h +2 -1
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHwndHost.cpp +61 -54
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHwndHost.h +0 -9
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.cpp +99 -30
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.h +4 -3
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView.cpp +273 -28
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView.h +28 -3
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView_emptyimpl.cpp +7 -3
- package/Microsoft.ReactNative/Fabric/Composition/CompositionUIService.cpp +4 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.cpp +479 -280
- package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.h +133 -79
- package/Microsoft.ReactNative/Fabric/Composition/DebuggingOverlayComponentView.cpp +113 -0
- package/Microsoft.ReactNative/Fabric/Composition/DebuggingOverlayComponentView.h +39 -0
- package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.cpp +61 -41
- package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.h +19 -14
- package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewComponentDescriptor.h +39 -0
- package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewComponentView.cpp +343 -0
- package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewComponentView.h +67 -0
- package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewShadowNode.cpp +18 -0
- package/Microsoft.ReactNative/Fabric/Composition/Modal/WindowsModalHostViewShadowNode.h +39 -0
- package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.cpp +53 -186
- package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.h +20 -12
- package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.cpp +59 -150
- package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.h +27 -76
- package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.cpp +81 -32
- package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.h +27 -14
- package/Microsoft.ReactNative/Fabric/Composition/ScrollViewComponentView.cpp +707 -64
- package/Microsoft.ReactNative/Fabric/Composition/ScrollViewComponentView.h +47 -26
- package/Microsoft.ReactNative/Fabric/Composition/SwitchComponentView.cpp +225 -125
- package/Microsoft.ReactNative/Fabric/Composition/SwitchComponentView.h +34 -21
- package/Microsoft.ReactNative/Fabric/Composition/TextDrawing.cpp +179 -0
- package/Microsoft.ReactNative/Fabric/Composition/TextDrawing.h +25 -0
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentDescriptor.h +110 -115
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.cpp +228 -79
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.h +43 -22
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputEventEmitter.cpp +18 -0
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputEventEmitter.h +12 -0
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputProps.h +5 -5
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputShadowNode.cpp +5 -1
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputShadowNode.h +1 -2
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputState.cpp +4 -44
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputState.h +11 -9
- package/Microsoft.ReactNative/Fabric/Composition/Theme.cpp +550 -0
- package/Microsoft.ReactNative/Fabric/Composition/Theme.h +73 -0
- package/Microsoft.ReactNative/Fabric/Composition/Theme_emptyimpl.cpp +85 -0
- package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.cpp +48 -26
- package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.h +6 -2
- package/Microsoft.ReactNative/Fabric/Composition/UnimplementedNativeViewComponentView.cpp +30 -65
- package/Microsoft.ReactNative/Fabric/Composition/UnimplementedNativeViewComponentView.h +16 -25
- package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.cpp +72 -88
- package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.h +5 -2
- package/Microsoft.ReactNative/Fabric/IComponentViewRegistry.h +3 -2
- package/Microsoft.ReactNative/Fabric/ReactNativeConfigProperties.cpp +6 -6
- package/Microsoft.ReactNative/Fabric/ReactNativeConfigProperties.h +2 -2
- package/Microsoft.ReactNative/Fabric/ReactTaggedView.h +12 -7
- package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.cpp +28 -19
- package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.h +5 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/HostPlatformViewEventEmitter.cpp +0 -2
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/HostPlatformViewTraitsInitializer.h +5 -1
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/WindowsViewEvents.h +2 -4
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Float.h +20 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/HostPlatformColor.h +86 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/PlatformColorParser.h +38 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/{Color.cpp → PlatformColorUtils.cpp} +7 -77
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/PlatformColorUtils.h +12 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.cpp +1 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.h +2 -0
- package/Microsoft.ReactNative/IReactCompositionViewComponentBuilder.idl +6 -87
- package/Microsoft.ReactNative/IReactContext.idl +3 -0
- package/Microsoft.ReactNative/IReactViewComponentBuilder.idl +71 -1
- package/Microsoft.ReactNative/JsiApi.cpp +17 -7
- package/Microsoft.ReactNative/JsiApi.h +2 -2
- package/Microsoft.ReactNative/JsiApi.idl +5 -4
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj +13 -22
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj.filters +6 -2
- package/Microsoft.ReactNative/Modules/AccessibilityInfoModule.h +1 -1
- package/Microsoft.ReactNative/Modules/AlertModule.h +2 -2
- package/Microsoft.ReactNative/Modules/Animated/PropsAnimatedNode.cpp +12 -8
- package/Microsoft.ReactNative/Modules/Animated/PropsAnimatedNode.h +1 -1
- package/Microsoft.ReactNative/Modules/AppStateModule.h +2 -2
- package/Microsoft.ReactNative/Modules/AppThemeModuleUwp.cpp +5 -3
- package/Microsoft.ReactNative/Modules/AppThemeModuleUwp.h +4 -4
- package/Microsoft.ReactNative/Modules/AppearanceModule.cpp +10 -1
- package/Microsoft.ReactNative/Modules/ClipboardModule.h +1 -1
- package/Microsoft.ReactNative/Modules/DeviceInfoModule.cpp +71 -38
- package/Microsoft.ReactNative/Modules/DeviceInfoModule.h +5 -5
- package/Microsoft.ReactNative/Modules/ExceptionsManager.cpp +110 -0
- package/Microsoft.ReactNative/Modules/ExceptionsManager.h +54 -0
- package/Microsoft.ReactNative/Modules/ImageViewManagerModule.h +11 -10
- package/Microsoft.ReactNative/Modules/LinkingManagerModule.h +8 -6
- package/Microsoft.ReactNative/Modules/LogBoxModule.h +3 -3
- package/Microsoft.ReactNative/Modules/NativeUIManager.cpp +5 -28
- package/Microsoft.ReactNative/Modules/NativeUIManager.h +1 -1
- package/Microsoft.ReactNative/Modules/PaperUIManagerModule.cpp +8 -5
- package/Microsoft.ReactNative/Modules/PaperUIManagerModule.h +3 -3
- package/Microsoft.ReactNative/Modules/PlatformConstantsWinModule.cpp +49 -0
- package/Microsoft.ReactNative/Modules/PlatformConstantsWinModule.h +18 -0
- package/Microsoft.ReactNative/Modules/SourceCode.cpp +31 -0
- package/Microsoft.ReactNative/Modules/SourceCode.h +28 -0
- package/Microsoft.ReactNative/Modules/StatusBarManager.h +12 -0
- package/Microsoft.ReactNative/Modules/Timing.cpp +325 -0
- package/Microsoft.ReactNative/Modules/Timing.h +121 -0
- package/Microsoft.ReactNative/QuirkSettings.cpp +32 -0
- package/Microsoft.ReactNative/QuirkSettings.h +9 -0
- package/Microsoft.ReactNative/QuirkSettings.idl +6 -0
- package/Microsoft.ReactNative/ReactCoreInjection.cpp +15 -0
- package/Microsoft.ReactNative/ReactCoreInjection.h +4 -0
- package/Microsoft.ReactNative/ReactCoreInjection.idl +8 -0
- package/Microsoft.ReactNative/ReactHost/IReactInstance.h +1 -1
- package/Microsoft.ReactNative/ReactHost/MsoReactContext.cpp +1 -1
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.cpp +556 -234
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.h +36 -9
- package/Microsoft.ReactNative/ReactInstanceSettings.idl +3 -0
- package/Microsoft.ReactNative/ReactPointerEventArgs.cpp +8 -0
- package/Microsoft.ReactNative/ReactPointerEventArgs.h +4 -0
- package/Microsoft.ReactNative/ReactPointerEventArgs.idl +12 -0
- package/Microsoft.ReactNative/SchedulerSettings.cpp +23 -0
- package/Microsoft.ReactNative/SchedulerSettings.h +9 -1
- package/Microsoft.ReactNative/SynchronousEventBeat.cpp +41 -0
- package/Microsoft.ReactNative/SynchronousEventBeat.h +29 -0
- package/Microsoft.ReactNative/Theme.idl +57 -0
- package/Microsoft.ReactNative/Timer.cpp +63 -0
- package/Microsoft.ReactNative/{CoreAppPage.h → Timer.h} +12 -5
- package/Microsoft.ReactNative/Timer.idl +34 -0
- package/Microsoft.ReactNative/TurboModulesProvider.cpp +4 -0
- package/Microsoft.ReactNative/Utils/ImageUtils.cpp +37 -3
- package/Microsoft.ReactNative/Utils/ImageUtils.h +0 -1
- package/Microsoft.ReactNative/Utils/LocalBundleReader.cpp +11 -12
- package/Microsoft.ReactNative/Utils/LocalBundleReader.h +3 -3
- package/Microsoft.ReactNative/Utils/ThemeUtils.cpp +33 -0
- package/Microsoft.ReactNative/Utils/ThemeUtils.h +13 -0
- package/Microsoft.ReactNative/Utils/ValueUtils.cpp +0 -5
- package/Microsoft.ReactNative/Utils/ValueUtils.h +0 -3
- package/Microsoft.ReactNative/ViewProps.idl +17 -0
- package/Microsoft.ReactNative/Views/ActivityIndicatorViewManager.cpp +1 -0
- package/Microsoft.ReactNative/Views/DebuggingOverlayViewManager.cpp +54 -0
- package/Microsoft.ReactNative/Views/DebuggingOverlayViewManager.h +30 -0
- package/Microsoft.ReactNative/Views/DevMenu.cpp +1 -20
- package/Microsoft.ReactNative/Views/DynamicAutomationPeer.cpp +157 -0
- package/Microsoft.ReactNative/Views/DynamicAutomationPeer.h +5 -0
- package/Microsoft.ReactNative/Views/DynamicAutomationProperties.cpp +20 -0
- package/Microsoft.ReactNative/Views/DynamicAutomationProperties.h +4 -0
- package/Microsoft.ReactNative/Views/FlyoutViewManager.cpp +1 -5
- package/Microsoft.ReactNative/Views/FrameworkElementViewManager.cpp +137 -0
- package/Microsoft.ReactNative/Views/ICompositionRootView.h +0 -1
- package/Microsoft.ReactNative/Views/Image/ImageViewManager.cpp +0 -5
- package/Microsoft.ReactNative/Views/PopupViewManager.cpp +1 -5
- package/Microsoft.ReactNative/Views/ShadowNodeBase.cpp +11 -0
- package/Microsoft.ReactNative/Views/ShadowNodeBase.h +3 -4
- package/Microsoft.ReactNative/Views/TextInputViewManager.cpp +0 -6
- package/Microsoft.ReactNative/Views/TextViewManager.cpp +0 -11
- package/Microsoft.ReactNative/Views/TouchEventHandler.cpp +1 -1
- package/Microsoft.ReactNative/Views/UnimplementedViewManager.cpp +79 -0
- package/Microsoft.ReactNative/Views/UnimplementedViewManager.h +27 -0
- package/Microsoft.ReactNative/Views/ViewManagerBase.cpp +46 -0
- package/Microsoft.ReactNative/Views/ViewManagerBase.h +1 -1
- package/Microsoft.ReactNative/Views/cppwinrt/DynamicAutomationPeer.idl +77 -2
- package/Microsoft.ReactNative/microsoft.reactnative.def +0 -3
- package/Microsoft.ReactNative/packages.lock.json +9 -6
- package/{Shared/Composition → Microsoft.ReactNative.Cxx}/AutoDraw.h +2 -0
- package/{Shared/Composition → Microsoft.ReactNative.Cxx}/CompositionSwitcher.interop.h +4 -10
- package/Microsoft.ReactNative.Cxx/CppWinRTIncludes.h +0 -5
- package/Microsoft.ReactNative.Cxx/DesktopWindowBridge.h +5 -0
- package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.cpp +19 -10
- package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.h +2 -0
- package/Microsoft.ReactNative.Cxx/JSValueComposition.h +22 -0
- package/Microsoft.ReactNative.Cxx/JSValueReader.h +19 -0
- package/Microsoft.ReactNative.Cxx/JSValueXaml.h +1 -1
- package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems +6 -4
- package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems.filters +0 -1
- package/Microsoft.ReactNative.Cxx/NativeModules.h +15 -15
- package/Microsoft.ReactNative.Cxx/TurboModuleProvider.cpp +1 -1
- package/Microsoft.ReactNative.Managed/ReactSettingsSnapshot.cs +2 -0
- package/Microsoft.ReactNative.Managed/packages.lock.json +6 -3
- package/Microsoft.ReactNative.Managed.CodeGen/Microsoft.ReactNative.Managed.CodeGen.csproj +0 -1
- package/Mso/future/details/executor.h +1 -1
- package/Mso/src/debugAssertApi/debugAssertApi.cpp +1 -1
- package/PropertySheets/External/Microsoft.ReactNative.Composition.Common.props +8 -0
- package/PropertySheets/External/Microsoft.ReactNative.Composition.CppLib.props +24 -0
- package/PropertySheets/External/Microsoft.ReactNative.Composition.CppLib.targets +20 -0
- package/PropertySheets/External/Microsoft.ReactNative.Cpp.Dependencies.props +1 -1
- package/PropertySheets/External/Microsoft.ReactNative.WindowsSdk.Default.props +2 -0
- package/PropertySheets/Generated/PackageVersion.g.props +4 -4
- package/PropertySheets/JSEngine.props +0 -8
- package/PropertySheets/React.Cpp.props +14 -3
- package/PropertySheets/ReactCommunity.cpp.props +2 -2
- package/PropertySheets/Release.props +0 -1
- package/PropertySheets/WinUI.props +21 -1
- package/PropertySheets/x64.props +3 -0
- package/PropertySheets/x86.props +3 -0
- package/ReactCommon/ReactCommon.vcxproj +13 -8
- package/ReactCommon/ReactCommon.vcxproj.filters +12 -1
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/jsi/test/testlib.cpp +114 -19
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModule.cpp +66 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleBinding.cpp +114 -52
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleUtils.h +13 -15
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/scrollview/ScrollViewProps.cpp +535 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/runtime/ReactInstance.cpp +437 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/utils/jsi-utils.cpp +39 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/utils/jsi-utils.h +31 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/YGEnums.h +19 -24
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/algorithm/CalculateLayout.cpp +600 -980
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/enums/ExperimentalFeature.h +5 -11
- package/ReactCommon/cgmanifest.json +1 -1
- package/Scripts/EnableInternalWinAppSDKFeed.ps1 +21 -0
- package/Scripts/IntegrationTests.ps1 +26 -15
- package/Scripts/Microsoft.ReactNative.targets +0 -6
- package/Scripts/OfficeReact.Win32.nuspec +1 -2
- package/Scripts/TestServers.ps1 +2 -28
- package/Scripts/Tfs/Start-TestServers.ps1 +1 -21
- package/Scripts/Tfs/Stop-TestServers.ps1 +0 -5
- package/Scripts/rnw-dependencies.ps1 +38 -67
- package/Shared/CreateInstance.h +25 -0
- package/Shared/DevServerHelper.h +0 -3
- package/Shared/DevSettings.h +9 -0
- package/Shared/HermesRuntimeHolder.cpp +17 -0
- package/Shared/HermesRuntimeHolder.h +17 -0
- package/Shared/HermesSamplingProfiler.cpp +12 -10
- package/Shared/HermesSamplingProfiler.h +5 -4
- package/Shared/IDevSupportManager.h +4 -2
- package/Shared/InstanceManager.cpp +13 -11
- package/Shared/InstanceManager.h +8 -18
- package/Shared/JSI/ChakraRuntime.cpp +66 -9
- package/Shared/JSI/ChakraRuntime.h +8 -0
- package/Shared/JSI/JSExecutorFactoryDelegate.h +12 -0
- package/Shared/JSI/JSExecutorFactorySettings.cpp +30 -0
- package/Shared/JSI/JSExecutorFactorySettings.h +21 -0
- package/Shared/Modules/BlobModule.h +1 -1
- package/Shared/Modules/FileReaderModule.h +1 -1
- package/Shared/Modules/HttpModule.h +1 -1
- package/Shared/Modules/WebSocketTurboModule.h +1 -1
- package/Shared/OInstance.cpp +212 -165
- package/Shared/OInstance.h +19 -0
- package/Shared/Shared.vcxitems +134 -50
- package/Shared/Shared.vcxitems.filters +81 -24
- package/Shared/Utils.cpp +12 -10
- package/Shared/Utils.h +2 -2
- package/Shared/WebSocketJSExecutorFactory.h +1 -0
- package/codegen/NativeBugReportingSpec.g.h +0 -6
- package/codegen/NativeFrameRateLoggerSpec.g.h +0 -2
- package/codegen/NativeImageLoaderAndroidSpec.g.h +10 -23
- package/codegen/NativePerformanceObserverSpec.g.h +6 -0
- package/codegen/NativePlatformConstantsIOSSpec.g.h +2 -0
- package/codegen/NativePlatformConstantsWinSpec.g.h +17 -0
- package/codegen/NativePushNotificationManagerIOSSpec.g.h +8 -6
- package/codegen/NativeReactNativeFeatureFlagsSpec.g.h +88 -0
- package/codegen/NativeUIManagerSpec.g.h +83 -95
- package/codegen/react/components/rnwcore/ComponentDescriptors.h +10 -7
- package/codegen/react/components/rnwcore/EventEmitters.cpp +40 -52
- package/codegen/react/components/rnwcore/EventEmitters.h +66 -84
- package/codegen/react/components/rnwcore/Props.cpp +60 -95
- package/codegen/react/components/rnwcore/Props.h +198 -239
- package/codegen/react/components/rnwcore/ShadowNodes.cpp +6 -7
- package/codegen/react/components/rnwcore/ShadowNodes.h +38 -29
- package/codegen/react/components/rnwcore/States.cpp +3 -5
- package/codegen/react/components/rnwcore/States.h +29 -16
- package/codegen/rnwcoreJSI-generated.cpp +1442 -1398
- package/codegen/rnwcoreJSI.h +6066 -3593
- package/index.js +66 -99
- package/index.windows.js +60 -102
- package/jest/assetFileTransformer.js +1 -1
- package/jest/local-setup.js +0 -5
- package/jest/mockModal.js +2 -1
- package/jest/mockScrollView.js +1 -2
- package/jest/renderer.js +1 -1
- package/jest/setup.js +6 -3
- package/just-task.js +1 -1
- package/package.json +30 -29
- package/{Libraries/Core → src/private/core}/setUpDOM.js +2 -2
- package/src/private/featureflags/NativeReactNativeFeatureFlags.js +42 -0
- package/src/private/featureflags/ReactNativeFeatureFlags.js +140 -0
- package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +84 -0
- package/src/private/featureflags/__tests__/ReactNativeFeatureFlags-test.js +92 -0
- package/src/private/specs/components/ActivityIndicatorViewNativeComponent.js +53 -0
- package/src/private/specs/components/AndroidDrawerLayoutNativeComponent.js +124 -0
- package/src/private/specs/components/AndroidHorizontalScrollContentViewNativeComponent.js +26 -0
- package/src/private/specs/components/AndroidSwipeRefreshLayoutNativeComponent.js +74 -0
- package/src/private/specs/components/AndroidSwitchNativeComponent.js +62 -0
- package/src/private/specs/components/DebuggingOverlayNativeComponent.js +61 -0
- package/src/private/specs/components/PopupMenuAndroidNativeComponent.js +47 -0
- package/src/private/specs/components/ProgressBarAndroidNativeComponent.js +36 -0
- package/src/private/specs/components/PullToRefreshViewNativeComponent.js +71 -0
- package/src/private/specs/components/RCTInputAccessoryViewNativeComponent.js +26 -0
- package/src/private/specs/components/RCTModalHostViewNativeComponent.js +139 -0
- package/src/private/specs/components/RCTSafeAreaViewNativeComponent.js +25 -0
- package/src/private/specs/components/SwitchNativeComponent.js +61 -0
- package/src/private/specs/components/UnimplementedNativeViewNativeComponent.js +26 -0
- package/src/private/specs/modules/NativeAccessibilityInfo.js +33 -0
- package/src/private/specs/modules/NativeAccessibilityManager.js +66 -0
- package/src/private/specs/modules/NativeActionSheetManager.js +54 -0
- package/src/private/specs/modules/NativeAlertManager.js +35 -0
- package/src/private/specs/modules/NativeAnimatedModule.js +77 -0
- package/src/private/specs/modules/NativeAnimatedTurboModule.js +78 -0
- package/src/private/specs/modules/NativeAnimationsDebugModule.js +20 -0
- package/src/private/specs/modules/NativeAppState.js +33 -0
- package/src/private/specs/modules/NativeAppTheme.js +33 -0
- package/src/private/specs/modules/NativeAppearance.js +36 -0
- package/src/private/specs/modules/NativeBlobModule.js +59 -0
- package/src/private/specs/modules/NativeBugReporting.js +20 -0
- package/src/private/specs/modules/NativeClipboard.js +21 -0
- package/src/private/specs/modules/NativeDevLoadingView.js +24 -0
- package/src/private/specs/modules/NativeDevMenu.js +23 -0
- package/src/private/specs/modules/NativeDevSettings.js +33 -0
- package/src/private/specs/modules/NativeDevToolsSettingsManager.js +24 -0
- package/src/private/specs/modules/NativeDeviceEventManager.js +19 -0
- package/src/private/specs/modules/NativeDeviceInfo.js +58 -0
- package/src/private/specs/modules/NativeDialogManagerAndroid.js +48 -0
- package/{Libraries/Alert → src/private/specs/modules}/NativeDialogManagerWindows.js +5 -4
- package/src/private/specs/modules/NativeExceptionsManager.js +103 -0
- package/src/private/specs/modules/NativeFileReaderModule.js +22 -0
- package/src/private/specs/modules/NativeFrameRateLogger.js +22 -0
- package/src/private/specs/modules/NativeHeadlessJsTaskSupport.js +20 -0
- package/src/private/specs/modules/NativeI18nManager.js +28 -0
- package/src/private/specs/modules/NativeImageEditor.js +52 -0
- package/src/private/specs/modules/NativeImageLoaderAndroid.js +30 -0
- package/src/private/specs/modules/NativeImageLoaderIOS.js +37 -0
- package/src/private/specs/modules/NativeImageStoreAndroid.js +26 -0
- package/src/private/specs/modules/NativeImageStoreIOS.js +33 -0
- package/src/private/specs/modules/NativeIntentAndroid.js +30 -0
- package/src/private/specs/modules/NativeIntersectionObserver.js +41 -0
- package/src/private/specs/modules/NativeJSCHeapCapture.js +19 -0
- package/src/private/specs/modules/NativeJSCSamplingProfiler.js +19 -0
- package/src/private/specs/modules/NativeKeyboardObserver.js +20 -0
- package/src/private/specs/modules/NativeLinkingManager.js +27 -0
- package/src/private/specs/modules/NativeLogBox.js +20 -0
- package/src/private/specs/modules/NativeModalManager.js +21 -0
- package/src/private/specs/modules/NativeMutationObserver.js +58 -0
- package/src/private/specs/modules/NativeNetworkingAndroid.js +37 -0
- package/src/private/specs/modules/NativeNetworkingIOS.js +37 -0
- package/src/private/specs/modules/NativePermissionsAndroid.js +77 -0
- package/src/private/specs/modules/NativePlatformConstantsAndroid.js +44 -0
- package/src/private/specs/modules/NativePlatformConstantsIOS.js +37 -0
- package/src/private/specs/modules/NativePlatformConstantsWin.js +38 -0
- package/src/private/specs/modules/NativePushNotificationManagerIOS.js +107 -0
- package/src/private/specs/modules/NativeRedBox.js +20 -0
- package/src/private/specs/modules/NativeSampleTurboModule.js +53 -0
- package/src/private/specs/modules/NativeSegmentFetcher.js +28 -0
- package/src/private/specs/modules/NativeSettingsManager.js +25 -0
- package/src/private/specs/modules/NativeShareModule.js +23 -0
- package/src/private/specs/modules/NativeSoundManager.js +22 -0
- package/src/private/specs/modules/NativeSourceCode.js +36 -0
- package/src/private/specs/modules/NativeStatusBarManagerAndroid.js +68 -0
- package/src/private/specs/modules/NativeStatusBarManagerIOS.js +89 -0
- package/src/private/specs/modules/NativeTiming.js +26 -0
- package/src/private/specs/modules/NativeToastAndroid.js +38 -0
- package/src/private/specs/modules/NativeUIManager.js +118 -0
- package/src/private/specs/modules/NativeVibration.js +24 -0
- package/src/private/specs/modules/NativeWebSocketModule.js +34 -0
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReactNativeElement.js +6 -6
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyCharacterData.js +2 -2
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyElement.js +5 -5
- package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyNode.js +19 -10
- package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/DOMRectList.js +1 -1
- package/src/private/webapis/dom/oldstylecollections/__tests__/DOMRectList-test.js +85 -0
- package/src/private/webapis/dom/oldstylecollections/__tests__/HTMLCollection-test.js +80 -0
- package/src/private/webapis/dom/oldstylecollections/__tests__/NodeList-test.js +161 -0
- package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformance.js +2 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/NativePerformanceObserver.js +3 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/Performance.js +2 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEventTiming.js +1 -1
- package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceObserver.js +21 -2
- package/{Libraries/WebPerformance → src/private/webapis/performance}/RawPerformanceEntry.js +1 -1
- package/{Libraries/WebPerformance → src/private/webapis/performance}/__mocks__/NativePerformanceObserver.js +9 -0
- package/src/private/webapis/performance/__tests__/EventCounts-test.js +116 -0
- package/src/private/webapis/performance/__tests__/NativePerformanceMock-test.js +82 -0
- package/src/private/webapis/performance/__tests__/NativePerformanceObserverMock-test.js +108 -0
- package/src/private/webapis/performance/__tests__/Performance-test.js +117 -0
- package/src/private/webapis/performance/__tests__/PerformanceObserver-test.js +208 -0
- package/template/cpp-app/src/App.cpp +2 -2
- package/template/cs-app/src/App.xaml.cs +2 -2
- package/templates/cpp-app/jest.config.windows.js +3 -0
- package/templates/cpp-app/metro.config.js +0 -2
- package/templates/cpp-app/template.config.js +24 -9
- package/templates/cpp-app/windows/ExperimentalFeatures.props +1 -1
- package/templates/cpp-app/windows/MyApp/AutolinkedNativeModules.g.cpp +13 -0
- package/templates/cpp-app/windows/MyApp/AutolinkedNativeModules.g.h +10 -0
- package/templates/cpp-app/windows/MyApp/MyApp.cpp +134 -249
- package/templates/cpp-app/windows/MyApp/MyApp.vcxproj +12 -11
- package/templates/cpp-app/windows/MyApp/MyApp.vcxproj.filters +6 -3
- package/templates/cpp-app/windows/MyApp/pch.h +12 -9
- package/templates/cpp-app/windows/MyApp/resource.h +0 -1
- package/templates/cpp-app/windows/MyApp.sln +26 -26
- package/templates/cpp-lib/example/metro.config.js +74 -0
- package/templates/cpp-lib/template.config.js +235 -0
- package/templates/cpp-lib/windows/ExperimentalFeatures.props +11 -0
- package/templates/cpp-lib/windows/MyLib/MyLib.cpp +18 -0
- package/templates/cpp-lib/windows/MyLib/MyLib.def +3 -0
- package/templates/cpp-lib/windows/MyLib/MyLib.h +31 -0
- package/templates/cpp-lib/windows/MyLib/MyLib.rc +0 -0
- package/templates/cpp-lib/windows/MyLib/MyLib.vcxproj +148 -0
- package/templates/cpp-lib/windows/MyLib/MyLib.vcxproj.filters +44 -0
- package/templates/cpp-lib/windows/MyLib/ReactPackageProvider.cpp +20 -0
- package/templates/cpp-lib/windows/MyLib/ReactPackageProvider.h +24 -0
- package/templates/cpp-lib/windows/MyLib/ReactPackageProvider.idl +9 -0
- package/templates/cpp-lib/windows/MyLib/pch.cpp +1 -0
- package/templates/cpp-lib/windows/MyLib/pch.h +30 -0
- package/templates/cpp-lib/windows/MyLib/resource.h +5 -0
- package/templates/cpp-lib/windows/MyLib/targetver.h +8 -0
- package/templates/cpp-lib/windows/MyLib.sln +156 -0
- package/templates/cpp-lib/windows/_gitignore +41 -0
- package/templates/templateUtils.js +137 -0
- package/types/modules/globals.d.ts +1 -0
- package/Folly/TEMP_UntilFollyUpdate/hash/Hash.h +0 -1016
- package/Libraries/Components/Button.flow.js +0 -265
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.windows.js +0 -8
- package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.windows.js +0 -14
- package/Libraries/Components/SafeAreaView/SafeAreaView.windows.js +0 -34
- package/Libraries/Components/ScrollView/ScrollView.windows.js +0 -1941
- package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +0 -85
- package/Libraries/Components/ToastAndroid/ToastAndroid.windows.js +0 -45
- package/Libraries/Components/Touchable/Touchable.flow.js +0 -284
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +0 -189
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +0 -43
- package/Libraries/Image/Image.flow.js +0 -64
- package/Libraries/Inspector/DevtoolsOverlay.js +0 -223
- package/Libraries/Performance/QuickPerformanceLogger.js +0 -142
- package/Libraries/Settings/Settings.windows.js +0 -28
- package/Microsoft.ReactNative/CoreApp.cpp +0 -303
- package/Microsoft.ReactNative/CoreAppPage.cpp +0 -21
- package/Microsoft.ReactNative/CoreAppPage.idl +0 -12
- package/Microsoft.ReactNative/CoreAppPage.xaml +0 -14
- package/Microsoft.ReactNative/Fabric/Composition/AbiCompositionViewComponentView.cpp +0 -197
- package/Microsoft.ReactNative/Fabric/Composition/AbiCompositionViewComponentView.h +0 -84
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/EventEmitters.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/Props.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/ShadowNodes.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rnwcore/States.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/core/graphicsConversions.h +0 -245
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Color.h +0 -134
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/conversions.h +0 -27
- package/Microsoft.ReactNative/Modules/TimingModule.cpp +0 -229
- package/Microsoft.ReactNative/Modules/TimingModule.h +0 -88
- package/Microsoft.ReactNative.Cxx/CoreApp.h +0 -60
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/LongLivedObject.cpp +0 -60
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/LongLivedObject.h +0 -60
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleBinding.h +0 -63
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/YogaLayoutableShadowNode.cpp +0 -1038
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/YogaStylableProps.cpp +0 -503
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/conversions.h +0 -895
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/mapbuffer/MapBufferBuilder.cpp +0 -182
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/mounting/ShadowTree.cpp +0 -543
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/uimanager/UIManagerBinding.cpp +0 -1505
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/bits/NumericBitfield.h +0 -67
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/config/Config.h +0 -93
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/node/LayoutResults.h +0 -88
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/node/Node.cpp +0 -606
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/node/Node.h +0 -344
- package/ReactCommon/Yoga.cpp +0 -961
- /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRect.js +0 -0
- /package/{Libraries/DOM/Geometry → src/private/webapis/dom/geometry}/DOMRectReadOnly.js +0 -0
- /package/{Libraries/DOM/Nodes → src/private/webapis/dom/nodes}/ReadOnlyText.js +0 -0
- /package/{Libraries/DOM/Nodes/Utilities → src/private/webapis/dom/nodes/utilities}/Traversal.js +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/ArrayLikeUtils.js +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/HTMLCollection.js +0 -0
- /package/{Libraries/DOM/OldStyleCollections → src/private/webapis/dom/oldstylecollections}/NodeList.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/EventCounts.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/MemoryInfo.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/PerformanceEntry.js +0 -0
- /package/{Libraries/WebPerformance → src/private/webapis/performance}/ReactNativeStartupTiming.js +0 -0
- /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
|
-
|
|
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
|
|
29
|
-
|
|
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
|
-
|
|
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::
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
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
|
-
|
|
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::
|
|
138
|
-
|
|
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
|
-
|
|
141
|
-
|
|
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
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
188
|
-
|
|
189
|
-
|
|
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
|
-
|
|
203
|
-
|
|
204
|
-
|
|
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
|
-
|
|
212
|
-
|
|
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::
|
|
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::
|
|
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::
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
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
|
-
|
|
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::
|
|
1031
|
+
Super::HandleCommand(commandName, args);
|
|
414
1032
|
}
|
|
415
1033
|
}
|
|
416
1034
|
|
|
417
|
-
void ScrollViewComponentView::
|
|
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(
|
|
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
|
-
|
|
561
|
-
|
|
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
|