react-native-windows 0.81.1 → 0.82.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 +11 -10
- package/Directory.Build.props +3 -3
- package/Folly/Folly.vcxproj +1 -3
- package/Libraries/ActionSheetIOS/ActionSheetIOS.js +7 -3
- package/Libraries/Alert/RCTAlertManager.android.js +4 -2
- package/Libraries/Animated/Animated.d.ts +2 -0
- package/Libraries/Animated/AnimatedEvent.js +1 -1
- package/Libraries/Animated/AnimatedExports.js.flow +1 -0
- package/Libraries/Animated/AnimatedImplementation.js +4 -2
- package/Libraries/Animated/AnimatedMock.js +1 -1
- package/Libraries/Animated/Easing.js +2 -0
- package/Libraries/Animated/NativeAnimatedAllowlist.js +1 -0
- package/Libraries/Animated/animations/Animation.js +19 -20
- package/Libraries/Animated/animations/TimingAnimation.js +2 -0
- package/Libraries/Animated/components/AnimatedScrollView.js +3 -2
- package/Libraries/Animated/components/AnimatedSectionList.js +1 -1
- package/Libraries/Animated/nodes/AnimatedColor.js +9 -9
- package/Libraries/Animated/nodes/AnimatedInterpolation.js +4 -4
- package/Libraries/Animated/nodes/AnimatedNode.js +14 -7
- package/Libraries/Animated/nodes/AnimatedObject.js +7 -7
- package/Libraries/Animated/nodes/AnimatedProps.js +32 -32
- package/Libraries/Animated/nodes/AnimatedStyle.js +23 -21
- package/Libraries/Animated/nodes/AnimatedTransform.js +6 -6
- package/Libraries/Animated/nodes/AnimatedValue.js +18 -18
- package/Libraries/AppState/AppState.js +8 -4
- package/Libraries/BatchedBridge/MessageQueue.js +4 -0
- package/Libraries/BatchedBridge/NativeModules.js +1 -1
- package/Libraries/Blob/BlobManager.js +1 -1
- package/Libraries/Blob/URLSearchParams.js +2 -0
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +2 -2
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.windows.js +2 -2
- package/Libraries/Components/Button.js +1 -1
- package/Libraries/Components/Button.windows.js +1 -1
- package/Libraries/Components/Flyout/FlyoutNativeComponent.js +2 -2
- package/Libraries/Components/Glyph/GlyphNativeComponent.js +1 -1
- package/Libraries/Components/Popup/PopupNativeComponent.js +1 -0
- package/Libraries/Components/Pressable/Pressable.d.ts +8 -0
- package/Libraries/Components/Pressable/Pressable.js +10 -1
- package/Libraries/Components/Pressable/Pressable.windows.js +30 -2
- package/Libraries/Components/Pressable/useAndroidRippleForView.js +2 -2
- package/Libraries/Components/ScrollView/ScrollView.js +13 -4
- package/Libraries/Components/ScrollView/ScrollView.windows.js +14 -5
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +1 -1
- package/Libraries/Components/StatusBar/StatusBar.js +2 -2
- package/Libraries/Components/Switch/Switch.js +2 -2
- package/Libraries/Components/Switch/Switch.windows.js +2 -2
- package/Libraries/Components/TextInput/TextInput.flow.js +12 -5
- package/Libraries/Components/TextInput/TextInput.flow.windows.js +12 -5
- package/Libraries/Components/TextInput/TextInput.js +14 -5
- package/Libraries/Components/TextInput/TextInput.windows.js +23 -11
- package/Libraries/Components/TextInput/TextInputState.js +1 -1
- package/Libraries/Components/TextInput/TextInputState.windows.js +1 -1
- package/Libraries/Components/Touchable/TouchableBounce.js +1 -1
- package/Libraries/Components/Touchable/TouchableHighlight.js +1 -1
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +1 -1
- package/Libraries/Components/Touchable/TouchableOpacity.js +1 -1
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +3 -3
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.windows.js +1 -1
- package/Libraries/Components/View/View.js +81 -167
- package/Libraries/Components/View/View.windows.js +202 -302
- package/Libraries/Core/Devtools/loadBundleFromServer.js +1 -1
- package/Libraries/Core/Devtools/loadBundleFromServer.windows.js +1 -1
- package/Libraries/Core/ExceptionsManager.js +4 -2
- package/Libraries/Core/ReactFiberErrorDialog.js +3 -3
- package/Libraries/Core/ReactNativeVersion.js +37 -10
- package/Libraries/Core/Timers/JSTimers.js +3 -1
- package/Libraries/Core/Timers/immediateShim.js +1 -1
- package/Libraries/Core/Timers/queueMicrotask.js +1 -0
- package/Libraries/Core/setUpPerformance.js +2 -1
- package/Libraries/Debugging/DebuggingOverlayRegistry.js +5 -3
- package/Libraries/Image/AssetSourceResolver.windows.js +2 -2
- package/Libraries/Image/Image.android.js +327 -111
- package/Libraries/Image/Image.ios.js +6 -1
- package/Libraries/Image/Image.windows.js +28 -61
- package/Libraries/Image/ImageSourceUtils.js +8 -2
- package/Libraries/Image/resolveAssetSource.js +1 -1
- package/Libraries/Image/resolveAssetSource.windows.js +1 -1
- package/Libraries/Interaction/InteractionManager.js +118 -167
- package/Libraries/Interaction/PanResponder.js +1 -1
- package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -0
- package/Libraries/Lists/FlatList.js +5 -6
- package/Libraries/LogBox/Data/LogBoxData.js +5 -2
- package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +1 -1
- package/Libraries/Modal/Modal.js +3 -3
- package/Libraries/Modal/Modal.windows.js +2 -2
- package/Libraries/NativeComponent/NativeComponentRegistry.js +1 -1
- package/Libraries/NativeComponent/ViewConfig.js +2 -2
- package/Libraries/Network/RCTNetworking.android.js +1 -1
- package/Libraries/Network/RCTNetworking.ios.js +1 -1
- package/Libraries/Network/RCTNetworking.windows.js +1 -1
- package/Libraries/Network/XMLHttpRequest.js +20 -5
- package/Libraries/Network/convertRequestBody.js +1 -1
- package/Libraries/PermissionsAndroid/PermissionsAndroid.js +10 -9
- package/Libraries/Pressability/HoverState.js +2 -0
- package/Libraries/Pressability/Pressability.js +1 -1
- package/Libraries/Pressability/Pressability.windows.js +5 -5
- package/Libraries/PushNotificationIOS/PushNotificationIOS.js +2 -2
- package/Libraries/ReactNative/AppRegistryImpl.js +4 -2
- package/Libraries/ReactNative/PaperUIManager.windows.js +4 -4
- package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricHostComponent.js +2 -0
- package/Libraries/ReactNative/ReactFabricPublicInstance/ReactFabricPublicInstance.js +3 -3
- package/Libraries/ReactNative/RendererImplementation.js +116 -116
- package/Libraries/ReactNative/UIManager.js +3 -3
- package/Libraries/ReactNative/renderApplication.js +1 -0
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +1 -1
- package/Libraries/Renderer/implementations/ReactFabric-dev.js +38 -35
- package/Libraries/Renderer/implementations/ReactFabric-prod.js +51 -22
- package/Libraries/Renderer/implementations/ReactFabric-profiling.js +54 -24
- package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +36 -33
- package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +5 -5
- package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +5 -5
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +3 -1
- package/Libraries/Share/Share.js +4 -0
- package/Libraries/StyleSheet/PlatformColorValueTypes.android.js +2 -2
- package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +2 -2
- package/Libraries/StyleSheet/PlatformColorValueTypes.windows.js +2 -0
- package/Libraries/StyleSheet/StyleSheet.d.ts +7 -22
- package/Libraries/StyleSheet/StyleSheetExports.js +2 -8
- package/Libraries/StyleSheet/StyleSheetExports.js.flow +11 -18
- package/Libraries/StyleSheet/flattenStyle.js +2 -2
- package/Libraries/StyleSheet/processAspectRatio.js +2 -0
- package/Libraries/StyleSheet/processFilter.js +5 -5
- package/Libraries/StyleSheet/splitLayoutProps.js +2 -2
- package/Libraries/Text/Text.js +534 -234
- package/Libraries/Text/Text.windows.js +622 -265
- package/Libraries/Text/TextNativeComponent.js +2 -2
- package/Libraries/Utilities/Appearance.d.ts +3 -5
- package/Libraries/Utilities/Appearance.js +5 -17
- package/Libraries/Utilities/HMRClient.js +2 -1
- package/Libraries/Utilities/Platform.android.js +3 -3
- package/Libraries/Utilities/Platform.d.ts +1 -0
- package/Libraries/Utilities/Platform.ios.js +1 -1
- package/Libraries/Utilities/Platform.windows.js +3 -3
- package/Libraries/Utilities/PlatformTypes.js +1 -1
- package/Libraries/Utilities/ReactNativeTestTools.js +12 -0
- package/Libraries/Utilities/SceneTracker.js +1 -1
- package/Libraries/Utilities/codegenNativeCommands.js +1 -1
- package/Libraries/Utilities/codegenNativeComponent.js +1 -1
- package/Libraries/Utilities/createPerformanceLogger.js +32 -0
- package/Libraries/Utilities/deepFreezeAndThrowOnMutationInDev.js +2 -0
- package/Libraries/Utilities/differ/pointsDiffer.js +1 -1
- package/Libraries/Utilities/useMergeRefs.js +1 -1
- package/Libraries/WebSocket/WebSocketInterceptor.js +2 -0
- package/Libraries/promiseRejectionTrackingOptions.js +17 -31
- package/Libraries/vendor/emitter/EventEmitter.js +1 -1
- package/Microsoft.ReactNative/App.xaml +5 -0
- package/Microsoft.ReactNative/Base/CxxReactIncludes.h +0 -3
- package/Microsoft.ReactNative/CompositionContext.idl +0 -2
- package/Microsoft.ReactNative/Fabric/AbiViewProps.cpp +2 -2
- package/Microsoft.ReactNative/Fabric/AbiViewProps.h +0 -2
- package/Microsoft.ReactNative/Fabric/ComponentView.cpp +26 -0
- package/Microsoft.ReactNative/Fabric/ComponentView.h +2 -0
- package/Microsoft.ReactNative/Fabric/Composition/ActivityIndicatorComponentView.cpp +0 -1
- package/Microsoft.ReactNative/Fabric/Composition/Composition.Input.cpp +0 -69
- package/Microsoft.ReactNative/Fabric/Composition/Composition.Input.h +1 -15
- package/Microsoft.ReactNative/Fabric/Composition/CompositionAnnotationProvider.cpp +2 -5
- package/Microsoft.ReactNative/Fabric/Composition/CompositionAnnotationProvider.h +1 -4
- package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper.cpp +0 -31
- package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper.h +0 -10
- package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper_emptyimpl.cpp +0 -4
- package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.cpp +65 -32
- package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.h +9 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.cpp +8 -6
- package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.h +0 -2
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHelpers.h +0 -2
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHwndHost.cpp +0 -9
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.cpp +2 -11
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.h +0 -4
- package/Microsoft.ReactNative/Fabric/Composition/CompositionTextProvider.cpp +4 -7
- package/Microsoft.ReactNative/Fabric/Composition/CompositionTextProvider.h +1 -5
- package/Microsoft.ReactNative/Fabric/Composition/CompositionTextRangeProvider.cpp +68 -53
- package/Microsoft.ReactNative/Fabric/Composition/CompositionTextRangeProvider.h +1 -5
- package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.cpp +20 -18
- package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.h +10 -3
- package/Microsoft.ReactNative/Fabric/Composition/ContentIslandComponentView.cpp +30 -9
- package/Microsoft.ReactNative/Fabric/Composition/ContentIslandComponentView.h +4 -1
- package/Microsoft.ReactNative/Fabric/Composition/DebuggingOverlayComponentView.cpp +3 -2
- package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.cpp +0 -2
- package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.h +0 -1
- package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.cpp +550 -4
- package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.h +52 -0
- package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.cpp +16 -0
- package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.h +6 -0
- package/Microsoft.ReactNative/Fabric/Composition/ReactNativeIsland.cpp +0 -6
- package/Microsoft.ReactNative/Fabric/Composition/ReactNativeIsland.h +0 -2
- package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.cpp +53 -2
- package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.h +8 -1
- package/Microsoft.ReactNative/Fabric/Composition/ScrollViewComponentView.cpp +0 -2
- package/Microsoft.ReactNative/Fabric/Composition/SwitchComponentView.cpp +0 -1
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.cpp +5 -2
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputShadowNode.cpp +4 -1
- package/Microsoft.ReactNative/Fabric/Composition/Theme.cpp +6 -30
- package/Microsoft.ReactNative/Fabric/Composition/Theme.h +1 -3
- package/Microsoft.ReactNative/Fabric/Composition/TooltipService.cpp +1 -1
- package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.cpp +36 -14
- package/Microsoft.ReactNative/Fabric/Composition/UnimplementedNativeViewComponentView.cpp +0 -1
- package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.cpp +0 -1
- package/Microsoft.ReactNative/Fabric/ImageManager.cpp +0 -4
- package/Microsoft.ReactNative/Fabric/ReactTaggedView.h +1 -1
- package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.cpp +8 -0
- package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.h +3 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/PlatformColorUtils.cpp +0 -11
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/WindowsTextLayoutManager.h +2 -1
- package/Microsoft.ReactNative/IReactContext.cpp +2 -25
- package/Microsoft.ReactNative/IReactContext.h +0 -7
- package/Microsoft.ReactNative/IReactContext.idl +4 -29
- package/Microsoft.ReactNative/IReactModuleBuilder.cpp +24 -140
- package/Microsoft.ReactNative/IReactModuleBuilder.h +0 -11
- package/Microsoft.ReactNative/IReactPackageBuilder.idl +1 -16
- package/Microsoft.ReactNative/IReactPackageProvider.idl +0 -1
- package/Microsoft.ReactNative/IReactViewComponentBuilder.idl +10 -0
- package/Microsoft.ReactNative/JsiApi.cpp +4 -3
- package/Microsoft.ReactNative/JsiApi.h +2 -3
- package/Microsoft.ReactNative/JsiApi.idl +3 -2
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj +6 -214
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj.filters +0 -252
- package/Microsoft.ReactNative/Modules/AccessibilityInfoModule.cpp +0 -37
- package/Microsoft.ReactNative/Modules/AlertModule.cpp +2 -140
- package/Microsoft.ReactNative/Modules/AlertModule.h +0 -2
- package/Microsoft.ReactNative/Modules/Animated/NativeAnimatedNodeManager.cpp +5 -10
- package/Microsoft.ReactNative/Modules/Animated/NativeAnimatedNodeManager.h +0 -1
- package/Microsoft.ReactNative/Modules/Animated/PropsAnimatedNode.cpp +1 -96
- package/Microsoft.ReactNative/Modules/Animated/PropsAnimatedNode.h +0 -14
- package/Microsoft.ReactNative/Modules/AppStateModule.cpp +0 -53
- package/Microsoft.ReactNative/Modules/AppStateModule.h +0 -5
- package/Microsoft.ReactNative/Modules/AppThemeModuleUwp.cpp +5 -14
- package/Microsoft.ReactNative/Modules/AppThemeModuleUwp.h +0 -2
- package/Microsoft.ReactNative/Modules/AppearanceModule.cpp +1 -9
- package/Microsoft.ReactNative/Modules/DevSettingsModule.cpp +0 -4
- package/Microsoft.ReactNative/Modules/DevSettingsModule.h +0 -2
- package/Microsoft.ReactNative/Modules/DeviceInfoModule.cpp +16 -90
- package/Microsoft.ReactNative/Modules/I18nManagerModule.cpp +3 -8
- package/Microsoft.ReactNative/Modules/ImageViewManagerModule.cpp +11 -48
- package/Microsoft.ReactNative/Modules/LinkingManagerModule.cpp +0 -3
- package/Microsoft.ReactNative/Modules/LogBoxModule.cpp +30 -102
- package/Microsoft.ReactNative/Modules/LogBoxModule.h +0 -7
- package/Microsoft.ReactNative/Modules/Timing.cpp +7 -9
- package/Microsoft.ReactNative/Pch/pch.h +0 -28
- package/Microsoft.ReactNative/ReactCoreInjection.h +0 -1
- package/Microsoft.ReactNative/ReactHost/IReactInstance.h +0 -8
- package/Microsoft.ReactNative/ReactHost/MsoReactContext.cpp +0 -15
- package/Microsoft.ReactNative/ReactHost/MsoReactContext.h +0 -2
- package/Microsoft.ReactNative/ReactHost/React.h +0 -44
- package/Microsoft.ReactNative/ReactHost/ReactHost.cpp +10 -47
- package/Microsoft.ReactNative/ReactHost/ReactHost.h +1 -1
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.cpp +30 -586
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.h +2 -37
- package/Microsoft.ReactNative/ReactHost/ReactNativeHeaders.h +0 -13
- package/Microsoft.ReactNative/ReactHost/React_Win.h +0 -1
- package/Microsoft.ReactNative/ReactInstanceSettings.cpp +0 -8
- package/Microsoft.ReactNative/ReactInstanceSettings.h +0 -13
- package/Microsoft.ReactNative/ReactInstanceSettings.idl +7 -23
- package/Microsoft.ReactNative/ReactNativeHost.cpp +10 -35
- package/Microsoft.ReactNative/ReactNativeHost.h +0 -1
- package/Microsoft.ReactNative/ReactNativeIsland.idl +0 -4
- package/Microsoft.ReactNative/ReactPackageBuilder.cpp +9 -36
- package/Microsoft.ReactNative/ReactPackageBuilder.h +4 -38
- package/Microsoft.ReactNative/RedBox.cpp +9 -362
- package/Microsoft.ReactNative/Theme.idl +0 -2
- package/Microsoft.ReactNative/Timer.cpp +3 -2
- package/Microsoft.ReactNative/Utils/Helpers.cpp +0 -47
- package/Microsoft.ReactNative/Utils/Helpers.h +0 -5
- package/Microsoft.ReactNative/Utils/IcuUtils.cpp +84 -0
- package/Microsoft.ReactNative/Utils/IcuUtils.h +42 -0
- package/Microsoft.ReactNative/Utils/KeyboardUtils.cpp +0 -11
- package/Microsoft.ReactNative/Utils/ThemeUtils.cpp +0 -4
- package/Microsoft.ReactNative/Utils/ThemeUtils.h +1 -5
- package/Microsoft.ReactNative/Utils/UwpPreparedScriptStore.h +0 -2
- package/Microsoft.ReactNative/Utils/ValueUtils.cpp +0 -245
- package/Microsoft.ReactNative/Utils/ValueUtils.h +0 -23
- package/Microsoft.ReactNative/ViewProps.idl +0 -2
- package/Microsoft.ReactNative/Views/DevMenu.cpp +2 -278
- package/Microsoft.ReactNative/Views/DevMenu.h +0 -5
- package/Microsoft.ReactNative/XamlApplication.cpp +71 -0
- package/Microsoft.ReactNative/XamlApplication.h +47 -0
- package/Microsoft.ReactNative/XamlApplication.idl +19 -0
- package/Microsoft.ReactNative/XamlUIService.cpp +0 -54
- package/Microsoft.ReactNative/XamlUIService.h +0 -12
- package/Microsoft.ReactNative/XamlUIService.idl +0 -12
- package/Microsoft.ReactNative.Cxx/CppWinRTIncludes.h +0 -19
- package/Microsoft.ReactNative.Cxx/DesktopWindowBridge.h +1 -1
- package/Microsoft.ReactNative.Cxx/JSI/decorator.h +191 -114
- package/Microsoft.ReactNative.Cxx/JSI/instrumentation.h +5 -0
- package/Microsoft.ReactNative.Cxx/JSI/jsi-inl.h +37 -0
- package/Microsoft.ReactNative.Cxx/JSI/jsi.cpp +68 -0
- package/Microsoft.ReactNative.Cxx/JSI/jsi.h +77 -11
- package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems +2 -2
- package/Microsoft.ReactNative.Cxx/NamespaceRedirect.h +0 -5
- package/Microsoft.ReactNative.Cxx/NodeApiJsiRuntime.cpp +93 -1
- package/Microsoft.ReactNative.Cxx/ReactCommon/TurboModule.cpp +4 -3
- package/Microsoft.ReactNative.Cxx/ReactCommon/TurboModule.h +2 -2
- package/Microsoft.ReactNative.Cxx/ReactCommon/TurboModuleUtils.cpp +2 -55
- package/Microsoft.ReactNative.Cxx/ReactCommon/TurboModuleUtils.h +4 -8
- package/Microsoft.ReactNative.Cxx/ReactCommon/react/bridging/Class.h +5 -0
- package/Microsoft.ReactNative.Cxx/ReactCommon/react/timing/primitives.h +32 -4
- package/Microsoft.ReactNative.Cxx/ReactContext.h +0 -13
- package/Microsoft.ReactNative.Cxx/StructInfo.h +8 -1
- package/Microsoft.ReactNative.Cxx/UI.Composition.Effects.h +0 -4
- package/Microsoft.ReactNative.Cxx/UI.Composition.h +0 -4
- package/Microsoft.ReactNative.Cxx/UI.Input.h +0 -4
- package/Microsoft.ReactNative.Cxx/UI.Popups.h +0 -4
- package/Microsoft.ReactNative.Cxx/UI.Text.h +0 -4
- package/Microsoft.ReactNative.Cxx/XamlUtils.h +0 -33
- package/Microsoft.ReactNative.Managed/JSValueReader.cs +0 -4
- package/Microsoft.ReactNative.Managed/Microsoft.ReactNative.Managed.csproj +0 -3
- package/Microsoft.ReactNative.Managed/ReactContext.cs +0 -5
- package/Microsoft.ReactNative.Managed/ReactContextGenerator.cs +0 -4
- package/Microsoft.ReactNative.Managed/ReactPackageBuilderExtensions.cs +0 -25
- package/Microsoft.ReactNative.Managed/ReactSettingsSnapshot.cs +0 -4
- package/Microsoft.ReactNative.Managed/ReflectionReactPackageProvider.cs +1 -2
- package/Microsoft.ReactNative.Managed.CodeGen/CodeAnalyzer.cs +0 -10
- package/Microsoft.ReactNative.Managed.CodeGen/CodeGenerator.ViewManager.cs +0 -36
- package/Microsoft.ReactNative.Managed.CodeGen/CodeGenerator.cs +0 -6
- package/Microsoft.ReactNative.Managed.CodeGen/Model/ReactAssembly.cs +0 -2
- package/Microsoft.ReactNative.Managed.CodeGen/Model/ReactTypes.cs +0 -2
- package/Microsoft.ReactNative.Managed.CodeGen/ReactNativeNames.cs +0 -2
- package/Mso/src/dispatchQueue/queueService.cpp +3 -1
- package/Mso/src/dispatchQueue/uiScheduler_winrt.cpp +2 -10
- package/PropertySheets/Bundle.Common.targets +1 -1
- package/PropertySheets/Bundle.props +3 -4
- package/PropertySheets/External/Microsoft.ReactNative.Common.props +0 -1
- package/PropertySheets/External/Microsoft.ReactNative.Uwp.CSharpApp.targets +1 -1
- package/PropertySheets/External/Microsoft.ReactNative.Uwp.CppApp.targets +1 -1
- package/PropertySheets/Generated/PackageVersion.g.props +4 -4
- package/PropertySheets/JSEngine.props +1 -1
- package/PropertySheets/NuGet.LockFile.props +0 -8
- package/PropertySheets/OutputMSBuildProperties.targets +0 -1
- package/PropertySheets/React.Cpp.props +3 -5
- package/PropertySheets/WinUI.props +3 -3
- package/README.md +1 -5
- package/ReactCommon/ReactCommon.vcxproj +12 -31
- package/ReactCommon/ReactCommon.vcxproj.filters +0 -3
- package/ReactCommon/TEMP_UntilReactCommonUpdate/cxxreact/CxxNativeModule.cpp +3 -2
- package/ReactCommon/TEMP_UntilReactCommonUpdate/cxxreact/NativeToJsBridge.cpp +5 -2
- package/ReactCommon/TEMP_UntilReactCommonUpdate/cxxreact/TraceSection.h +20 -4
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsi/jsi/test/testlib.cpp +113 -1
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsinspector-modern/NetworkIOAgent.cpp +14 -6
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsinspector-modern/Utf8.h +1 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/jsinspector-modern/tracing/RuntimeSamplingProfileTraceEventSerializer.cpp +351 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModule.h +2 -2
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/dom/NativeDOM.cpp +42 -36
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/dom/NativeDOM.h +15 -3
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/componentregistry/ComponentDescriptorRegistry.cpp +1 -1
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/image/conversions.h +174 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/text/ParagraphShadowNode.cpp +1 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/AccessibilityPrimitives.h +26 -3
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/conversions.h +1 -1
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/core/ShadowNode.cpp +1 -1
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/imagemanager/primitives.h +189 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/reactperflogger/reactperflogger/ReactPerfettoLogger.cpp +27 -8
- package/ReactCommon/cgmanifest.json +1 -1
- package/Scripts/Microsoft.ReactNative.nuspec +15 -33
- package/Scripts/NuGetRestoreForceEvaluateAllSolutions.ps1 +23 -23
- package/Scripts/OfficeReact.Win32.nuspec +0 -3
- package/Scripts/creaternwapp.cmd +1 -1
- package/Shared/DevServerHelper.h +17 -21
- package/Shared/DevSettings.h +1 -25
- package/Shared/DevSupportManager.cpp +0 -50
- package/Shared/DevSupportManager.h +0 -4
- package/Shared/Hermes/HermesRuntimeTargetDelegate.cpp +5 -1
- package/Shared/HermesRuntimeHolder.cpp +0 -31
- package/Shared/HermesRuntimeHolder.h +0 -14
- package/Shared/IDevSupportManager.h +0 -6
- package/Shared/InstanceManager.cpp +0 -97
- package/Shared/InstanceManager.h +0 -53
- package/Shared/JSI/ScriptStore.h +1 -1
- package/Shared/Logging.cpp +1 -12
- package/Shared/Modules/CxxModuleUtilities.cpp +0 -9
- package/Shared/Modules/CxxModuleUtilities.h +0 -8
- package/Shared/Networking/OriginPolicyHttpFilter.cpp +9 -1
- package/Shared/OInstance.cpp +144 -424
- package/Shared/OInstance.h +0 -81
- package/Shared/Shared.vcxitems +83 -203
- package/Shared/Shared.vcxitems.filters +8 -67
- package/Shared/Threading/MessageQueueThreadFactory.cpp +0 -6
- package/Shared/Threading/MessageQueueThreadFactory.h +0 -4
- package/Shared/TurboModuleManager.cpp +0 -4
- package/Shared/Utils.cpp +26 -0
- package/Shared/Utils.h +3 -0
- package/codegen/NativeDOMSpec.g.h +41 -35
- package/codegen/NativeIntersectionObserverSpec.g.h +9 -21
- package/codegen/NativePerformanceSpec.g.h +47 -35
- package/codegen/NativeReactNativeFeatureFlagsSpec.g.h +177 -129
- package/codegen/react/components/rnwcore/ActivityIndicatorView.g.h +14 -0
- package/codegen/react/components/rnwcore/AndroidDrawerLayout.g.h +14 -0
- package/codegen/react/components/rnwcore/AndroidHorizontalScrollContentView.g.h +14 -0
- package/codegen/react/components/rnwcore/AndroidProgressBar.g.h +14 -0
- package/codegen/react/components/rnwcore/AndroidSwipeRefreshLayout.g.h +14 -0
- package/codegen/react/components/rnwcore/AndroidSwitch.g.h +14 -0
- package/codegen/react/components/rnwcore/DebuggingOverlay.g.h +14 -0
- package/codegen/react/components/rnwcore/EventEmitters.cpp +25 -0
- package/codegen/react/components/rnwcore/EventEmitters.h +25 -0
- package/codegen/react/components/rnwcore/InputAccessory.g.h +14 -0
- package/codegen/react/components/rnwcore/ModalHostView.g.h +14 -0
- package/codegen/react/components/rnwcore/Props.cpp +41 -2
- package/codegen/react/components/rnwcore/Props.h +51 -2
- package/codegen/react/components/rnwcore/PullToRefreshView.g.h +14 -0
- package/codegen/react/components/rnwcore/SafeAreaView.g.h +14 -0
- package/codegen/react/components/rnwcore/Switch.g.h +14 -0
- package/codegen/react/components/rnwcore/UnimplementedNativeView.g.h +14 -0
- package/codegen/react/components/rnwcore/VirtualView.g.h +18 -0
- package/codegen/react/components/rnwcore/VirtualViewExperimental.g.h +240 -0
- package/codegen/rnwcoreJSI-generated.cpp +106 -51
- package/codegen/rnwcoreJSI.h +148 -67
- package/fmt/cgmanifest.json +1 -1
- package/fmt/fmt.vcxproj +0 -8
- package/index.js +8 -2
- package/index.windows.js +8 -2
- package/jest/local-setup.js +2 -2
- package/jest/mock.js +1 -1
- package/jest/mockComponent.js +9 -9
- package/jest/mockNativeComponent.js +3 -2
- package/jest/mocks/Modal.js +1 -1
- package/jest/mocks/ScrollView.js +1 -1
- package/jest/mocks/ViewNativeComponent.js +1 -1
- package/jest/setup.js +23 -12
- package/just-task.js +14 -0
- package/package.json +31 -32
- package/src/private/animated/NativeAnimatedHelper.js +16 -5
- package/src/private/animated/createAnimatedPropsHook.js +11 -60
- package/src/private/animated/createAnimatedPropsMemoHook.js +8 -54
- package/src/private/components/virtualview/VirtualView.js +43 -12
- package/src/private/components/virtualview/VirtualViewExperimentalNativeComponent.js +93 -0
- package/src/private/components/virtualview/VirtualViewNativeComponent.js +6 -0
- package/src/private/devsupport/devmenu/elementinspector/Inspector.js +2 -2
- package/src/private/devsupport/devmenu/elementinspector/ReactDevToolsOverlay.js +2 -2
- package/src/private/featureflags/ReactNativeFeatureFlags.js +80 -52
- package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +23 -4
- package/src/private/featureflags/specs/NativeReactNativeFeatureFlags.js +14 -6
- package/src/private/renderer/errorhandling/ErrorHandlers.js +3 -3
- package/src/private/specs_DEPRECATED/components/SwitchNativeComponent.js +0 -1
- package/src/private/types/HostInstance.js +4 -1
- package/src/private/webapis/dom/nodes/ReactNativeDocument.js +22 -2
- package/src/private/webapis/dom/nodes/ReactNativeElement.js +1 -1
- package/src/private/webapis/dom/nodes/ReadOnlyElement.js +5 -3
- package/src/private/webapis/dom/nodes/ReadOnlyNode.js +16 -13
- package/src/private/webapis/dom/nodes/internals/NodeInternals.js +45 -22
- package/src/private/webapis/dom/nodes/internals/ReactNativeDocumentInstanceHandle.js +1 -1
- package/src/private/webapis/dom/nodes/specs/NativeDOM.js +26 -192
- package/src/private/webapis/dom/oldstylecollections/HTMLCollection.js +15 -12
- package/src/private/webapis/dom/oldstylecollections/NodeList.js +14 -11
- package/src/private/webapis/geometry/DOMRectList.js +2 -2
- package/src/private/webapis/intersectionobserver/internals/IntersectionObserverManager.js +19 -74
- package/src/private/webapis/intersectionobserver/specs/NativeIntersectionObserver.js +0 -4
- package/src/private/webapis/mutationobserver/internals/MutationObserverManager.js +1 -1
- package/src/private/webapis/performance/EventTiming.js +6 -10
- package/src/private/webapis/performance/Performance.js +309 -164
- package/src/private/webapis/performance/PerformanceEntry.js +20 -16
- package/src/private/webapis/performance/PerformanceObserver.js +8 -29
- package/src/private/webapis/performance/UserTiming.js +71 -18
- package/src/private/webapis/performance/UserTimingExtensibility.js.flow +38 -0
- package/src/private/webapis/performance/internals/Utilities.js +9 -0
- package/src/private/webapis/performance/specs/NativePerformance.js +21 -23
- package/src/private/webapis/structuredClone/structuredClone.js +10 -10
- package/stubs/double-conversion/README.md +1 -1
- package/template/cpp-lib/proj/MyLib.sln +0 -5
- package/template/cpp-lib/src/pch.h +0 -5
- package/template/cs-lib/proj/MyLib.sln +0 -5
- package/template/metro.config.js +1 -0
- package/templates/cpp-app/metro.config.js +2 -1
- package/templates/cpp-app/windows/MyApp.sln +0 -5
- package/templates/cpp-lib/example/metro.config.js +3 -4
- package/templates/cpp-lib/windows/MyLib.sln +0 -5
- package/Chakra/Chakra.vcxitems +0 -32
- package/Chakra/Chakra.vcxitems.filters +0 -54
- package/Chakra/ChakraHelpers.cpp +0 -468
- package/Chakra/ChakraHelpers.h +0 -146
- package/Chakra/ChakraInstanceArgs.h +0 -52
- package/Chakra/ChakraPlatform.cpp +0 -42
- package/Chakra/ChakraPlatform.h +0 -51
- package/Chakra/ChakraTracing.cpp +0 -275
- package/Chakra/ChakraTracing.h +0 -11
- package/Chakra/ChakraUtils.cpp +0 -190
- package/Chakra/ChakraUtils.h +0 -72
- package/Chakra/ChakraValue.cpp +0 -257
- package/Chakra/ChakraValue.h +0 -308
- package/Chakra/Utf8DebugExtensions.cpp +0 -62
- package/Chakra/Utf8DebugExtensions.h +0 -29
- package/Libraries/Interaction/InteractionManagerStub.js +0 -184
- package/Libraries/Interaction/TaskQueue.js +0 -183
- package/Libraries/ReactNative/ReactNativeFeatureFlags.js +0 -31
- package/Microsoft.ReactNative/ABICxxModule.cpp +0 -51
- package/Microsoft.ReactNative/ABICxxModule.h +0 -38
- package/Microsoft.ReactNative/ABIViewManager.cpp +0 -263
- package/Microsoft.ReactNative/ABIViewManager.h +0 -100
- package/Microsoft.ReactNative/Base/CoreUIManagers.cpp +0 -55
- package/Microsoft.ReactNative/DevMenuControl.cpp +0 -14
- package/Microsoft.ReactNative/DevMenuControl.h +0 -20
- package/Microsoft.ReactNative/DevMenuControl.idl +0 -28
- package/Microsoft.ReactNative/DevMenuControl.xaml +0 -139
- package/Microsoft.ReactNative/GlyphViewManager.cpp +0 -167
- package/Microsoft.ReactNative/GlyphViewManager.h +0 -24
- package/Microsoft.ReactNative/INativeUIManager.h +0 -75
- package/Microsoft.ReactNative/IViewManager.idl +0 -120
- package/Microsoft.ReactNative/IViewManagerCore.idl +0 -45
- package/Microsoft.ReactNative/LayoutService.cpp +0 -51
- package/Microsoft.ReactNative/LayoutService.h +0 -32
- package/Microsoft.ReactNative/LayoutService.idl +0 -41
- package/Microsoft.ReactNative/Modules/NativeUIManager.cpp +0 -1187
- package/Microsoft.ReactNative/Modules/NativeUIManager.h +0 -128
- package/Microsoft.ReactNative/Modules/PaperUIManagerModule.cpp +0 -891
- package/Microsoft.ReactNative/Modules/PaperUIManagerModule.h +0 -185
- package/Microsoft.ReactNative/NativeModulesProvider.cpp +0 -49
- package/Microsoft.ReactNative/NativeModulesProvider.h +0 -25
- package/Microsoft.ReactNative/ReactApplication.cpp +0 -276
- package/Microsoft.ReactNative/ReactApplication.h +0 -156
- package/Microsoft.ReactNative/ReactApplication.idl +0 -48
- package/Microsoft.ReactNative/ReactHost/ViewManagerProvider.h +0 -19
- package/Microsoft.ReactNative/ReactPointerEventArgs.cpp +0 -55
- package/Microsoft.ReactNative/ReactPointerEventArgs.h +0 -32
- package/Microsoft.ReactNative/ReactPointerEventArgs.idl +0 -79
- package/Microsoft.ReactNative/ReactRootView.cpp +0 -592
- package/Microsoft.ReactNative/ReactRootView.h +0 -127
- package/Microsoft.ReactNative/ReactRootView.idl +0 -40
- package/Microsoft.ReactNative/TestHook.cpp +0 -99
- package/Microsoft.ReactNative/TestHook.h +0 -15
- package/Microsoft.ReactNative/Utils/AccessibilityUtils.cpp +0 -36
- package/Microsoft.ReactNative/Utils/AccessibilityUtils.h +0 -15
- package/Microsoft.ReactNative/Utils/BatchingEventEmitter.cpp +0 -171
- package/Microsoft.ReactNative/Utils/BatchingEventEmitter.h +0 -72
- package/Microsoft.ReactNative/Utils/PropertyHandlerUtils.h +0 -87
- package/Microsoft.ReactNative/Utils/PropertyUtils.h +0 -568
- package/Microsoft.ReactNative/Utils/ResourceBrushUtils.cpp +0 -182
- package/Microsoft.ReactNative/Utils/ResourceBrushUtils.h +0 -58
- package/Microsoft.ReactNative/Utils/ShadowNodeTypeUtils.h +0 -26
- package/Microsoft.ReactNative/Utils/XamlIslandUtils.cpp +0 -93
- package/Microsoft.ReactNative/Utils/XamlIslandUtils.h +0 -48
- package/Microsoft.ReactNative/ViewManagersProvider.cpp +0 -39
- package/Microsoft.ReactNative/ViewManagersProvider.h +0 -27
- package/Microsoft.ReactNative/Views/ActivityIndicatorViewManager.cpp +0 -62
- package/Microsoft.ReactNative/Views/ActivityIndicatorViewManager.h +0 -29
- package/Microsoft.ReactNative/Views/ConfigureBundlerDlg.cpp +0 -186
- package/Microsoft.ReactNative/Views/ConfigureBundlerDlg.h +0 -11
- package/Microsoft.ReactNative/Views/ControlViewManager.cpp +0 -143
- package/Microsoft.ReactNative/Views/ControlViewManager.h +0 -38
- package/Microsoft.ReactNative/Views/DebuggingOverlayViewManager.cpp +0 -53
- package/Microsoft.ReactNative/Views/DebuggingOverlayViewManager.h +0 -30
- package/Microsoft.ReactNative/Views/DynamicAutomationPeer.cpp +0 -586
- package/Microsoft.ReactNative/Views/DynamicAutomationPeer.h +0 -104
- package/Microsoft.ReactNative/Views/DynamicAutomationProperties.cpp +0 -330
- package/Microsoft.ReactNative/Views/DynamicAutomationProperties.h +0 -111
- package/Microsoft.ReactNative/Views/DynamicValueProvider.cpp +0 -59
- package/Microsoft.ReactNative/Views/DynamicValueProvider.h +0 -32
- package/Microsoft.ReactNative/Views/ExpressionAnimationStore.cpp +0 -61
- package/Microsoft.ReactNative/Views/ExpressionAnimationStore.h +0 -26
- package/Microsoft.ReactNative/Views/FlyoutViewManager.cpp +0 -559
- package/Microsoft.ReactNative/Views/FlyoutViewManager.h +0 -34
- package/Microsoft.ReactNative/Views/FrameworkElementTransferProperties.cpp +0 -126
- package/Microsoft.ReactNative/Views/FrameworkElementTransferProperties.h +0 -23
- package/Microsoft.ReactNative/Views/FrameworkElementViewManager.cpp +0 -957
- package/Microsoft.ReactNative/Views/FrameworkElementViewManager.h +0 -41
- package/Microsoft.ReactNative/Views/IXamlRootView.h +0 -17
- package/Microsoft.ReactNative/Views/Image/ImageViewManager.cpp +0 -245
- package/Microsoft.ReactNative/Views/Image/ImageViewManager.h +0 -45
- package/Microsoft.ReactNative/Views/Image/ReactImage.cpp +0 -469
- package/Microsoft.ReactNative/Views/Image/ReactImage.h +0 -80
- package/Microsoft.ReactNative/Views/Image/ReactImageBrush.cpp +0 -247
- package/Microsoft.ReactNative/Views/Image/ReactImageBrush.h +0 -67
- package/Microsoft.ReactNative/Views/KeyboardEventHandler.cpp +0 -261
- package/Microsoft.ReactNative/Views/KeyboardEventHandler.h +0 -132
- package/Microsoft.ReactNative/Views/PaperShadowNode.cpp +0 -18
- package/Microsoft.ReactNative/Views/PaperShadowNode.h +0 -38
- package/Microsoft.ReactNative/Views/PopupViewManager.cpp +0 -349
- package/Microsoft.ReactNative/Views/PopupViewManager.h +0 -36
- package/Microsoft.ReactNative/Views/RawTextViewManager.cpp +0 -69
- package/Microsoft.ReactNative/Views/RawTextViewManager.h +0 -46
- package/Microsoft.ReactNative/Views/ReactViewInstance.cpp +0 -43
- package/Microsoft.ReactNative/Views/ReactViewInstance.h +0 -53
- package/Microsoft.ReactNative/Views/RefreshControlManager.cpp +0 -116
- package/Microsoft.ReactNative/Views/RefreshControlManager.h +0 -28
- package/Microsoft.ReactNative/Views/RootViewManager.cpp +0 -65
- package/Microsoft.ReactNative/Views/RootViewManager.h +0 -36
- package/Microsoft.ReactNative/Views/SIPEventHandler.cpp +0 -117
- package/Microsoft.ReactNative/Views/SIPEventHandler.h +0 -45
- package/Microsoft.ReactNative/Views/ScrollContentViewManager.cpp +0 -16
- package/Microsoft.ReactNative/Views/ScrollContentViewManager.h +0 -19
- package/Microsoft.ReactNative/Views/ScrollViewManager.cpp +0 -540
- package/Microsoft.ReactNative/Views/ScrollViewManager.h +0 -42
- package/Microsoft.ReactNative/Views/ShadowNodeBase.cpp +0 -228
- package/Microsoft.ReactNative/Views/ShadowNodeBase.h +0 -169
- package/Microsoft.ReactNative/Views/ShadowNodeRegistry.cpp +0 -68
- package/Microsoft.ReactNative/Views/ShadowNodeRegistry.h +0 -40
- package/Microsoft.ReactNative/Views/SliderViewManager.cpp +0 -97
- package/Microsoft.ReactNative/Views/SliderViewManager.h +0 -32
- package/Microsoft.ReactNative/Views/SwitchViewManager.cpp +0 -227
- package/Microsoft.ReactNative/Views/SwitchViewManager.h +0 -31
- package/Microsoft.ReactNative/Views/Text/TextHighlighterVisitor.cpp +0 -52
- package/Microsoft.ReactNative/Views/Text/TextHighlighterVisitor.h +0 -37
- package/Microsoft.ReactNative/Views/Text/TextHitTestUtils.cpp +0 -348
- package/Microsoft.ReactNative/Views/Text/TextHitTestUtils.h +0 -13
- package/Microsoft.ReactNative/Views/Text/TextHitTestVisitor.cpp +0 -76
- package/Microsoft.ReactNative/Views/Text/TextHitTestVisitor.h +0 -32
- package/Microsoft.ReactNative/Views/Text/TextParentVisitor.cpp +0 -12
- package/Microsoft.ReactNative/Views/Text/TextParentVisitor.h +0 -19
- package/Microsoft.ReactNative/Views/Text/TextPropertyChangedParentVisitor.cpp +0 -75
- package/Microsoft.ReactNative/Views/Text/TextPropertyChangedParentVisitor.h +0 -43
- package/Microsoft.ReactNative/Views/Text/TextTransformParentVisitor.cpp +0 -21
- package/Microsoft.ReactNative/Views/Text/TextTransformParentVisitor.h +0 -23
- package/Microsoft.ReactNative/Views/Text/TextTransformVisitor.cpp +0 -70
- package/Microsoft.ReactNative/Views/Text/TextTransformVisitor.h +0 -34
- package/Microsoft.ReactNative/Views/Text/TextVisitor.cpp +0 -56
- package/Microsoft.ReactNative/Views/Text/TextVisitor.h +0 -34
- package/Microsoft.ReactNative/Views/Text/TextVisitorScope.h +0 -35
- package/Microsoft.ReactNative/Views/Text/TextVisitors.h +0 -47
- package/Microsoft.ReactNative/Views/TextInputViewManager.cpp +0 -1003
- package/Microsoft.ReactNative/Views/TextInputViewManager.h +0 -33
- package/Microsoft.ReactNative/Views/TextViewManager.cpp +0 -414
- package/Microsoft.ReactNative/Views/TextViewManager.h +0 -47
- package/Microsoft.ReactNative/Views/TouchEventHandler.cpp +0 -608
- package/Microsoft.ReactNative/Views/TouchEventHandler.h +0 -116
- package/Microsoft.ReactNative/Views/UnimplementedViewManager.cpp +0 -79
- package/Microsoft.ReactNative/Views/UnimplementedViewManager.h +0 -27
- package/Microsoft.ReactNative/Views/ViewControl.cpp +0 -43
- package/Microsoft.ReactNative/Views/ViewControl.h +0 -32
- package/Microsoft.ReactNative/Views/ViewManager.h +0 -33
- package/Microsoft.ReactNative/Views/ViewManagerBase.cpp +0 -487
- package/Microsoft.ReactNative/Views/ViewManagerBase.h +0 -121
- package/Microsoft.ReactNative/Views/ViewPanel.cpp +0 -164
- package/Microsoft.ReactNative/Views/ViewPanel.h +0 -82
- package/Microsoft.ReactNative/Views/ViewViewManager.cpp +0 -507
- package/Microsoft.ReactNative/Views/ViewViewManager.h +0 -52
- package/Microsoft.ReactNative/Views/VirtualTextViewManager.cpp +0 -143
- package/Microsoft.ReactNative/Views/VirtualTextViewManager.h +0 -57
- package/Microsoft.ReactNative/Views/XamlFeatures.cpp +0 -11
- package/Microsoft.ReactNative/Views/XamlFeatures.h +0 -11
- package/Microsoft.ReactNative/Views/cppwinrt/AccessibilityAction.idl +0 -12
- package/Microsoft.ReactNative/Views/cppwinrt/DynamicAutomationPeer.idl +0 -231
- package/Microsoft.ReactNative/Views/cppwinrt/ViewPanel.idl +0 -48
- package/Microsoft.ReactNative/XamlHelper.cpp +0 -78
- package/Microsoft.ReactNative/XamlHelper.h +0 -54
- package/Microsoft.ReactNative/XamlHelper.idl +0 -30
- package/Microsoft.ReactNative/XamlLoadState.cpp +0 -217
- package/Microsoft.ReactNative/XamlLoadState.h +0 -44
- package/Microsoft.ReactNative/XamlView.cpp +0 -59
- package/Microsoft.ReactNative/XamlView.h +0 -58
- package/Microsoft.ReactNative/getLayoutProps.ps1 +0 -5
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Automation.Peers.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Automation.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Controls.Primitives.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Controls.h +0 -13
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Documents.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Hosting.DesktopWindowXamlSource.h +0 -11
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Hosting.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Input.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Markup.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Media.Imaging.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Media.Media3D.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Media.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Navigation.h +0 -10
- package/Microsoft.ReactNative.Cxx/UI.Xaml.Shapes.h +0 -10
- package/Microsoft.ReactNative.Managed/AttributedViewManager.cs +0 -527
- package/Microsoft.ReactNative.Managed/ViewManagerAttributes.cs +0 -91
- package/Microsoft.ReactNative.Managed/ViewManagerEvent.cs +0 -13
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/AccessibilityProps.cpp +0 -344
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/core/DynamicEventPayload.cpp +0 -42
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/YGEnums.h +0 -146
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/algorithm/CalculateLayout.cpp +0 -2435
- package/ReactCommon/TEMP_UntilReactCommonUpdate/yoga/yoga/enums/ExperimentalFeature.h +0 -40
- package/Shared/BatchingMessageQueueThread.h +0 -20
- package/Shared/ChakraRuntimeHolder.cpp +0 -62
- package/Shared/ChakraRuntimeHolder.h +0 -46
- package/Shared/CreateInstance.h +0 -25
- package/Shared/Executors/WebSocketJSExecutor.cpp +0 -294
- package/Shared/Executors/WebSocketJSExecutor.h +0 -123
- package/Shared/Executors/WebSocketJSExecutorFactory.cpp +0 -25
- package/Shared/Hermes/HermesSamplingProfiler.cpp +0 -114
- package/Shared/Hermes/HermesSamplingProfiler.h +0 -26
- package/Shared/JSI/ChakraApi.cpp +0 -436
- package/Shared/JSI/ChakraApi.h +0 -474
- package/Shared/JSI/ChakraJsiRuntime_edgemode.cpp +0 -100
- package/Shared/JSI/ChakraRuntime.cpp +0 -1132
- package/Shared/JSI/ChakraRuntime.h +0 -512
- package/Shared/JSI/ChakraRuntimeArgs.h +0 -45
- package/Shared/JSI/ChakraRuntimeFactory.h +0 -15
- package/Shared/JSI/JSExecutorFactoryDelegate.h +0 -12
- package/Shared/JSI/JSExecutorFactorySettings.cpp +0 -30
- package/Shared/JSI/JSExecutorFactorySettings.h +0 -21
- package/Shared/NativeModuleProvider.h +0 -40
- package/Shared/SystemChakraRuntime.h +0 -38
- package/Shared/Threading/BatchingQueueThread.cpp +0 -128
- package/Shared/Threading/BatchingQueueThread.h +0 -59
- package/Shared/WebSocketJSExecutorFactory.h +0 -27
- package/fmt/TEMP_UntilFmtUpdate/core.h +0 -2925
- package/template/cpp-app/proj/MyApp.sln +0 -166
- package/template/cpp-app/proj/MyApp.vcxproj +0 -176
- package/template/cpp-app/proj/MyApp.vcxproj.filters +0 -62
- package/template/cpp-app/src/App.cpp +0 -93
- package/template/cpp-app/src/App.h +0 -21
- package/template/cpp-app/src/App.idl +0 -3
- package/template/cpp-app/src/AutolinkedNativeModules.g.cpp +0 -13
- package/template/cpp-app/src/AutolinkedNativeModules.g.h +0 -10
- package/template/cpp-app/src/MainPage.cpp +0 -20
- package/template/cpp-app/src/MainPage.h +0 -19
- package/template/cpp-app/src/MainPage.idl +0 -10
- package/template/cpp-app/src/PropertySheet.props +0 -16
- package/template/cpp-app/src/ReactPackageProvider.cpp +0 -15
- package/template/cpp-app/src/ReactPackageProvider.h +0 -13
- package/template/cpp-app/src/pch.cpp +0 -1
- package/template/cpp-app/src/pch.h +0 -24
- package/template/cs-app/proj/MyApp.csproj +0 -162
- package/template/cs-app/proj/MyApp.sln +0 -191
- package/template/cs-app/src/App.xaml.cs +0 -62
- package/template/cs-app/src/AutolinkedNativeModules.g.cs +0 -13
- package/template/cs-app/src/MainPage.xaml.cs +0 -34
- package/template/cs-app/src/Properties/AssemblyInfo.cs +0 -29
- package/template/cs-app/src/Properties/Default.rd.xml +0 -32
- package/template/cs-app/src/ReactPackageProvider.cs +0 -17
- package/template/shared-app/assets/LockScreenLogo.scale-200.png +0 -0
- package/template/shared-app/assets/SplashScreen.scale-200.png +0 -0
- package/template/shared-app/assets/Square150x150Logo.scale-200.png +0 -0
- package/template/shared-app/assets/Square44x44Logo.scale-200.png +0 -0
- package/template/shared-app/assets/Square44x44Logo.targetsize-24_altform-unplated.png +0 -0
- package/template/shared-app/assets/StoreLogo.png +0 -0
- package/template/shared-app/assets/Wide310x150Logo.scale-200.png +0 -0
- package/template/shared-app/proj/ExperimentalFeatures.props +0 -32
- package/template/shared-app/proj/NuGet_Config +0 -19
- package/template/shared-app/src/App.xaml +0 -10
- package/template/shared-app/src/AutolinkedNativeModules.g.props +0 -6
- package/template/shared-app/src/AutolinkedNativeModules.g.targets +0 -6
- package/template/shared-app/src/MainPage.xaml +0 -21
- package/template/shared-app/src/Package.appxmanifest +0 -50
- package/templates/old/uwp-cpp-app/template.config.js +0 -15
- package/templates/old/uwp-cs-app/template.config.js +0 -15
|
@@ -8,17 +8,44 @@
|
|
|
8
8
|
#include <react/renderer/textlayoutmanager/WindowsTextLayoutManager.h>
|
|
9
9
|
|
|
10
10
|
#include <AutoDraw.h>
|
|
11
|
+
#include <Fabric/ReactTaggedView.h>
|
|
12
|
+
#include <Utils/IcuUtils.h>
|
|
11
13
|
#include <Utils/ValueUtils.h>
|
|
12
14
|
#include <react/renderer/components/text/ParagraphShadowNode.h>
|
|
13
15
|
#include <react/renderer/components/text/ParagraphState.h>
|
|
14
16
|
#include <unicode.h>
|
|
15
17
|
#include <winrt/Microsoft.ReactNative.Composition.h>
|
|
16
|
-
#include
|
|
18
|
+
#include <winrt/Microsoft.UI.Input.h>
|
|
19
|
+
#include <winrt/Windows.ApplicationModel.DataTransfer.h>
|
|
17
20
|
#include "CompositionHelpers.h"
|
|
21
|
+
#include "RootComponentView.h"
|
|
18
22
|
#include "TextDrawing.h"
|
|
19
23
|
|
|
20
24
|
namespace winrt::Microsoft::ReactNative::Composition::implementation {
|
|
21
25
|
|
|
26
|
+
// Automatically restores the original DPI of a render target
|
|
27
|
+
struct DpiRestorer {
|
|
28
|
+
ID2D1RenderTarget *renderTarget = nullptr;
|
|
29
|
+
float originalDpiX = 0.0f;
|
|
30
|
+
float originalDpiY = 0.0f;
|
|
31
|
+
|
|
32
|
+
void operator()(ID2D1RenderTarget *) const noexcept {
|
|
33
|
+
if (renderTarget) {
|
|
34
|
+
renderTarget->SetDpi(originalDpiX, originalDpiY);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
inline std::unique_ptr<ID2D1RenderTarget, DpiRestorer>
|
|
40
|
+
MakeDpiGuard(ID2D1RenderTarget &renderTarget, float newDpiX, float newDpiY) noexcept {
|
|
41
|
+
float originalDpiX, originalDpiY;
|
|
42
|
+
renderTarget.GetDpi(&originalDpiX, &originalDpiY);
|
|
43
|
+
renderTarget.SetDpi(newDpiX, newDpiY);
|
|
44
|
+
|
|
45
|
+
return std::unique_ptr<ID2D1RenderTarget, DpiRestorer>(
|
|
46
|
+
&renderTarget, DpiRestorer{&renderTarget, originalDpiX, originalDpiY});
|
|
47
|
+
}
|
|
48
|
+
|
|
22
49
|
ParagraphComponentView::ParagraphComponentView(
|
|
23
50
|
const winrt::Microsoft::ReactNative::Composition::Experimental::ICompositionContext &compContext,
|
|
24
51
|
facebook::react::Tag tag,
|
|
@@ -28,7 +55,8 @@ ParagraphComponentView::ParagraphComponentView(
|
|
|
28
55
|
compContext,
|
|
29
56
|
tag,
|
|
30
57
|
reactContext,
|
|
31
|
-
|
|
58
|
+
// Disable Background (text draws its own) and FocusVisual (selection highlight is the focus indicator)
|
|
59
|
+
ComponentViewFeatures::Default & ~ComponentViewFeatures::Background & ~ComponentViewFeatures::FocusVisual) {}
|
|
32
60
|
|
|
33
61
|
void ParagraphComponentView::MountChildComponentView(
|
|
34
62
|
const winrt::Microsoft::ReactNative::ComponentView &childComponentView,
|
|
@@ -71,6 +99,14 @@ void ParagraphComponentView::updateProps(
|
|
|
71
99
|
m_textLayout = nullptr;
|
|
72
100
|
}
|
|
73
101
|
|
|
102
|
+
// Clear selection if text becomes non-selectable
|
|
103
|
+
if (oldViewProps.isSelectable != newViewProps.isSelectable) {
|
|
104
|
+
if (!newViewProps.isSelectable) {
|
|
105
|
+
ClearSelection();
|
|
106
|
+
}
|
|
107
|
+
m_requireRedraw = true;
|
|
108
|
+
}
|
|
109
|
+
|
|
74
110
|
Super::updateProps(props, oldProps);
|
|
75
111
|
}
|
|
76
112
|
|
|
@@ -131,6 +167,108 @@ void ParagraphComponentView::updateTextAlignment(
|
|
|
131
167
|
m_textLayout = nullptr;
|
|
132
168
|
}
|
|
133
169
|
|
|
170
|
+
bool ParagraphComponentView::IsTextSelectableAtPoint(facebook::react::Point pt) noexcept {
|
|
171
|
+
// paragraph-level selectable prop is enabled
|
|
172
|
+
const auto &props = paragraphProps();
|
|
173
|
+
if (!props.isSelectable) {
|
|
174
|
+
return false;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
// Finds which text fragment was hit
|
|
178
|
+
if (m_attributedStringBox.getValue().getFragments().size() && m_textLayout) {
|
|
179
|
+
BOOL isTrailingHit = false;
|
|
180
|
+
BOOL isInside = false;
|
|
181
|
+
DWRITE_HIT_TEST_METRICS metrics;
|
|
182
|
+
winrt::check_hresult(m_textLayout->HitTestPoint(pt.x, pt.y, &isTrailingHit, &isInside, &metrics));
|
|
183
|
+
|
|
184
|
+
if (isInside) {
|
|
185
|
+
uint32_t textPosition = metrics.textPosition;
|
|
186
|
+
|
|
187
|
+
// Finds which fragment contains this text position
|
|
188
|
+
for (auto fragment : m_attributedStringBox.getValue().getFragments()) {
|
|
189
|
+
if (textPosition < fragment.string.length()) {
|
|
190
|
+
return true;
|
|
191
|
+
}
|
|
192
|
+
textPosition -= static_cast<uint32_t>(fragment.string.length());
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
return false;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
std::optional<int32_t> ParagraphComponentView::GetTextPositionAtPoint(facebook::react::Point pt) noexcept {
|
|
201
|
+
if (!m_textLayout) {
|
|
202
|
+
return std::nullopt;
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
BOOL isTrailingHit = FALSE;
|
|
206
|
+
BOOL isInside = FALSE;
|
|
207
|
+
DWRITE_HIT_TEST_METRICS metrics = {};
|
|
208
|
+
|
|
209
|
+
// Convert screen coordinates to character position
|
|
210
|
+
HRESULT hr = m_textLayout->HitTestPoint(pt.x, pt.y, &isTrailingHit, &isInside, &metrics);
|
|
211
|
+
if (FAILED(hr) || !isInside) {
|
|
212
|
+
return std::nullopt;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
// Calculates the actual character position
|
|
216
|
+
// If isTrailingHit is true, the point is closer to the trailing edge of the character,
|
|
217
|
+
// so we should return the next character position (for cursor positioning)
|
|
218
|
+
return static_cast<int32_t>(metrics.textPosition + isTrailingHit);
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
std::optional<int32_t> ParagraphComponentView::GetClampedTextPosition(facebook::react::Point pt) noexcept {
|
|
222
|
+
if (!m_textLayout) {
|
|
223
|
+
return std::nullopt;
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
const std::wstring utf16Text{facebook::react::WindowsTextLayoutManager::GetTransformedText(m_attributedStringBox)};
|
|
227
|
+
if (utf16Text.empty()) {
|
|
228
|
+
return std::nullopt;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
DWRITE_TEXT_METRICS textMetrics;
|
|
232
|
+
if (FAILED(m_textLayout->GetMetrics(&textMetrics))) {
|
|
233
|
+
return std::nullopt;
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
// Clamp the point to the text bounds for hit testing
|
|
237
|
+
const float clampedX = std::max(0.0f, std::min(pt.x, textMetrics.width));
|
|
238
|
+
const float clampedY = std::max(0.0f, std::min(pt.y, textMetrics.height));
|
|
239
|
+
|
|
240
|
+
BOOL isTrailingHit = FALSE;
|
|
241
|
+
BOOL isInside = FALSE;
|
|
242
|
+
DWRITE_HIT_TEST_METRICS metrics = {};
|
|
243
|
+
|
|
244
|
+
HRESULT hr = m_textLayout->HitTestPoint(clampedX, clampedY, &isTrailingHit, &isInside, &metrics);
|
|
245
|
+
if (FAILED(hr)) {
|
|
246
|
+
return std::nullopt;
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
int32_t result = static_cast<int32_t>(metrics.textPosition);
|
|
250
|
+
if (pt.x > textMetrics.width) {
|
|
251
|
+
// Dragging right - go to end of character
|
|
252
|
+
result = static_cast<int32_t>(metrics.textPosition + metrics.length);
|
|
253
|
+
} else if (pt.x < 0) {
|
|
254
|
+
// Dragging left - go to start of character
|
|
255
|
+
result = static_cast<int32_t>(metrics.textPosition);
|
|
256
|
+
} else if (isTrailingHit) {
|
|
257
|
+
// Inside bounds, trailing hit
|
|
258
|
+
result += 1;
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
if (pt.y > textMetrics.height) {
|
|
262
|
+
// Dragging below - select to end of text
|
|
263
|
+
result = static_cast<int32_t>(utf16Text.length());
|
|
264
|
+
} else if (pt.y < 0) {
|
|
265
|
+
// Dragging above - select to start of text
|
|
266
|
+
result = 0;
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
return result;
|
|
270
|
+
}
|
|
271
|
+
|
|
134
272
|
void ParagraphComponentView::OnRenderingDeviceLost() noexcept {
|
|
135
273
|
DrawText();
|
|
136
274
|
}
|
|
@@ -263,6 +401,76 @@ void ParagraphComponentView::onThemeChanged() noexcept {
|
|
|
263
401
|
}
|
|
264
402
|
|
|
265
403
|
// Renders the text into our composition surface
|
|
404
|
+
void ParagraphComponentView::DrawSelectionHighlight(
|
|
405
|
+
ID2D1RenderTarget &renderTarget,
|
|
406
|
+
float offsetX,
|
|
407
|
+
float offsetY,
|
|
408
|
+
float pointScaleFactor) noexcept {
|
|
409
|
+
if (!m_selectionStart || !m_selectionEnd || !m_textLayout) {
|
|
410
|
+
return;
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
// During drag, selection may not be normalized yet, using min/max for rendering
|
|
414
|
+
const int32_t selStart = std::min(*m_selectionStart, *m_selectionEnd);
|
|
415
|
+
const int32_t selEnd = std::max(*m_selectionStart, *m_selectionEnd);
|
|
416
|
+
if (selEnd <= selStart) {
|
|
417
|
+
return;
|
|
418
|
+
}
|
|
419
|
+
|
|
420
|
+
// Scale offset to match text layout coordinates (same as RenderText)
|
|
421
|
+
const float scaledOffsetX = offsetX / pointScaleFactor;
|
|
422
|
+
const float scaledOffsetY = offsetY / pointScaleFactor;
|
|
423
|
+
|
|
424
|
+
// Set DPI to match text rendering
|
|
425
|
+
const float dpi = pointScaleFactor * 96.0f;
|
|
426
|
+
std::unique_ptr<ID2D1RenderTarget, DpiRestorer> dpiGuard = MakeDpiGuard(renderTarget, dpi, dpi);
|
|
427
|
+
|
|
428
|
+
// Get the hit test metrics for the selected text range
|
|
429
|
+
UINT32 actualCount = 0;
|
|
430
|
+
HRESULT hr = m_textLayout->HitTestTextRange(
|
|
431
|
+
static_cast<UINT32>(selStart),
|
|
432
|
+
static_cast<UINT32>(selEnd - selStart),
|
|
433
|
+
scaledOffsetX,
|
|
434
|
+
scaledOffsetY,
|
|
435
|
+
nullptr,
|
|
436
|
+
0,
|
|
437
|
+
&actualCount);
|
|
438
|
+
|
|
439
|
+
if (actualCount == 0) {
|
|
440
|
+
return;
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
std::vector<DWRITE_HIT_TEST_METRICS> hitTestMetrics(actualCount);
|
|
444
|
+
hr = m_textLayout->HitTestTextRange(
|
|
445
|
+
static_cast<UINT32>(selStart),
|
|
446
|
+
static_cast<UINT32>(selEnd - selStart),
|
|
447
|
+
scaledOffsetX,
|
|
448
|
+
scaledOffsetY,
|
|
449
|
+
hitTestMetrics.data(),
|
|
450
|
+
actualCount,
|
|
451
|
+
&actualCount);
|
|
452
|
+
|
|
453
|
+
if (FAILED(hr)) {
|
|
454
|
+
return;
|
|
455
|
+
}
|
|
456
|
+
|
|
457
|
+
// TODO: use prop selectionColor if provided
|
|
458
|
+
winrt::com_ptr<ID2D1SolidColorBrush> selectionBrush;
|
|
459
|
+
const D2D1_COLOR_F selectionColor = theme()->D2DPlatformColor("Highlight@40");
|
|
460
|
+
hr = renderTarget.CreateSolidColorBrush(selectionColor, selectionBrush.put());
|
|
461
|
+
|
|
462
|
+
if (FAILED(hr)) {
|
|
463
|
+
return;
|
|
464
|
+
}
|
|
465
|
+
|
|
466
|
+
// Draw rectangles for each hit test metric
|
|
467
|
+
for (UINT32 i = 0; i < actualCount; i++) {
|
|
468
|
+
const auto &metric = hitTestMetrics[i];
|
|
469
|
+
const D2D1_RECT_F rect = {metric.left, metric.top, metric.left + metric.width, metric.top + metric.height};
|
|
470
|
+
renderTarget.FillRectangle(&rect, selectionBrush.get());
|
|
471
|
+
}
|
|
472
|
+
}
|
|
473
|
+
|
|
266
474
|
void ParagraphComponentView::DrawText() noexcept {
|
|
267
475
|
if (!m_drawingSurface || theme()->IsEmpty())
|
|
268
476
|
return;
|
|
@@ -281,13 +489,20 @@ void ParagraphComponentView::DrawText() noexcept {
|
|
|
281
489
|
viewProps()->backgroundColor ? theme()->D2DColor(*viewProps()->backgroundColor)
|
|
282
490
|
: D2D1::ColorF(D2D1::ColorF::Black, 0.0f));
|
|
283
491
|
const auto &props = paragraphProps();
|
|
492
|
+
|
|
493
|
+
// Calculate text offset
|
|
494
|
+
const float textOffsetX = static_cast<float>(offset.x) + m_layoutMetrics.contentInsets.left;
|
|
495
|
+
const float textOffsetY = static_cast<float>(offset.y) + m_layoutMetrics.contentInsets.top;
|
|
496
|
+
|
|
497
|
+
// Draw selection highlight behind text
|
|
498
|
+
DrawSelectionHighlight(*d2dDeviceContext, textOffsetX, textOffsetY, m_layoutMetrics.pointScaleFactor);
|
|
499
|
+
|
|
284
500
|
RenderText(
|
|
285
501
|
*d2dDeviceContext,
|
|
286
502
|
*m_textLayout,
|
|
287
503
|
m_attributedStringBox.getValue(),
|
|
288
504
|
props.textAttributes,
|
|
289
|
-
{
|
|
290
|
-
static_cast<float>(offset.y) + m_layoutMetrics.contentInsets.top},
|
|
505
|
+
{textOffsetX, textOffsetY},
|
|
291
506
|
m_layoutMetrics.pointScaleFactor,
|
|
292
507
|
*theme());
|
|
293
508
|
|
|
@@ -299,6 +514,324 @@ void ParagraphComponentView::DrawText() noexcept {
|
|
|
299
514
|
}
|
|
300
515
|
}
|
|
301
516
|
|
|
517
|
+
void ParagraphComponentView::ClearSelection() noexcept {
|
|
518
|
+
const bool hadSelection = (m_selectionStart || m_selectionEnd || m_isSelecting);
|
|
519
|
+
m_selectionStart = std::nullopt;
|
|
520
|
+
m_selectionEnd = std::nullopt;
|
|
521
|
+
m_isSelecting = false;
|
|
522
|
+
if (hadSelection) {
|
|
523
|
+
// Clears selection highlight
|
|
524
|
+
DrawText();
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
|
|
528
|
+
void ParagraphComponentView::OnPointerPressed(
|
|
529
|
+
const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept {
|
|
530
|
+
// Only handle selection if text is selectable
|
|
531
|
+
const auto &props = paragraphProps();
|
|
532
|
+
if (!props.isSelectable) {
|
|
533
|
+
Super::OnPointerPressed(args);
|
|
534
|
+
return;
|
|
535
|
+
}
|
|
536
|
+
|
|
537
|
+
auto pp = args.GetCurrentPoint(-1);
|
|
538
|
+
|
|
539
|
+
// Ignores right-click
|
|
540
|
+
if (pp.Properties().PointerUpdateKind() ==
|
|
541
|
+
winrt::Microsoft::ReactNative::Composition::Input::PointerUpdateKind::RightButtonPressed) {
|
|
542
|
+
args.Handled(true);
|
|
543
|
+
return;
|
|
544
|
+
}
|
|
545
|
+
|
|
546
|
+
auto position = pp.Position();
|
|
547
|
+
|
|
548
|
+
facebook::react::Point localPt{
|
|
549
|
+
position.X - m_layoutMetrics.frame.origin.x, position.Y - m_layoutMetrics.frame.origin.y};
|
|
550
|
+
|
|
551
|
+
std::optional<int32_t> charPosition = GetTextPositionAtPoint(localPt);
|
|
552
|
+
|
|
553
|
+
if (charPosition) {
|
|
554
|
+
if (auto root = rootComponentView()) {
|
|
555
|
+
root->ClearCurrentTextSelection();
|
|
556
|
+
}
|
|
557
|
+
|
|
558
|
+
// Check for double-click
|
|
559
|
+
auto now = std::chrono::steady_clock::now();
|
|
560
|
+
auto timeSinceLastClick = std::chrono::duration_cast<std::chrono::milliseconds>(now - m_lastClickTime);
|
|
561
|
+
const UINT doubleClickTime = GetDoubleClickTime();
|
|
562
|
+
const bool isDoubleClick = (timeSinceLastClick.count() < static_cast<long long>(doubleClickTime)) &&
|
|
563
|
+
m_lastClickPosition && (std::abs(*charPosition - *m_lastClickPosition) <= 1);
|
|
564
|
+
|
|
565
|
+
// Update last click tracking
|
|
566
|
+
m_lastClickTime = now;
|
|
567
|
+
m_lastClickPosition = charPosition;
|
|
568
|
+
|
|
569
|
+
if (isDoubleClick) {
|
|
570
|
+
SelectWordAtPosition(*charPosition);
|
|
571
|
+
m_isSelecting = false;
|
|
572
|
+
} else {
|
|
573
|
+
// Single-click: start drag selection
|
|
574
|
+
m_selectionStart = charPosition;
|
|
575
|
+
m_selectionEnd = charPosition;
|
|
576
|
+
m_isSelecting = true;
|
|
577
|
+
|
|
578
|
+
// Tracks selection even when the mouse moves outside the component bounds
|
|
579
|
+
CapturePointer(args.Pointer());
|
|
580
|
+
}
|
|
581
|
+
|
|
582
|
+
if (auto root = rootComponentView()) {
|
|
583
|
+
root->SetViewWithTextSelection(*get_strong());
|
|
584
|
+
}
|
|
585
|
+
|
|
586
|
+
// Focuses so we receive onLostFocus when clicking elsewhere
|
|
587
|
+
if (auto root = rootComponentView()) {
|
|
588
|
+
root->TrySetFocusedComponent(*get_strong(), winrt::Microsoft::ReactNative::FocusNavigationDirection::None);
|
|
589
|
+
}
|
|
590
|
+
|
|
591
|
+
args.Handled(true);
|
|
592
|
+
} else {
|
|
593
|
+
ClearSelection();
|
|
594
|
+
m_lastClickPosition = std::nullopt;
|
|
595
|
+
Super::OnPointerPressed(args);
|
|
596
|
+
}
|
|
597
|
+
}
|
|
598
|
+
|
|
599
|
+
void ParagraphComponentView::OnPointerMoved(
|
|
600
|
+
const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept {
|
|
601
|
+
// Only track movement if we're actively selecting
|
|
602
|
+
if (!m_isSelecting) {
|
|
603
|
+
Super::OnPointerMoved(args);
|
|
604
|
+
return;
|
|
605
|
+
}
|
|
606
|
+
|
|
607
|
+
auto pp = args.GetCurrentPoint(static_cast<int32_t>(Tag()));
|
|
608
|
+
auto position = pp.Position();
|
|
609
|
+
|
|
610
|
+
facebook::react::Point localPt{position.X, position.Y};
|
|
611
|
+
std::optional<int32_t> charPosition = GetClampedTextPosition(localPt);
|
|
612
|
+
|
|
613
|
+
if (charPosition && charPosition != m_selectionEnd) {
|
|
614
|
+
m_selectionEnd = charPosition;
|
|
615
|
+
DrawText();
|
|
616
|
+
args.Handled(true);
|
|
617
|
+
}
|
|
618
|
+
}
|
|
619
|
+
|
|
620
|
+
void ParagraphComponentView::OnPointerReleased(
|
|
621
|
+
const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept {
|
|
622
|
+
// Check for right-click to show context menu
|
|
623
|
+
auto pp = args.GetCurrentPoint(-1);
|
|
624
|
+
if (pp.Properties().PointerUpdateKind() ==
|
|
625
|
+
winrt::Microsoft::ReactNative::Composition::Input::PointerUpdateKind::RightButtonReleased) {
|
|
626
|
+
const auto &props = paragraphProps();
|
|
627
|
+
if (props.isSelectable) {
|
|
628
|
+
ShowContextMenu();
|
|
629
|
+
args.Handled(true);
|
|
630
|
+
return;
|
|
631
|
+
}
|
|
632
|
+
}
|
|
633
|
+
|
|
634
|
+
if (!m_isSelecting) {
|
|
635
|
+
Super::OnPointerReleased(args);
|
|
636
|
+
return;
|
|
637
|
+
}
|
|
638
|
+
|
|
639
|
+
m_isSelecting = false;
|
|
640
|
+
|
|
641
|
+
ReleasePointerCapture(args.Pointer());
|
|
642
|
+
|
|
643
|
+
if (!m_selectionStart || !m_selectionEnd || *m_selectionStart == *m_selectionEnd) {
|
|
644
|
+
m_selectionStart = std::nullopt;
|
|
645
|
+
m_selectionEnd = std::nullopt;
|
|
646
|
+
} else {
|
|
647
|
+
SetSelection(*m_selectionStart, *m_selectionEnd);
|
|
648
|
+
}
|
|
649
|
+
|
|
650
|
+
args.Handled(true);
|
|
651
|
+
}
|
|
652
|
+
|
|
653
|
+
void ParagraphComponentView::onLostFocus(
|
|
654
|
+
const winrt::Microsoft::ReactNative::Composition::Input::RoutedEventArgs &args) noexcept {
|
|
655
|
+
ClearSelection();
|
|
656
|
+
|
|
657
|
+
Super::onLostFocus(args);
|
|
658
|
+
}
|
|
659
|
+
|
|
660
|
+
void ParagraphComponentView::OnPointerCaptureLost() noexcept {
|
|
661
|
+
// Pointer capture was lost stop any active selection drag
|
|
662
|
+
if (m_isSelecting) {
|
|
663
|
+
m_isSelecting = false;
|
|
664
|
+
|
|
665
|
+
if (!m_selectionStart || !m_selectionEnd || *m_selectionStart == *m_selectionEnd) {
|
|
666
|
+
m_selectionStart = std::nullopt;
|
|
667
|
+
m_selectionEnd = std::nullopt;
|
|
668
|
+
} else {
|
|
669
|
+
SetSelection(*m_selectionStart, *m_selectionEnd);
|
|
670
|
+
}
|
|
671
|
+
}
|
|
672
|
+
|
|
673
|
+
Super::OnPointerCaptureLost();
|
|
674
|
+
}
|
|
675
|
+
|
|
676
|
+
std::string ParagraphComponentView::GetSelectedText() const noexcept {
|
|
677
|
+
if (!m_selectionStart || !m_selectionEnd) {
|
|
678
|
+
return "";
|
|
679
|
+
}
|
|
680
|
+
|
|
681
|
+
const int32_t selStart = std::min(*m_selectionStart, *m_selectionEnd);
|
|
682
|
+
const int32_t selEnd = std::max(*m_selectionStart, *m_selectionEnd);
|
|
683
|
+
|
|
684
|
+
if (selEnd <= selStart) {
|
|
685
|
+
return "";
|
|
686
|
+
}
|
|
687
|
+
|
|
688
|
+
const std::wstring utf16Text{facebook::react::WindowsTextLayoutManager::GetTransformedText(m_attributedStringBox)};
|
|
689
|
+
|
|
690
|
+
if (selStart >= static_cast<int32_t>(utf16Text.length())) {
|
|
691
|
+
return "";
|
|
692
|
+
}
|
|
693
|
+
|
|
694
|
+
const int32_t clampedEnd = std::min(selEnd, static_cast<int32_t>(utf16Text.length()));
|
|
695
|
+
const std::wstring selectedUtf16 =
|
|
696
|
+
utf16Text.substr(static_cast<size_t>(selStart), static_cast<size_t>(clampedEnd - selStart));
|
|
697
|
+
return ::Microsoft::Common::Unicode::Utf16ToUtf8(selectedUtf16);
|
|
698
|
+
}
|
|
699
|
+
|
|
700
|
+
void ParagraphComponentView::CopySelectionToClipboard() noexcept {
|
|
701
|
+
const std::string selectedText = GetSelectedText();
|
|
702
|
+
if (selectedText.empty()) {
|
|
703
|
+
return;
|
|
704
|
+
}
|
|
705
|
+
|
|
706
|
+
// Convert UTF-8 to wide string for Windows clipboard
|
|
707
|
+
const std::wstring wideText = ::Microsoft::Common::Unicode::Utf8ToUtf16(selectedText);
|
|
708
|
+
|
|
709
|
+
winrt::Windows::ApplicationModel::DataTransfer::DataPackage dataPackage;
|
|
710
|
+
dataPackage.SetText(wideText);
|
|
711
|
+
winrt::Windows::ApplicationModel::DataTransfer::Clipboard::SetContent(dataPackage);
|
|
712
|
+
}
|
|
713
|
+
|
|
714
|
+
void ParagraphComponentView::SelectWordAtPosition(int32_t charPosition) noexcept {
|
|
715
|
+
const std::wstring utf16Text{facebook::react::WindowsTextLayoutManager::GetTransformedText(m_attributedStringBox)};
|
|
716
|
+
const int32_t textLength = static_cast<int32_t>(utf16Text.length());
|
|
717
|
+
|
|
718
|
+
if (utf16Text.empty() || charPosition < 0 || charPosition >= textLength) {
|
|
719
|
+
return;
|
|
720
|
+
}
|
|
721
|
+
|
|
722
|
+
int32_t wordStart = charPosition;
|
|
723
|
+
int32_t wordEnd = charPosition;
|
|
724
|
+
|
|
725
|
+
::Microsoft::ReactNative::IcuUtils::WordBreakIterator wordBreaker(utf16Text.c_str(), textLength);
|
|
726
|
+
const bool icuSuccess = wordBreaker.IsValid() && wordBreaker.GetWordBoundaries(charPosition, wordStart, wordEnd);
|
|
727
|
+
|
|
728
|
+
if (!icuSuccess) {
|
|
729
|
+
wordStart = charPosition;
|
|
730
|
+
wordEnd = charPosition;
|
|
731
|
+
|
|
732
|
+
while (wordStart > 0) {
|
|
733
|
+
int32_t prevPos = ::Microsoft::ReactNative::IcuUtils::MoveToPreviousCodePoint(utf16Text.c_str(), wordStart);
|
|
734
|
+
::Microsoft::ReactNative::IcuUtils::UChar32 prevCp =
|
|
735
|
+
::Microsoft::ReactNative::IcuUtils::GetCodePointAt(utf16Text.c_str(), textLength, prevPos);
|
|
736
|
+
if (!::Microsoft::ReactNative::IcuUtils::IsAlphanumeric(prevCp)) {
|
|
737
|
+
break;
|
|
738
|
+
}
|
|
739
|
+
wordStart = prevPos;
|
|
740
|
+
}
|
|
741
|
+
|
|
742
|
+
while (wordEnd < textLength) {
|
|
743
|
+
::Microsoft::ReactNative::IcuUtils::UChar32 cp =
|
|
744
|
+
::Microsoft::ReactNative::IcuUtils::GetCodePointAt(utf16Text.c_str(), textLength, wordEnd);
|
|
745
|
+
if (!::Microsoft::ReactNative::IcuUtils::IsAlphanumeric(cp)) {
|
|
746
|
+
break;
|
|
747
|
+
}
|
|
748
|
+
wordEnd = ::Microsoft::ReactNative::IcuUtils::MoveToNextCodePoint(utf16Text.c_str(), textLength, wordEnd);
|
|
749
|
+
}
|
|
750
|
+
}
|
|
751
|
+
|
|
752
|
+
if (wordEnd > wordStart) {
|
|
753
|
+
SetSelection(wordStart, wordEnd);
|
|
754
|
+
DrawText();
|
|
755
|
+
}
|
|
756
|
+
}
|
|
757
|
+
|
|
758
|
+
void ParagraphComponentView::SetSelection(int32_t start, int32_t end) noexcept {
|
|
759
|
+
m_selectionStart = std::min(start, end);
|
|
760
|
+
m_selectionEnd = std::max(start, end);
|
|
761
|
+
}
|
|
762
|
+
|
|
763
|
+
void ParagraphComponentView::ShowContextMenu() noexcept {
|
|
764
|
+
HMENU menu = CreatePopupMenu();
|
|
765
|
+
if (!menu) {
|
|
766
|
+
return;
|
|
767
|
+
}
|
|
768
|
+
|
|
769
|
+
const bool hasSelection = (m_selectionStart && m_selectionEnd && *m_selectionStart != *m_selectionEnd);
|
|
770
|
+
const std::wstring utf16Text{facebook::react::WindowsTextLayoutManager::GetTransformedText(m_attributedStringBox)};
|
|
771
|
+
const bool hasText = !utf16Text.empty();
|
|
772
|
+
|
|
773
|
+
// Add menu items (1 = Copy, 2 = Select All)
|
|
774
|
+
AppendMenuW(menu, MF_STRING | (hasSelection ? 0 : MF_GRAYED), 1, L"Copy");
|
|
775
|
+
AppendMenuW(menu, MF_STRING | (hasText ? 0 : MF_GRAYED), 2, L"Select All");
|
|
776
|
+
|
|
777
|
+
// Get cursor position for menu placement
|
|
778
|
+
POINT cursorPos;
|
|
779
|
+
GetCursorPos(&cursorPos);
|
|
780
|
+
|
|
781
|
+
const HWND hwnd = GetActiveWindow();
|
|
782
|
+
|
|
783
|
+
const int cmd = TrackPopupMenu(
|
|
784
|
+
menu, TPM_LEFTALIGN | TPM_TOPALIGN | TPM_RETURNCMD | TPM_NONOTIFY, cursorPos.x, cursorPos.y, 0, hwnd, NULL);
|
|
785
|
+
|
|
786
|
+
if (cmd == 1) {
|
|
787
|
+
// Copy
|
|
788
|
+
CopySelectionToClipboard();
|
|
789
|
+
} else if (cmd == 2) {
|
|
790
|
+
SetSelection(0, static_cast<int32_t>(utf16Text.length()));
|
|
791
|
+
DrawText();
|
|
792
|
+
}
|
|
793
|
+
|
|
794
|
+
DestroyMenu(menu);
|
|
795
|
+
}
|
|
796
|
+
|
|
797
|
+
void ParagraphComponentView::OnKeyDown(
|
|
798
|
+
const winrt::Microsoft::ReactNative::Composition::Input::KeyRoutedEventArgs &args) noexcept {
|
|
799
|
+
const bool isCtrlDown =
|
|
800
|
+
(args.KeyboardSource().GetKeyState(winrt::Windows::System::VirtualKey::Control) &
|
|
801
|
+
winrt::Microsoft::UI::Input::VirtualKeyStates::Down) == winrt::Microsoft::UI::Input::VirtualKeyStates::Down;
|
|
802
|
+
|
|
803
|
+
// Handle Ctrl+C for copy
|
|
804
|
+
if (isCtrlDown && args.Key() == winrt::Windows::System::VirtualKey::C) {
|
|
805
|
+
if (m_selectionStart && m_selectionEnd && *m_selectionStart != *m_selectionEnd) {
|
|
806
|
+
CopySelectionToClipboard();
|
|
807
|
+
args.Handled(true);
|
|
808
|
+
return;
|
|
809
|
+
}
|
|
810
|
+
}
|
|
811
|
+
|
|
812
|
+
// Handle Ctrl+A for select all
|
|
813
|
+
if (isCtrlDown && args.Key() == winrt::Windows::System::VirtualKey::A) {
|
|
814
|
+
const std::wstring utf16Text{facebook::react::WindowsTextLayoutManager::GetTransformedText(m_attributedStringBox)};
|
|
815
|
+
if (!utf16Text.empty()) {
|
|
816
|
+
if (auto root = rootComponentView()) {
|
|
817
|
+
root->ClearCurrentTextSelection();
|
|
818
|
+
}
|
|
819
|
+
|
|
820
|
+
SetSelection(0, static_cast<int32_t>(utf16Text.length()));
|
|
821
|
+
|
|
822
|
+
if (auto root = rootComponentView()) {
|
|
823
|
+
root->SetViewWithTextSelection(*get_strong());
|
|
824
|
+
}
|
|
825
|
+
|
|
826
|
+
DrawText();
|
|
827
|
+
args.Handled(true);
|
|
828
|
+
return;
|
|
829
|
+
}
|
|
830
|
+
}
|
|
831
|
+
|
|
832
|
+
Super::OnKeyDown(args);
|
|
833
|
+
}
|
|
834
|
+
|
|
302
835
|
std::string ParagraphComponentView::DefaultControlType() const noexcept {
|
|
303
836
|
return "text";
|
|
304
837
|
}
|
|
@@ -307,6 +840,19 @@ std::string ParagraphComponentView::DefaultAccessibleName() const noexcept {
|
|
|
307
840
|
return m_attributedStringBox.getValue().getString();
|
|
308
841
|
}
|
|
309
842
|
|
|
843
|
+
bool ParagraphComponentView::focusable() const noexcept {
|
|
844
|
+
// Text is focusable when it's selectable or when explicitly marked as focusable via props
|
|
845
|
+
return paragraphProps().isSelectable || viewProps()->focusable;
|
|
846
|
+
}
|
|
847
|
+
|
|
848
|
+
std::pair<facebook::react::Cursor, HCURSOR> ParagraphComponentView::cursor() const noexcept {
|
|
849
|
+
// Returns I-beam cursor for selectable text
|
|
850
|
+
if (paragraphProps().isSelectable) {
|
|
851
|
+
return {facebook::react::Cursor::Text, nullptr};
|
|
852
|
+
}
|
|
853
|
+
return Super::cursor();
|
|
854
|
+
}
|
|
855
|
+
|
|
310
856
|
winrt::Microsoft::ReactNative::ComponentView ParagraphComponentView::Create(
|
|
311
857
|
const winrt::Microsoft::ReactNative::Composition::Experimental::ICompositionContext &compContext,
|
|
312
858
|
facebook::react::Tag tag,
|
|
@@ -12,6 +12,7 @@
|
|
|
12
12
|
#include <react/renderer/components/text/ParagraphProps.h>
|
|
13
13
|
#include <windows.ui.composition.interop.h>
|
|
14
14
|
#include <winrt/Windows.UI.Composition.h>
|
|
15
|
+
#include <chrono>
|
|
15
16
|
#include "CompositionHelpers.h"
|
|
16
17
|
#include "CompositionViewComponentView.h"
|
|
17
18
|
|
|
@@ -48,6 +49,28 @@ struct ParagraphComponentView : ParagraphComponentViewT<ParagraphComponentView,
|
|
|
48
49
|
static facebook::react::SharedViewProps defaultProps() noexcept;
|
|
49
50
|
const facebook::react::ParagraphProps ¶graphProps() const noexcept;
|
|
50
51
|
|
|
52
|
+
// Returns true when text is selectable
|
|
53
|
+
bool focusable() const noexcept override;
|
|
54
|
+
|
|
55
|
+
// Returns I-beam cursor for selectable text
|
|
56
|
+
std::pair<facebook::react::Cursor, HCURSOR> cursor() const noexcept override;
|
|
57
|
+
|
|
58
|
+
// Called when losing focus, when another text starts selection, or when clicking outside text bounds.
|
|
59
|
+
void ClearSelection() noexcept;
|
|
60
|
+
|
|
61
|
+
// Text selection pointer event handlers
|
|
62
|
+
void OnPointerPressed(
|
|
63
|
+
const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept override;
|
|
64
|
+
void OnPointerMoved(
|
|
65
|
+
const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept override;
|
|
66
|
+
void OnPointerReleased(
|
|
67
|
+
const winrt::Microsoft::ReactNative::Composition::Input::PointerRoutedEventArgs &args) noexcept override;
|
|
68
|
+
void OnPointerCaptureLost() noexcept override;
|
|
69
|
+
void onLostFocus(const winrt::Microsoft::ReactNative::Composition::Input::RoutedEventArgs &args) noexcept override;
|
|
70
|
+
|
|
71
|
+
// Keyboard event handler for copy
|
|
72
|
+
void OnKeyDown(const winrt::Microsoft::ReactNative::Composition::Input::KeyRoutedEventArgs &args) noexcept override;
|
|
73
|
+
|
|
51
74
|
ParagraphComponentView(
|
|
52
75
|
const winrt::Microsoft::ReactNative::Composition::Experimental::ICompositionContext &compContext,
|
|
53
76
|
facebook::react::Tag tag,
|
|
@@ -56,7 +79,28 @@ struct ParagraphComponentView : ParagraphComponentViewT<ParagraphComponentView,
|
|
|
56
79
|
private:
|
|
57
80
|
void updateVisualBrush() noexcept;
|
|
58
81
|
void DrawText() noexcept;
|
|
82
|
+
void DrawSelectionHighlight(
|
|
83
|
+
ID2D1RenderTarget &renderTarget,
|
|
84
|
+
float offsetX,
|
|
85
|
+
float offsetY,
|
|
86
|
+
float pointScaleFactor) noexcept;
|
|
59
87
|
void updateTextAlignment(const std::optional<facebook::react::TextAlignment> &fbAlignment) noexcept;
|
|
88
|
+
bool IsTextSelectableAtPoint(facebook::react::Point pt) noexcept;
|
|
89
|
+
std::optional<int32_t> GetTextPositionAtPoint(facebook::react::Point pt) noexcept;
|
|
90
|
+
std::optional<int32_t> GetClampedTextPosition(facebook::react::Point pt) noexcept;
|
|
91
|
+
std::string GetSelectedText() const noexcept;
|
|
92
|
+
|
|
93
|
+
// Copies currently selected text to the system clipboard
|
|
94
|
+
void CopySelectionToClipboard() noexcept;
|
|
95
|
+
|
|
96
|
+
// Selects the word at the given character position
|
|
97
|
+
void SelectWordAtPosition(int32_t charPosition) noexcept;
|
|
98
|
+
|
|
99
|
+
// Shows a context menu with Copy/Select All options on right-click
|
|
100
|
+
void ShowContextMenu() noexcept;
|
|
101
|
+
|
|
102
|
+
// m_selectionStart <= m_selectionEnd
|
|
103
|
+
void SetSelection(int32_t start, int32_t end) noexcept;
|
|
60
104
|
|
|
61
105
|
winrt::com_ptr<::IDWriteTextLayout> m_textLayout;
|
|
62
106
|
facebook::react::AttributedStringBox m_attributedStringBox;
|
|
@@ -64,6 +108,14 @@ struct ParagraphComponentView : ParagraphComponentViewT<ParagraphComponentView,
|
|
|
64
108
|
|
|
65
109
|
bool m_requireRedraw{true};
|
|
66
110
|
winrt::Microsoft::ReactNative::Composition::Experimental::IDrawingSurfaceBrush m_drawingSurface;
|
|
111
|
+
|
|
112
|
+
std::optional<int32_t> m_selectionStart;
|
|
113
|
+
std::optional<int32_t> m_selectionEnd;
|
|
114
|
+
bool m_isSelecting{false};
|
|
115
|
+
|
|
116
|
+
// Double-click detection
|
|
117
|
+
std::chrono::steady_clock::time_point m_lastClickTime{};
|
|
118
|
+
std::optional<int32_t> m_lastClickPosition;
|
|
67
119
|
};
|
|
68
120
|
|
|
69
121
|
} // namespace winrt::Microsoft::ReactNative::Composition::implementation
|