react-native-windows 0.71.10 → 0.72.0-preview.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.flowconfig +13 -3
- package/Directory.Build.props +19 -19
- package/Libraries/ActionSheetIOS/ActionSheetIOS.js +1 -1
- package/Libraries/Alert/Alert.d.ts +4 -4
- package/Libraries/Alert/Alert.windows.js +2 -0
- package/Libraries/Alert/NativeDialogManagerWindows.js +1 -0
- package/Libraries/Animated/Animated.d.ts +17 -6
- package/Libraries/Animated/NativeAnimatedHelper.js +18 -6
- package/Libraries/Animated/bezier.js +1 -1
- package/Libraries/Animated/components/AnimatedFlatList.js +8 -3
- package/Libraries/Animated/components/AnimatedScrollView.js +4 -1
- package/Libraries/Animated/components/AnimatedSectionList.js +12 -3
- package/Libraries/Animated/createAnimatedComponent.js +26 -239
- package/Libraries/Animated/nodes/AnimatedColor.js +47 -80
- package/Libraries/Animated/nodes/AnimatedInterpolation.js +167 -121
- package/Libraries/Animated/nodes/AnimatedNode.js +3 -5
- package/Libraries/Animated/nodes/AnimatedProps.js +7 -6
- package/Libraries/Animated/nodes/AnimatedStyle.js +42 -8
- package/Libraries/Animated/nodes/AnimatedTransform.js +1 -1
- package/Libraries/Animated/nodes/AnimatedValue.js +8 -12
- package/Libraries/Animated/nodes/AnimatedWithChildren.js +1 -1
- package/Libraries/Animated/useAnimatedProps.js +7 -10
- package/Libraries/AppTheme/AppTheme.js +1 -0
- package/Libraries/AppTheme/AppThemeTypes.d.ts +1 -1
- package/Libraries/BatchedBridge/MessageQueue.js +2 -1
- package/Libraries/BatchedBridge/NativeModules.d.ts +1 -1
- package/Libraries/BatchedBridge/NativeModules.js +1 -0
- package/Libraries/Blob/Blob.js +4 -0
- package/Libraries/Blob/FileReader.js +30 -2
- package/Libraries/Blob/URL.js +3 -1
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +2 -2
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +2 -3
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.windows.js +2 -3
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +6 -4
- package/Libraries/Components/Button.js +3 -2
- package/Libraries/Components/Button.windows.js +3 -2
- package/Libraries/Components/Clipboard/Clipboard.js +1 -1
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +4 -0
- package/Libraries/Components/Flyout/Flyout.d.ts +55 -19
- package/Libraries/Components/Flyout/Flyout.js +110 -51
- package/Libraries/Components/Flyout/FlyoutNativeComponent.js +45 -0
- package/Libraries/Components/Glyph/Glyph.d.ts +29 -12
- package/Libraries/Components/Glyph/Glyph.js +43 -30
- package/Libraries/Components/Glyph/GlyphNativeComponent.js +31 -0
- package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +1 -0
- package/Libraries/Components/Keyboard/KeyboardExtProps.d.ts +2 -2
- package/Libraries/Components/Keyboard/KeyboardExtProps.js.map +1 -1
- package/Libraries/Components/Popup/Popup.d.ts +41 -19
- package/Libraries/Components/Popup/Popup.js +86 -52
- package/Libraries/Components/Popup/PopupNativeComponent.js +49 -0
- package/Libraries/Components/Pressable/Pressable.d.ts +1 -1
- package/Libraries/Components/Pressable/Pressable.js +1 -1
- package/Libraries/Components/RefreshControl/RefreshControl.js +1 -0
- package/Libraries/Components/RefreshControl/RefreshControl.windows.js +1 -0
- package/Libraries/Components/SafeAreaView/SafeAreaView.js +1 -2
- package/Libraries/Components/SafeAreaView/SafeAreaView.windows.js +1 -2
- package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +12 -6
- package/Libraries/Components/ScrollView/ScrollView.d.ts +2 -2
- package/Libraries/Components/ScrollView/ScrollView.js +149 -91
- package/Libraries/Components/ScrollView/ScrollView.windows.js +1939 -0
- package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +16 -6
- package/Libraries/Components/ScrollView/ScrollViewNativeComponent.windows.js +175 -0
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +5 -7
- package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +1 -1
- package/Libraries/Components/StatusBar/StatusBar.js +3 -0
- package/Libraries/Components/Switch/Switch.js +3 -1
- package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +21 -11
- package/Libraries/Components/TextInput/InputAccessoryView.d.ts +1 -1
- package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +11 -5
- package/Libraries/Components/TextInput/TextInput.d.ts +15 -5
- package/Libraries/Components/TextInput/TextInput.flow.js +1 -1
- package/Libraries/Components/TextInput/TextInput.js +130 -103
- package/Libraries/Components/TextInput/TextInput.windows.js +152 -115
- package/Libraries/Components/TextInput/WindowsTextInputNativeComponent.js +1 -1
- package/Libraries/Components/Touchable/Touchable.d.ts +1 -1
- package/Libraries/Components/Touchable/Touchable.flow.js +30 -4
- package/Libraries/Components/Touchable/Touchable.js +6 -3
- package/Libraries/Components/Touchable/Touchable.windows.js +6 -3
- package/Libraries/Components/Touchable/TouchableHighlight.js +1 -1
- package/Libraries/Components/Touchable/TouchableHighlight.windows.js +2 -1
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -2
- package/Libraries/Components/Touchable/TouchableOpacity.js +3 -0
- package/Libraries/Components/Touchable/TouchableOpacity.windows.js +4 -0
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts +1 -1
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +2 -2
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.windows.js +2 -2
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +179 -0
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +43 -0
- package/Libraries/Components/View/ReactNativeStyleAttributes.js +26 -0
- package/Libraries/Components/View/View.js +35 -16
- package/Libraries/Components/View/View.windows.js +40 -16
- package/Libraries/Components/View/ViewAccessibility.d.ts +6 -6
- package/Libraries/Components/View/ViewAccessibility.js +10 -1
- package/Libraries/Components/View/ViewAccessibility.windows.js +9 -0
- package/Libraries/Components/View/ViewNativeComponent.js +32 -8
- package/Libraries/Components/View/ViewPropTypes.d.ts +1 -1
- package/Libraries/Components/View/ViewPropTypes.js +1 -1
- package/Libraries/Components/View/ViewPropTypes.windows.js +3 -1
- package/Libraries/Core/Devtools/openFileInEditor.js +1 -0
- package/Libraries/Core/Devtools/openURLInBrowser.js +1 -0
- package/Libraries/Core/Devtools/parseErrorStack.js +2 -2
- package/Libraries/Core/Devtools/parseHermesStack.js +54 -34
- package/Libraries/Core/ExceptionsManager.js +2 -2
- package/Libraries/Core/InitializeCore.js +2 -1
- package/Libraries/Core/ReactNativeVersion.js +3 -3
- package/Libraries/Core/ReactNativeVersionCheck.js +4 -8
- package/Libraries/Core/Timers/JSTimers.js +1 -1
- package/Libraries/Core/Timers/immediateShim.js +1 -0
- package/Libraries/Core/Timers/queueMicrotask.js +1 -1
- package/Libraries/Core/setUpAlert.js +1 -1
- package/Libraries/Core/setUpDOM.js +18 -0
- package/Libraries/Core/setUpDeveloperTools.js +1 -1
- package/Libraries/Core/setUpGlobals.js +5 -2
- package/Libraries/Core/setUpNavigator.js +6 -5
- package/Libraries/Core/setUpPerformance.js +23 -13
- package/Libraries/Core/setUpReactDevTools.js +2 -0
- package/Libraries/Core/setUpSegmentFetcher.js +0 -41
- package/Libraries/Core/setUpTimers.js +2 -2
- package/Libraries/DOM/Geometry/DOMRect.js +82 -0
- package/Libraries/DOM/Geometry/DOMRectReadOnly.js +188 -0
- package/Libraries/DOM/Nodes/ReactNativeElement.js +75 -0
- package/Libraries/DOM/Nodes/ReadOnlyElement.js +89 -0
- package/Libraries/DOM/Nodes/ReadOnlyNode.js +167 -0
- package/Libraries/DOM/OldStyleCollections/ArrayLikeUtils.js +46 -0
- package/Libraries/DOM/OldStyleCollections/DOMRectList.js +76 -0
- package/Libraries/DOM/OldStyleCollections/HTMLCollection.js +82 -0
- package/Libraries/DOM/OldStyleCollections/NodeList.js +104 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.android.js +35 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.d.ts +20 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.ios.js +49 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.windows.js +35 -0
- package/Libraries/DevToolsSettings/NativeDevToolsSettingsManager.js +24 -0
- package/Libraries/EventEmitter/NativeEventEmitter.d.ts +1 -2
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.d.ts +1 -2
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +9 -1
- package/Libraries/Events/EventPolyfill.js +1 -1
- package/Libraries/Image/AssetRegistry.js +1 -1
- package/Libraries/Image/AssetSourceResolver.js +3 -3
- package/Libraries/Image/Image.android.js +4 -1
- package/Libraries/Image/Image.d.ts +63 -2
- package/Libraries/Image/Image.ios.js +3 -0
- package/Libraries/Image/Image.windows.js +3 -0
- package/Libraries/Image/ImageBackground.js +1 -0
- package/Libraries/Image/ImageProps.js +1 -1
- package/Libraries/Image/ImageViewNativeComponent.js +4 -4
- package/Libraries/Image/RelativeImageStub.js +1 -1
- package/Libraries/Image/TextInlineImageNativeComponent.js +1 -1
- package/Libraries/Image/resolveAssetSource.js +1 -1
- package/Libraries/Inspector/DevtoolsOverlay.js +26 -19
- package/Libraries/Inspector/ElementBox.js +4 -1
- package/Libraries/Inspector/Inspector.js +5 -6
- package/Libraries/Inspector/InspectorOverlay.js +3 -3
- package/Libraries/Inspector/NetworkOverlay.js +1 -1
- package/Libraries/Interaction/JSEventLoopWatchdog.js +1 -1
- package/Libraries/Interaction/PanResponder.js +5 -6
- package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -1
- package/Libraries/Linking/Linking.js +1 -4
- package/Libraries/Lists/FillRateHelper.js +4 -238
- package/Libraries/Lists/FlatList.d.ts +15 -22
- package/Libraries/Lists/FlatList.js +9 -6
- package/Libraries/Lists/SectionList.d.ts +10 -6
- package/Libraries/Lists/SectionList.js +5 -3
- package/Libraries/Lists/SectionListModern.js +3 -3
- package/Libraries/Lists/ViewabilityHelper.js +8 -344
- package/Libraries/Lists/VirtualizeUtils.js +4 -244
- package/Libraries/Lists/VirtualizedList.js +10 -1867
- package/Libraries/Lists/VirtualizedListContext.js +6 -104
- package/Libraries/Lists/VirtualizedSectionList.js +9 -602
- package/Libraries/Lists/__flowtests__/FlatList-flowtest.js +1 -0
- package/Libraries/Lists/__flowtests__/SectionList-flowtest.js +1 -1
- package/Libraries/LogBox/Data/LogBoxData.js +1 -1
- package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
- package/Libraries/LogBox/LogBox.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspector.js +1 -3
- package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.windows.js +167 -0
- package/Libraries/LogBox/UI/LogBoxInspectorHeader.windows.js +172 -0
- package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.windows.js +193 -0
- package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +1 -0
- package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.js +2 -2
- package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.windows.js +118 -0
- package/Libraries/LogBox/UI/LogBoxMessage.js +87 -5
- package/Libraries/LogBox/UI/LogBoxNotification.js +5 -7
- package/Libraries/Modal/Modal.js +2 -2
- package/Libraries/NativeComponent/BaseViewConfig.android.js +32 -12
- package/Libraries/NativeComponent/BaseViewConfig.ios.js +43 -19
- package/Libraries/NativeComponent/BaseViewConfig.windows.js +77 -19
- package/Libraries/NativeComponent/NativeComponentRegistryUnstable.js +4 -1
- package/Libraries/NativeComponent/ViewConfig.js +1 -0
- package/Libraries/NativeComponent/ViewConfigIgnore.js +1 -4
- package/Libraries/Network/RCTNetworking.android.js +2 -2
- package/Libraries/Network/RCTNetworking.ios.js +1 -1
- package/Libraries/Network/RCTNetworking.windows.js +1 -1
- package/Libraries/Network/XMLHttpRequest.js +1 -1
- package/Libraries/Pressability/Pressability.js +10 -4
- package/Libraries/Pressability/Pressability.windows.js +11 -4
- package/Libraries/ReactNative/AppContainer.js +7 -1
- package/Libraries/ReactNative/AppRegistry.d.ts +1 -1
- package/Libraries/ReactNative/AppRegistry.js +10 -13
- package/Libraries/ReactNative/FabricUIManager.js +24 -8
- package/Libraries/ReactNative/NativeUIManager.js +5 -5
- package/Libraries/ReactNative/ReactNativeFeatureFlags.js +10 -10
- package/Libraries/ReactNative/UIManager.js +168 -1
- package/Libraries/ReactNative/getCachedComponentWithDebugName.js +5 -5
- package/Libraries/ReactNative/getNativeComponentAttributes.js +1 -1
- package/Libraries/ReactNative/requireNativeComponent.d.ts +1 -1
- package/Libraries/ReactNative/requireNativeComponent.js +1 -1
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +1 -0
- package/Libraries/Renderer/implementations/ReactFabric-dev.js +26 -3
- package/Libraries/Renderer/implementations/ReactFabric-prod.js +13 -1
- package/Libraries/Renderer/implementations/ReactFabric-profiling.js +13 -1
- package/Libraries/Renderer/public/ReactFabricPublicInstanceUtils.js +38 -0
- package/Libraries/Renderer/shims/ReactNativeTypes.js +6 -6
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -7
- package/Libraries/Renderer/shims/createReactNativeComponentClass.js +2 -2
- package/Libraries/Share/Share.js +1 -1
- package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +1 -1
- package/Libraries/StyleSheet/StyleSheet.js +1 -1
- package/Libraries/StyleSheet/StyleSheetTypes.d.ts +115 -76
- package/Libraries/StyleSheet/StyleSheetTypes.js +188 -33
- package/Libraries/StyleSheet/flattenStyle.js +2 -0
- package/Libraries/StyleSheet/normalizeColor.js +1 -1
- package/Libraries/StyleSheet/processColor.js +1 -1
- package/Libraries/Text/Text.d.ts +12 -2
- package/Libraries/Text/Text.js +50 -41
- package/Libraries/Text/Text.windows.js +48 -38
- package/Libraries/Text/TextProps.js +3 -4
- package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +6 -0
- package/Libraries/Types/CodegenTypes.js +1 -0
- package/Libraries/UTFSequence.js +3 -1
- package/Libraries/Utilities/Appearance.d.ts +10 -0
- package/Libraries/Utilities/Appearance.js +13 -0
- package/Libraries/Utilities/Dimensions.js +1 -1
- package/Libraries/Utilities/GlobalPerformanceLogger.js +12 -1
- package/Libraries/Utilities/HMRClient.js +16 -10
- package/Libraries/Utilities/{createPerformanceLogger.d.ts → IPerformanceLogger.d.ts} +4 -4
- package/Libraries/Utilities/IPerformanceLogger.js +49 -0
- package/Libraries/Utilities/LoadingView.android.js +28 -11
- package/Libraries/Utilities/NativeAppearance.js +1 -0
- package/Libraries/Utilities/NativePlatformConstantsWin.js +1 -1
- package/Libraries/Utilities/PixelRatio.js +2 -2
- package/Libraries/Utilities/Platform.windows.js +1 -1
- package/Libraries/Utilities/ReactNativeTestTools.js +1 -1
- package/Libraries/Utilities/__mocks__/PixelRatio.js +1 -1
- package/Libraries/Utilities/codegenNativeCommands.js +2 -0
- package/Libraries/Utilities/createPerformanceLogger.js +55 -43
- package/Libraries/Utilities/stringifySafe.js +2 -7
- package/Libraries/Utilities/useColorScheme.windows.js +26 -0
- package/Libraries/Utilities/useWindowDimensions.js +3 -3
- package/Libraries/WebPerformance/EventCounts.js +78 -0
- package/Libraries/WebPerformance/MemoryInfo.js +54 -0
- package/Libraries/WebPerformance/NativePerformance.js +38 -0
- package/Libraries/WebPerformance/NativePerformanceObserver.js +22 -7
- package/Libraries/WebPerformance/Performance.js +312 -0
- package/Libraries/WebPerformance/PerformanceEntry.js +45 -0
- package/Libraries/WebPerformance/PerformanceEventTiming.js +38 -0
- package/Libraries/WebPerformance/PerformanceObserver.js +196 -101
- package/Libraries/WebPerformance/RawPerformanceEntry.js +87 -0
- package/Libraries/WebPerformance/ReactNativeStartupTiming.js +65 -0
- package/Libraries/WebPerformance/__mocks__/NativePerformance.js +65 -0
- package/Libraries/WebPerformance/__mocks__/NativePerformanceObserver.js +101 -0
- package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
- package/Libraries/platform-types.d.ts +3 -5
- package/Libraries/vendor/core/ErrorUtils.js +1 -1
- package/Libraries/vendor/emitter/EventEmitter.d.ts +2 -2
- package/Libraries/vendor/emitter/EventEmitter.js +9 -1
- package/Microsoft.ReactNative/Base/CoreNativeModules.cpp +0 -15
- package/Microsoft.ReactNative/CompositionHwndHost.idl +6 -0
- package/Microsoft.ReactNative/CompositionRootView.idl +35 -0
- package/Microsoft.ReactNative/CompositionSwitcher.idl +19 -0
- package/Microsoft.ReactNative/Fabric/AbiViewComponentDescriptor.cpp +174 -0
- package/Microsoft.ReactNative/Fabric/AbiViewComponentDescriptor.h +91 -0
- package/Microsoft.ReactNative/Fabric/AbiViewProps.cpp +48 -0
- package/Microsoft.ReactNative/Fabric/AbiViewProps.h +48 -0
- package/Microsoft.ReactNative/Fabric/ComponentView.h +19 -2
- package/Microsoft.ReactNative/Fabric/Composition/AbiCompositionViewComponentView.cpp +144 -0
- package/Microsoft.ReactNative/Fabric/Composition/AbiCompositionViewComponentView.h +63 -0
- package/Microsoft.ReactNative/Fabric/Composition/ComponentViewRegistry.cpp +27 -6
- package/Microsoft.ReactNative/Fabric/Composition/CompositionContextHelper.cpp +97 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.cpp +227 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionDynamicAutomationProvider.h +38 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.cpp +112 -95
- package/Microsoft.ReactNative/Fabric/Composition/CompositionEventHandler.h +12 -8
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHelpers.h +0 -2
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHwndHost.cpp +27 -6
- package/Microsoft.ReactNative/Fabric/Composition/CompositionHwndHost.h +8 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.cpp +147 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootAutomationProvider.h +46 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView.cpp +31 -4
- package/Microsoft.ReactNative/Fabric/Composition/CompositionRootView.h +37 -0
- package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.cpp +255 -50
- package/Microsoft.ReactNative/Fabric/Composition/CompositionViewComponentView.h +34 -15
- package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.cpp +127 -47
- package/Microsoft.ReactNative/Fabric/Composition/ImageComponentView.h +11 -7
- package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.cpp +109 -39
- package/Microsoft.ReactNative/Fabric/Composition/ParagraphComponentView.h +10 -7
- package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.cpp +106 -0
- package/Microsoft.ReactNative/Fabric/Composition/ReactCompositionViewComponentBuilder.h +63 -0
- package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.cpp +116 -0
- package/Microsoft.ReactNative/Fabric/Composition/RootComponentView.h +43 -0
- package/Microsoft.ReactNative/Fabric/Composition/ScrollViewComponentView.cpp +53 -38
- package/Microsoft.ReactNative/Fabric/Composition/ScrollViewComponentView.h +12 -8
- package/Microsoft.ReactNative/Fabric/Composition/SwitchComponentView.cpp +262 -0
- package/Microsoft.ReactNative/Fabric/Composition/SwitchComponentView.h +62 -0
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.cpp +35 -30
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputComponentView.h +11 -9
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputProps.cpp +9 -0
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputProps.h +3 -0
- package/Microsoft.ReactNative/Fabric/Composition/TextInput/WindowsTextInputShadowNode.cpp +2 -1
- package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.cpp +72 -0
- package/Microsoft.ReactNative/Fabric/Composition/UiaHelpers.h +16 -0
- package/Microsoft.ReactNative/Fabric/Composition/UnimplementedNativeViewComponentView.cpp +168 -0
- package/Microsoft.ReactNative/Fabric/Composition/UnimplementedNativeViewComponentView.h +49 -0
- package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.cpp +19 -53
- package/Microsoft.ReactNative/Fabric/FabricUIManagerModule.h +2 -3
- package/Microsoft.ReactNative/Fabric/ReactTaggedView.h +8 -9
- package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.cpp +100 -0
- package/Microsoft.ReactNative/Fabric/WindowsComponentDescriptorRegistry.h +43 -0
- package/Microsoft.ReactNative/Fabric/platform/react/components/view/windows/WindowsViewProps.cpp +61 -0
- package/Microsoft.ReactNative/Fabric/platform/react/components/view/windows/WindowsViewProps.h +34 -0
- package/Microsoft.ReactNative/Fabric/platform/react/components/view/windows/primitives.h +42 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/view/HostPlatformViewProps.h +10 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/core/graphicsConversions.h +248 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Color.cpp +5 -0
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Color.h +135 -4
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/conversions.h +18 -240
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.cpp +107 -17
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/textlayoutmanager/TextLayoutManager.h +13 -2
- package/Microsoft.ReactNative/IReactCompositionViewComponentBuilder.idl +87 -0
- package/Microsoft.ReactNative/IReactContext.cpp +4 -0
- package/Microsoft.ReactNative/IReactContext.h +1 -0
- package/Microsoft.ReactNative/IReactContext.idl +5 -0
- package/Microsoft.ReactNative/IReactDispatcher.cpp +4 -0
- package/Microsoft.ReactNative/IReactDispatcher.h +1 -0
- package/Microsoft.ReactNative/IReactPackageBuilderFabric.idl +23 -0
- package/Microsoft.ReactNative/IReactViewComponentBuilder.idl +23 -0
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj +4 -118
- package/Microsoft.ReactNative/Microsoft.ReactNative.vcxproj.filters +1 -7
- package/Microsoft.ReactNative/Modules/AccessibilityInfoModule.cpp +2 -2
- package/Microsoft.ReactNative/Modules/AccessibilityInfoModule.h +1 -1
- package/Microsoft.ReactNative/Modules/AlertModule.cpp +100 -4
- package/Microsoft.ReactNative/Modules/AlertModule.h +4 -0
- package/Microsoft.ReactNative/Modules/Animated/NativeAnimatedModule.cpp +9 -0
- package/Microsoft.ReactNative/Modules/Animated/NativeAnimatedModule.h +2 -0
- package/Microsoft.ReactNative/Modules/Animated/NativeAnimatedNodeManager.cpp +7 -5
- package/Microsoft.ReactNative/Modules/Animated/PropsAnimatedNode.cpp +17 -3
- package/Microsoft.ReactNative/Modules/Animated/ValueAnimatedNode.h +1 -0
- package/Microsoft.ReactNative/Modules/AppearanceModule.cpp +4 -0
- package/Microsoft.ReactNative/Modules/AppearanceModule.h +3 -0
- package/Microsoft.ReactNative/Modules/ClipboardModule.cpp +4 -4
- package/Microsoft.ReactNative/Modules/ClipboardModule.h +2 -2
- package/Microsoft.ReactNative/Modules/ImageViewManagerModule.cpp +27 -7
- package/Microsoft.ReactNative/Modules/ImageViewManagerModule.h +9 -5
- package/Microsoft.ReactNative/Modules/LinkingManagerModule.cpp +10 -12
- package/Microsoft.ReactNative/Modules/LinkingManagerModule.h +4 -4
- package/Microsoft.ReactNative/Modules/NativeUIManager.cpp +21 -1
- package/Microsoft.ReactNative/QuirkSettings.cpp +17 -0
- package/Microsoft.ReactNative/QuirkSettings.h +5 -0
- package/Microsoft.ReactNative/QuirkSettings.idl +6 -0
- package/Microsoft.ReactNative/ReactApplication.cpp +8 -0
- package/Microsoft.ReactNative/ReactApplication.h +3 -0
- package/Microsoft.ReactNative/ReactApplication.idl +3 -0
- package/Microsoft.ReactNative/ReactCoreInjection.cpp +29 -0
- package/Microsoft.ReactNative/ReactCoreInjection.h +6 -0
- package/Microsoft.ReactNative/ReactCoreInjection.idl +13 -0
- package/Microsoft.ReactNative/ReactHost/MsoReactContext.cpp +7 -0
- package/Microsoft.ReactNative/ReactHost/MsoReactContext.h +1 -0
- package/Microsoft.ReactNative/ReactHost/React.h +2 -0
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.cpp +57 -16
- package/Microsoft.ReactNative/ReactHost/ReactInstanceWin.h +1 -0
- package/Microsoft.ReactNative/ReactInstanceSettings.h +12 -0
- package/Microsoft.ReactNative/ReactInstanceSettings.idl +6 -0
- package/Microsoft.ReactNative/ReactNativeHost.cpp +17 -0
- package/Microsoft.ReactNative/ReactPackageBuilder.cpp +18 -0
- package/Microsoft.ReactNative/ReactPackageBuilder.h +24 -1
- package/Microsoft.ReactNative/ReactRootView.cpp +2 -2
- package/Microsoft.ReactNative/RedBox.cpp +2 -1
- package/Microsoft.ReactNative/Utils/Helpers.cpp +0 -32
- package/Microsoft.ReactNative/Utils/Helpers.h +0 -8
- package/Microsoft.ReactNative/Utils/ImageUtils.cpp +69 -6
- package/Microsoft.ReactNative/Utils/ImageUtils.h +3 -1
- package/Microsoft.ReactNative/Utils/KeyboardUtils.cpp +416 -0
- package/Microsoft.ReactNative/Utils/KeyboardUtils.h +15 -0
- package/Microsoft.ReactNative/Utils/TransformableText.h +1 -0
- package/Microsoft.ReactNative/Utils/ValueUtils.cpp +1 -9
- package/Microsoft.ReactNative/Utils/ValueUtils.h +0 -2
- package/Microsoft.ReactNative/ViewProps.idl +30 -0
- package/Microsoft.ReactNative/Views/ControlViewManager.cpp +6 -2
- package/Microsoft.ReactNative/Views/DevMenu.cpp +369 -230
- package/Microsoft.ReactNative/Views/DevMenu.h +3 -15
- package/Microsoft.ReactNative/Views/FlyoutViewManager.cpp +6 -3
- package/Microsoft.ReactNative/Views/Image/ImageViewManager.cpp +11 -3
- package/Microsoft.ReactNative/Views/Image/ImageViewManager.h +5 -1
- package/Microsoft.ReactNative/Views/Image/ReactImage.cpp +29 -22
- package/Microsoft.ReactNative/Views/Image/ReactImage.h +2 -2
- package/Microsoft.ReactNative/Views/KeyboardEventHandler.cpp +10 -405
- package/Microsoft.ReactNative/Views/KeyboardEventHandler.h +0 -3
- package/Microsoft.ReactNative/Views/PopupViewManager.cpp +1 -0
- package/Microsoft.ReactNative/Views/ScrollViewManager.cpp +2 -2
- package/Microsoft.ReactNative/Views/ShadowNodeBase.cpp +7 -0
- package/Microsoft.ReactNative/Views/ShadowNodeBase.h +3 -0
- package/Microsoft.ReactNative/Views/Text/TextHitTestUtils.cpp +6 -1
- package/Microsoft.ReactNative/Views/Text/TextPropertyChangedParentVisitor.cpp +1 -0
- package/Microsoft.ReactNative/Views/TextInputViewManager.cpp +38 -2
- package/Microsoft.ReactNative/Views/TextViewManager.cpp +3 -0
- package/Microsoft.ReactNative/Views/TouchEventHandler.h +0 -4
- package/Microsoft.ReactNative/Views/ViewManagerBase.cpp +0 -8
- package/Microsoft.ReactNative/Views/ViewPanel.cpp +1 -1
- package/Microsoft.ReactNative/Views/ViewViewManager.cpp +12 -3
- package/Microsoft.ReactNative/XamlHelper.cpp +36 -0
- package/Microsoft.ReactNative/XamlHelper.h +27 -0
- package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.cpp +4 -4
- package/Microsoft.ReactNative.Cxx/JSI/JsiAbiApi.h +4 -4
- package/Microsoft.ReactNative.Cxx/JSI/LongLivedJsiValue.h +1 -1
- package/Microsoft.ReactNative.Cxx/JSI/NodeApiJsiRuntime.cpp +10 -8
- package/Microsoft.ReactNative.Cxx/JSI/NodeApiJsiRuntime.h +3 -3
- package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems +4 -1
- package/Microsoft.ReactNative.Cxx/Microsoft.ReactNative.Cxx.vcxitems.filters +3 -0
- package/Microsoft.ReactNative.Cxx/NativeModules.h +16 -1
- package/Microsoft.ReactNative.Managed/ReactSettingsSnapshot.cs +2 -0
- package/Microsoft.ReactNative.Managed/packages.lock.json +5 -5
- package/PropertySheets/External/Microsoft.ReactNative.Cpp.ProjectReferences.props +3 -0
- package/PropertySheets/Generated/PackageVersion.g.props +4 -4
- package/PropertySheets/JSEngine.props +1 -2
- package/PropertySheets/Warnings.props +1 -1
- package/ReactCommon/ReactCommon.vcxproj +2 -4
- package/ReactCommon/ReactCommon.vcxproj.filters +3 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/CallbackWrapper.h +1 -1
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/LongLivedObject.cpp +60 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/bridging/LongLivedObject.h +60 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleBinding.cpp +116 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleBinding.h +63 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/nativemodule/core/ReactCommon/TurboModuleUtils.h +2 -2
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/TouchEventEmitter.cpp +237 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/TouchEventEmitter.h +59 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/ViewEventEmitter.cpp +159 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/ViewEventEmitter.h +94 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/ViewProps.cpp +465 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/ViewProps.h +116 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/ViewShadowNode.cpp +98 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/YogaStylableProps.cpp +362 -0
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/components/view/primitives.h +326 -0
- package/ReactCommon/Yoga.cpp +60 -127
- package/Scripts/OfficeReact.Win32.nuspec +1 -0
- package/Scripts/Tfs/Layout-MSRN-Headers.ps1 +1 -0
- package/Scripts/rnw-dependencies.ps1 +14 -6
- package/Shared/Composition/CompositionSwitcher.interop.h +1 -0
- package/Shared/DevServerHelper.h +11 -2
- package/Shared/DevSettings.h +1 -0
- package/Shared/DevSupportManager.cpp +11 -1
- package/Shared/DevSupportManager.h +1 -0
- package/Shared/HermesRuntimeHolder.cpp +53 -30
- package/Shared/HermesRuntimeHolder.h +26 -11
- package/Shared/HermesSamplingProfiler.cpp +61 -8
- package/Shared/HermesSamplingProfiler.h +6 -3
- package/Shared/HermesShim.cpp +86 -82
- package/Shared/HermesShim.h +28 -8
- package/Shared/JSI/ChakraRuntime.cpp +7 -4
- package/Shared/JSI/ChakraRuntime.h +4 -4
- package/Shared/JSI/NapiJsiV8RuntimeHolder.h +2 -0
- package/Shared/JSI/RuntimeHolder.h +2 -2
- package/Shared/Logging.cpp +1 -1
- package/Shared/Modules/BlobModule.cpp +3 -4
- package/Shared/Modules/BlobModule.h +0 -4
- package/Shared/Networking/OriginPolicyHttpFilter.cpp +13 -17
- package/Shared/Networking/OriginPolicyHttpFilter.h +11 -12
- package/Shared/Networking/WinRTWebSocketResource.cpp +59 -45
- package/Shared/OInstance.cpp +9 -2
- package/Shared/Shared.vcxitems +265 -58
- package/Shared/Shared.vcxitems.filters +312 -42
- package/Shared/V8JSIRuntimeHolder.cpp +1 -0
- package/Shared/V8JSIRuntimeHolder.h +7 -2
- package/codegen/NativeAppearanceSpec.g.h +9 -3
- package/codegen/NativeClipboardSpec.g.h +3 -3
- package/codegen/NativeDevSplitBundleLoaderSpec.g.h +3 -3
- package/codegen/NativeDevToolsSettingsManagerSpec.g.h +51 -0
- package/codegen/NativeDialogManagerWindowsSpec.g.h +2 -0
- package/codegen/NativeFileReaderModuleSpec.g.h +6 -6
- package/codegen/NativeHeadlessJsTaskSupportSpec.g.h +3 -3
- package/codegen/NativeImageLoaderAndroidSpec.g.h +25 -9
- package/codegen/NativeImageLoaderIOSSpec.g.h +20 -12
- package/codegen/NativeIntentAndroidSpec.g.h +15 -15
- package/codegen/NativeLinkingManagerSpec.g.h +12 -12
- package/codegen/NativePerformanceObserverSpec.g.h +48 -10
- package/codegen/NativePerformanceSpec.g.h +63 -0
- package/codegen/NativePermissionsAndroidSpec.g.h +9 -9
- package/codegen/NativePlatformConstantsWinSpec.g.h +1 -1
- package/codegen/NativePushNotificationManagerIOSSpec.g.h +6 -6
- package/codegen/NativeSampleTurboModuleSpec.g.h +25 -19
- package/codegen/NativeShareModuleSpec.g.h +9 -3
- package/codegen/NativeUIManagerSpec.g.h +12 -12
- package/codegen/react/components/rnwcore/ComponentDescriptors.h +1 -2
- package/codegen/react/components/rnwcore/EventEmitters.cpp +21 -29
- package/codegen/react/components/rnwcore/EventEmitters.h +30 -30
- package/codegen/react/components/rnwcore/Props.cpp +47 -48
- package/codegen/react/components/rnwcore/Props.h +59 -166
- package/codegen/react/components/rnwcore/ShadowNodes.cpp +1 -2
- package/codegen/react/components/rnwcore/ShadowNodes.h +11 -22
- package/codegen/react/components/rnwcore/States.h +15 -30
- package/codegen/rnwcoreJSI-generated.cpp +87 -17
- package/codegen/rnwcoreJSI.h +1080 -376
- package/generate.js +6 -1
- package/include/Include.vcxitems +0 -1
- package/include/Include.vcxitems.filters +0 -3
- package/index.js +56 -42
- package/index.windows.js +56 -42
- package/interface.js +1 -1
- package/jest/local-setup.js +33 -0
- package/jest/mockComponent.js +4 -2
- package/jest/mockNativeComponent.js +1 -1
- package/jest/mockScrollView.js +2 -1
- package/jest/react-native-env.js +1 -3
- package/jest/setup.js +11 -8
- package/just-task.js +12 -5
- package/package.json +34 -31
- package/rn-get-polyfills.js +1 -1
- package/template/metro.config.js +2 -0
- package/Libraries/Animated/createAnimatedComponentInjection.js +0 -48
- package/Libraries/Animated/createAnimatedComponent_EXPERIMENTAL.js +0 -48
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.flow.js +0 -208
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.flow.js +0 -58
- package/Libraries/Components/DatePicker/DatePickerIOS.android.js +0 -47
- package/Libraries/Components/DatePicker/DatePickerIOS.d.ts +0 -92
- package/Libraries/Components/DatePicker/DatePickerIOS.flow.android.js +0 -14
- package/Libraries/Components/DatePicker/DatePickerIOS.flow.ios.js +0 -113
- package/Libraries/Components/DatePicker/DatePickerIOS.ios.js +0 -242
- package/Libraries/Components/DatePicker/DatePickerIOS.windows.js +0 -47
- package/Libraries/Components/DatePicker/RCTDatePickerNativeComponent.js +0 -60
- package/Libraries/Components/DatePickerAndroid/NativeDatePickerAndroid.js +0 -26
- package/Libraries/Components/Flyout/Flyout.js.map +0 -1
- package/Libraries/Components/Flyout/FlyoutProps.d.ts +0 -25
- package/Libraries/Components/Flyout/FlyoutProps.js +0 -3
- package/Libraries/Components/Flyout/FlyoutProps.js.map +0 -1
- package/Libraries/Components/Glyph/Glyph.js.map +0 -1
- package/Libraries/Components/Glyph/GlyphProps.d.ts +0 -16
- package/Libraries/Components/Glyph/GlyphProps.js +0 -8
- package/Libraries/Components/Glyph/GlyphProps.js.map +0 -1
- package/Libraries/Components/Popup/Popup.js.map +0 -1
- package/Libraries/Components/Popup/PopupProps.d.ts +0 -27
- package/Libraries/Components/Popup/PopupProps.js +0 -8
- package/Libraries/Components/Popup/PopupProps.js.map +0 -1
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.android.js +0 -45
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.d.ts +0 -62
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.ios.js +0 -75
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.windows.js +0 -45
- package/Libraries/Components/ProgressViewIOS/RCTProgressViewNativeComponent.js +0 -33
- package/Libraries/Components/SafeAreaView/SafeAreaView.flow.js +0 -19
- package/Libraries/Components/Slider/Slider.d.ts +0 -132
- package/Libraries/Components/Slider/Slider.js +0 -282
- package/Libraries/Components/Slider/SliderNativeComponent.js +0 -56
- package/Libraries/Interaction/Batchinator.js +0 -76
- package/Libraries/Interaction/BridgeSpyStallHandler.js +0 -63
- package/Libraries/Interaction/InteractionStallDebugger.js +0 -23
- package/Libraries/Interaction/PanResponder.flow.js +0 -257
- package/Libraries/Lists/CellRenderMask.js +0 -155
- package/Libraries/Lists/ChildListCollection.js +0 -72
- package/Libraries/Lists/StateSafePureComponent.js +0 -85
- package/Libraries/Lists/VirtualizedList.d.ts +0 -347
- package/Libraries/Lists/VirtualizedListCellRenderer.js +0 -259
- package/Libraries/Lists/VirtualizedListProps.js +0 -279
- package/Libraries/Performance/PureComponentDebug.js +0 -74
- package/Libraries/Reliability/UserFlow.js +0 -158
- package/Libraries/Renderer/implementations/ReactNativeRenderer.d.ts +0 -149
- package/Libraries/Renderer/shims/ReactNativeTypes.d.ts +0 -141
- package/Libraries/Utilities/MatrixMath.js +0 -748
- package/Libraries/Utilities/buildStyleInterpolator.js +0 -209
- package/Libraries/Utilities/clamp.js +0 -23
- package/Libraries/Utilities/deprecatedPropType.js +0 -36
- package/Libraries/Utilities/groupByEveryN.js +0 -51
- package/Libraries/Utilities/mergeIntoFast.js +0 -26
- package/Libraries/Utilities/setAndForwardRef.js +0 -71
- package/Libraries/Utilities/truncate.js +0 -51
- package/Microsoft.ReactNative/Fabric/platform/react/components/image/conversions.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/components/view/ConcreteViewShadowNode.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/components/view/ViewEventEmitter.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/components/view/ViewProps.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/core/ConcreteComponentDescriptor.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/core/PropsParserContext.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/core/propsConversions.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/graphics/Color.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/imagemanager/primitives.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/iostextinput/TextInputEventEmitter.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/iostextinput/TextInputProps.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/iostextinput/TextInputShadowNode.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/iostextinput/TextInputState.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/iostextinput/conversions.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/iostextinput/primitives.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/iostextinput/propsConversions.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rncore/EventEmitters.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rncore/Props.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/components/rncore/States.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/Float.h +0 -5
- package/Microsoft.ReactNative/Fabric/platform/react/renderer/graphics/platform/cxx/react/renderer/graphics/Color.h +0 -135
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/core/ConcreteComponentDescriptor.h +0 -217
- package/ReactCommon/TEMP_UntilReactCommonUpdate/react/renderer/graphics/RectangleEdges.h +0 -100
- package/Shared/AsyncStorage/AsyncStorageManager.cpp +0 -149
- package/Shared/AsyncStorage/AsyncStorageManager.h +0 -71
- package/Shared/AsyncStorage/FollyDynamicConverter.cpp +0 -51
- package/Shared/AsyncStorage/FollyDynamicConverter.h +0 -24
- package/Shared/AsyncStorage/KeyValueStorage.cpp +0 -248
- package/Shared/AsyncStorage/KeyValueStorage.h +0 -50
- package/Shared/AsyncStorage/StorageFileIO.cpp +0 -160
- package/Shared/AsyncStorage/StorageFileIO.h +0 -40
- package/Shared/AsyncStorageModule.h +0 -25
- package/Shared/Modules/AsyncStorageModule.cpp +0 -87
- package/Shared/Modules/AsyncStorageModuleWin32.cpp +0 -496
- package/Shared/Modules/AsyncStorageModuleWin32.h +0 -75
- package/codegen/NativeDatePickerAndroidSpec.g.h +0 -33
- package/include/Shared/AsyncStorageModuleWin32Config.h +0 -15
- package/types/index.d.ts +0 -216
- package/types/modules/BatchedBridge.d.ts +0 -32
- package/types/modules/Codegen.d.ts +0 -74
- package/types/modules/Devtools.d.ts +0 -31
- package/types/modules/LaunchScreen.d.ts +0 -18
- package/types/modules/globals.d.ts +0 -577
- package/types/private/TimerMixin.d.ts +0 -19
- package/types/private/Utilities.d.ts +0 -10
- package/types/public/DeprecatedPropertiesAlias.d.ts +0 -205
- package/types/public/Insets.d.ts +0 -15
- package/types/public/ReactNativeRenderer.d.ts +0 -149
- package/types/public/ReactNativeTypes.d.ts +0 -143
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
* @flow strict-local
|
|
8
|
+
* @format
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import type {CodeFrame} from '../Data/parseLogBoxLog';
|
|
12
|
+
|
|
13
|
+
import ScrollView from '../../Components/ScrollView/ScrollView';
|
|
14
|
+
import View from '../../Components/View/View';
|
|
15
|
+
import openFileInEditor from '../../Core/Devtools/openFileInEditor';
|
|
16
|
+
import StyleSheet from '../../StyleSheet/StyleSheet';
|
|
17
|
+
import Text from '../../Text/Text';
|
|
18
|
+
import Platform from '../../Utilities/Platform';
|
|
19
|
+
import * as LogBoxData from '../Data/LogBoxData';
|
|
20
|
+
import AnsiHighlight from './AnsiHighlight';
|
|
21
|
+
import LogBoxButton from './LogBoxButton';
|
|
22
|
+
import LogBoxInspectorSection from './LogBoxInspectorSection';
|
|
23
|
+
import * as LogBoxStyle from './LogBoxStyle';
|
|
24
|
+
import * as React from 'react';
|
|
25
|
+
type Props = $ReadOnly<{|
|
|
26
|
+
codeFrame: ?CodeFrame,
|
|
27
|
+
|}>;
|
|
28
|
+
|
|
29
|
+
function LogBoxInspectorCodeFrame(props: Props): React.Node {
|
|
30
|
+
const codeFrame = props.codeFrame;
|
|
31
|
+
if (codeFrame == null) {
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
function getFileName() {
|
|
36
|
+
// $FlowFixMe[incompatible-use]
|
|
37
|
+
const matches = /[^/]*$/.exec(codeFrame.fileName);
|
|
38
|
+
if (matches && matches.length > 0) {
|
|
39
|
+
return matches[0];
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// $FlowFixMe[incompatible-use]
|
|
43
|
+
return codeFrame.fileName;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function getLocation() {
|
|
47
|
+
// $FlowFixMe[incompatible-use]
|
|
48
|
+
const location = codeFrame.location;
|
|
49
|
+
if (location != null) {
|
|
50
|
+
return ` (${location.row}:${
|
|
51
|
+
location.column + 1 /* Code frame columns are zero indexed */
|
|
52
|
+
})`;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
return (
|
|
59
|
+
<LogBoxInspectorSection heading="Source" action={<AppInfo />}>
|
|
60
|
+
<View style={styles.box}>
|
|
61
|
+
<View style={styles.frame}>
|
|
62
|
+
<ScrollView horizontal>
|
|
63
|
+
<AnsiHighlight style={styles.content} text={codeFrame.content} />
|
|
64
|
+
</ScrollView>
|
|
65
|
+
</View>
|
|
66
|
+
<LogBoxButton
|
|
67
|
+
backgroundColor={{
|
|
68
|
+
default: 'transparent',
|
|
69
|
+
pressed: LogBoxStyle.getBackgroundDarkColor(1),
|
|
70
|
+
}}
|
|
71
|
+
style={styles.button}
|
|
72
|
+
onPress={() => {
|
|
73
|
+
openFileInEditor(codeFrame.fileName, codeFrame.location?.row ?? 0);
|
|
74
|
+
}}>
|
|
75
|
+
<Text style={styles.fileText}>
|
|
76
|
+
{getFileName()}
|
|
77
|
+
{getLocation()}
|
|
78
|
+
</Text>
|
|
79
|
+
</LogBoxButton>
|
|
80
|
+
</View>
|
|
81
|
+
</LogBoxInspectorSection>
|
|
82
|
+
);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
function AppInfo() {
|
|
86
|
+
const appInfo = LogBoxData.getAppInfo();
|
|
87
|
+
if (appInfo == null) {
|
|
88
|
+
return null;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
return (
|
|
92
|
+
<LogBoxButton
|
|
93
|
+
backgroundColor={{
|
|
94
|
+
default: 'transparent',
|
|
95
|
+
pressed: appInfo.onPress
|
|
96
|
+
? LogBoxStyle.getBackgroundColor(1)
|
|
97
|
+
: 'transparent',
|
|
98
|
+
}}
|
|
99
|
+
style={appInfoStyles.buildButton}
|
|
100
|
+
onPress={appInfo.onPress}>
|
|
101
|
+
<Text style={appInfoStyles.text}>
|
|
102
|
+
{appInfo.appVersion} ({appInfo.engine})
|
|
103
|
+
</Text>
|
|
104
|
+
</LogBoxButton>
|
|
105
|
+
);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const appInfoStyles = StyleSheet.create({
|
|
109
|
+
text: {
|
|
110
|
+
color: LogBoxStyle.getTextColor(0.4),
|
|
111
|
+
fontSize: 12,
|
|
112
|
+
lineHeight: 12,
|
|
113
|
+
},
|
|
114
|
+
buildButton: {
|
|
115
|
+
flex: 0,
|
|
116
|
+
flexGrow: 0,
|
|
117
|
+
paddingVertical: 4,
|
|
118
|
+
paddingHorizontal: 5,
|
|
119
|
+
borderRadius: 5,
|
|
120
|
+
marginRight: -8,
|
|
121
|
+
},
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
const styles = StyleSheet.create({
|
|
125
|
+
box: {
|
|
126
|
+
backgroundColor: LogBoxStyle.getBackgroundColor(),
|
|
127
|
+
marginLeft: 10,
|
|
128
|
+
marginRight: 10,
|
|
129
|
+
marginTop: 5,
|
|
130
|
+
borderRadius: 3,
|
|
131
|
+
},
|
|
132
|
+
frame: {
|
|
133
|
+
padding: 10,
|
|
134
|
+
borderBottomColor: LogBoxStyle.getTextColor(0.1),
|
|
135
|
+
borderBottomWidth: 1,
|
|
136
|
+
},
|
|
137
|
+
button: {
|
|
138
|
+
paddingTop: 10,
|
|
139
|
+
paddingBottom: 10,
|
|
140
|
+
},
|
|
141
|
+
content: {
|
|
142
|
+
color: LogBoxStyle.getTextColor(1),
|
|
143
|
+
fontSize: 12,
|
|
144
|
+
includeFontPadding: false,
|
|
145
|
+
lineHeight: 20,
|
|
146
|
+
fontFamily: Platform.select({
|
|
147
|
+
android: 'monospace',
|
|
148
|
+
ios: 'Menlo',
|
|
149
|
+
windows: 'Consolas',
|
|
150
|
+
}),
|
|
151
|
+
},
|
|
152
|
+
fileText: {
|
|
153
|
+
color: LogBoxStyle.getTextColor(0.5),
|
|
154
|
+
textAlign: 'center',
|
|
155
|
+
flex: 1,
|
|
156
|
+
fontSize: 12,
|
|
157
|
+
includeFontPadding: false,
|
|
158
|
+
lineHeight: 16,
|
|
159
|
+
fontFamily: Platform.select({
|
|
160
|
+
android: 'monospace',
|
|
161
|
+
ios: 'Menlo',
|
|
162
|
+
windows: 'Consolas',
|
|
163
|
+
}),
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
export default LogBoxInspectorCodeFrame;
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
* @flow strict-local
|
|
8
|
+
* @format
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import type {ImageSource} from '../../Image/ImageSource';
|
|
12
|
+
import type {LogLevel} from '../Data/LogBoxLog';
|
|
13
|
+
|
|
14
|
+
import StatusBar from '../../Components/StatusBar/StatusBar';
|
|
15
|
+
import View from '../../Components/View/View';
|
|
16
|
+
import Image from '../../Image/Image';
|
|
17
|
+
import StyleSheet from '../../StyleSheet/StyleSheet';
|
|
18
|
+
import Text from '../../Text/Text';
|
|
19
|
+
import Platform from '../../Utilities/Platform';
|
|
20
|
+
import LogBoxButton from './LogBoxButton';
|
|
21
|
+
import * as LogBoxStyle from './LogBoxStyle';
|
|
22
|
+
import * as React from 'react';
|
|
23
|
+
type Props = $ReadOnly<{|
|
|
24
|
+
onSelectIndex: (selectedIndex: number) => void,
|
|
25
|
+
selectedIndex: number,
|
|
26
|
+
total: number,
|
|
27
|
+
level: LogLevel,
|
|
28
|
+
|}>;
|
|
29
|
+
|
|
30
|
+
function LogBoxInspectorHeader(props: Props): React.Node {
|
|
31
|
+
if (props.level === 'syntax') {
|
|
32
|
+
return (
|
|
33
|
+
<View style={[styles.safeArea, styles[props.level]]}>
|
|
34
|
+
<View style={styles.header}>
|
|
35
|
+
<View style={styles.title}>
|
|
36
|
+
<Text style={styles.titleText}>Failed to compile</Text>
|
|
37
|
+
</View>
|
|
38
|
+
</View>
|
|
39
|
+
</View>
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const prevIndex =
|
|
44
|
+
props.selectedIndex - 1 < 0 ? props.total - 1 : props.selectedIndex - 1;
|
|
45
|
+
const nextIndex =
|
|
46
|
+
props.selectedIndex + 1 > props.total - 1 ? 0 : props.selectedIndex + 1;
|
|
47
|
+
|
|
48
|
+
const titleText = `Log ${props.selectedIndex + 1} of ${props.total}`;
|
|
49
|
+
|
|
50
|
+
return (
|
|
51
|
+
<View style={[styles.safeArea, styles[props.level]]}>
|
|
52
|
+
<View style={styles.header}>
|
|
53
|
+
<LogBoxInspectorHeaderButton
|
|
54
|
+
disabled={props.total <= 1}
|
|
55
|
+
level={props.level}
|
|
56
|
+
image={require('./LogBoxImages/chevron-left.png')}
|
|
57
|
+
onPress={() => props.onSelectIndex(prevIndex)}
|
|
58
|
+
/>
|
|
59
|
+
<View style={styles.title}>
|
|
60
|
+
<Text style={styles.titleText}>{titleText}</Text>
|
|
61
|
+
</View>
|
|
62
|
+
<LogBoxInspectorHeaderButton
|
|
63
|
+
disabled={props.total <= 1}
|
|
64
|
+
level={props.level}
|
|
65
|
+
image={require('./LogBoxImages/chevron-right.png')}
|
|
66
|
+
onPress={() => props.onSelectIndex(nextIndex)}
|
|
67
|
+
/>
|
|
68
|
+
</View>
|
|
69
|
+
</View>
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const backgroundForLevel = (level: LogLevel) =>
|
|
74
|
+
({
|
|
75
|
+
warn: {
|
|
76
|
+
default: 'transparent',
|
|
77
|
+
pressed: LogBoxStyle.getWarningDarkColor(),
|
|
78
|
+
},
|
|
79
|
+
error: {
|
|
80
|
+
default: 'transparent',
|
|
81
|
+
pressed: LogBoxStyle.getErrorDarkColor(),
|
|
82
|
+
},
|
|
83
|
+
fatal: {
|
|
84
|
+
default: 'transparent',
|
|
85
|
+
pressed: LogBoxStyle.getFatalDarkColor(),
|
|
86
|
+
},
|
|
87
|
+
syntax: {
|
|
88
|
+
default: 'transparent',
|
|
89
|
+
pressed: LogBoxStyle.getFatalDarkColor(),
|
|
90
|
+
},
|
|
91
|
+
}[level]);
|
|
92
|
+
|
|
93
|
+
function LogBoxInspectorHeaderButton(
|
|
94
|
+
props: $ReadOnly<{|
|
|
95
|
+
disabled: boolean,
|
|
96
|
+
image: ImageSource,
|
|
97
|
+
level: LogLevel,
|
|
98
|
+
onPress?: ?() => void,
|
|
99
|
+
|}>,
|
|
100
|
+
): React.Node {
|
|
101
|
+
return (
|
|
102
|
+
<LogBoxButton
|
|
103
|
+
backgroundColor={backgroundForLevel(props.level)}
|
|
104
|
+
onPress={props.disabled ? null : props.onPress}
|
|
105
|
+
style={headerStyles.button}>
|
|
106
|
+
{props.disabled ? null : (
|
|
107
|
+
<Image source={props.image} style={headerStyles.buttonImage} />
|
|
108
|
+
)}
|
|
109
|
+
</LogBoxButton>
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
const headerStyles = StyleSheet.create({
|
|
114
|
+
button: {
|
|
115
|
+
alignItems: 'center',
|
|
116
|
+
aspectRatio: 1,
|
|
117
|
+
justifyContent: 'center',
|
|
118
|
+
marginTop: 5,
|
|
119
|
+
marginRight: 6,
|
|
120
|
+
marginLeft: 6,
|
|
121
|
+
marginBottom: -8,
|
|
122
|
+
borderRadius: 3,
|
|
123
|
+
},
|
|
124
|
+
buttonImage: {
|
|
125
|
+
height: 14,
|
|
126
|
+
width: 8,
|
|
127
|
+
tintColor: LogBoxStyle.getTextColor(),
|
|
128
|
+
},
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
const styles = StyleSheet.create({
|
|
132
|
+
syntax: {
|
|
133
|
+
backgroundColor: LogBoxStyle.getFatalColor(),
|
|
134
|
+
},
|
|
135
|
+
fatal: {
|
|
136
|
+
backgroundColor: LogBoxStyle.getFatalColor(),
|
|
137
|
+
},
|
|
138
|
+
warn: {
|
|
139
|
+
backgroundColor: LogBoxStyle.getWarningColor(),
|
|
140
|
+
},
|
|
141
|
+
error: {
|
|
142
|
+
backgroundColor: LogBoxStyle.getErrorColor(),
|
|
143
|
+
},
|
|
144
|
+
header: {
|
|
145
|
+
flexDirection: 'row',
|
|
146
|
+
// $FlowFixMe[underconstrained-implicit-instantiation]
|
|
147
|
+
height: Platform.select({
|
|
148
|
+
android: 48,
|
|
149
|
+
ios: 44,
|
|
150
|
+
// [Windows
|
|
151
|
+
windows: 48,
|
|
152
|
+
// Windows]
|
|
153
|
+
}),
|
|
154
|
+
},
|
|
155
|
+
title: {
|
|
156
|
+
alignItems: 'center',
|
|
157
|
+
flex: 1,
|
|
158
|
+
justifyContent: 'center',
|
|
159
|
+
},
|
|
160
|
+
titleText: {
|
|
161
|
+
color: LogBoxStyle.getTextColor(),
|
|
162
|
+
fontSize: 16,
|
|
163
|
+
fontWeight: '600',
|
|
164
|
+
includeFontPadding: false,
|
|
165
|
+
lineHeight: 20,
|
|
166
|
+
},
|
|
167
|
+
safeArea: {
|
|
168
|
+
paddingTop: Platform.OS === 'android' ? StatusBar.currentHeight : 40,
|
|
169
|
+
},
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
export default LogBoxInspectorHeader;
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
* @flow strict-local
|
|
8
|
+
* @format
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import type LogBoxLog from '../Data/LogBoxLog';
|
|
12
|
+
|
|
13
|
+
import View from '../../Components/View/View';
|
|
14
|
+
import openFileInEditor from '../../Core/Devtools/openFileInEditor';
|
|
15
|
+
import StyleSheet from '../../StyleSheet/StyleSheet';
|
|
16
|
+
import Text from '../../Text/Text';
|
|
17
|
+
import Platform from '../../Utilities/Platform';
|
|
18
|
+
import LogBoxButton from './LogBoxButton';
|
|
19
|
+
import LogBoxInspectorSection from './LogBoxInspectorSection';
|
|
20
|
+
import * as LogBoxStyle from './LogBoxStyle';
|
|
21
|
+
import * as React from 'react';
|
|
22
|
+
|
|
23
|
+
type Props = $ReadOnly<{|
|
|
24
|
+
log: LogBoxLog,
|
|
25
|
+
|}>;
|
|
26
|
+
|
|
27
|
+
const BEFORE_SLASH_RE = /^(.*)[\\/]/;
|
|
28
|
+
|
|
29
|
+
// Taken from React https://github.com/facebook/react/blob/206d61f72214e8ae5b935f0bf8628491cb7f0797/packages/react-devtools-shared/src/backend/describeComponentFrame.js#L27-L41
|
|
30
|
+
function getPrettyFileName(path: string) {
|
|
31
|
+
let fileName = path.replace(BEFORE_SLASH_RE, '');
|
|
32
|
+
|
|
33
|
+
// In DEV, include code for a common special case:
|
|
34
|
+
// prefer "folder/index.js" instead of just "index.js".
|
|
35
|
+
if (/^index\./.test(fileName)) {
|
|
36
|
+
const match = path.match(BEFORE_SLASH_RE);
|
|
37
|
+
if (match) {
|
|
38
|
+
const pathBeforeSlash = match[1];
|
|
39
|
+
if (pathBeforeSlash) {
|
|
40
|
+
const folderName = pathBeforeSlash.replace(BEFORE_SLASH_RE, '');
|
|
41
|
+
// Note the below string contains a zero width space after the "/" character.
|
|
42
|
+
// This is to prevent browsers like Chrome from formatting the file name as a link.
|
|
43
|
+
// (Since this is a source link, it would not work to open the source file anyway.)
|
|
44
|
+
fileName = folderName + '/' + fileName;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return fileName;
|
|
50
|
+
}
|
|
51
|
+
function LogBoxInspectorReactFrames(props: Props): React.Node {
|
|
52
|
+
const [collapsed, setCollapsed] = React.useState(true);
|
|
53
|
+
if (props.log.componentStack == null || props.log.componentStack.length < 1) {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
function getStackList() {
|
|
58
|
+
if (collapsed) {
|
|
59
|
+
return props.log.componentStack.slice(0, 3);
|
|
60
|
+
} else {
|
|
61
|
+
return props.log.componentStack;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function getCollapseMessage() {
|
|
66
|
+
if (props.log.componentStack.length <= 3) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
const count = props.log.componentStack.length - 3;
|
|
71
|
+
if (collapsed) {
|
|
72
|
+
return `See ${count} more components`;
|
|
73
|
+
} else {
|
|
74
|
+
return `Collapse ${count} components`;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
return (
|
|
79
|
+
<LogBoxInspectorSection heading="Component Stack">
|
|
80
|
+
{getStackList().map((frame, index) => (
|
|
81
|
+
<View
|
|
82
|
+
// Unfortunately we don't have a unique identifier for stack traces.
|
|
83
|
+
key={index}
|
|
84
|
+
style={componentStyles.frameContainer}>
|
|
85
|
+
<LogBoxButton
|
|
86
|
+
backgroundColor={{
|
|
87
|
+
default: 'transparent',
|
|
88
|
+
pressed: LogBoxStyle.getBackgroundColor(1),
|
|
89
|
+
}}
|
|
90
|
+
onPress={
|
|
91
|
+
// Older versions of DevTools do not provide full path.
|
|
92
|
+
// This will not work on Windows, remove check once the
|
|
93
|
+
// DevTools return the full file path.
|
|
94
|
+
frame.fileName.startsWith('/')
|
|
95
|
+
? () =>
|
|
96
|
+
openFileInEditor(frame.fileName, frame.location?.row ?? 1)
|
|
97
|
+
: null
|
|
98
|
+
}
|
|
99
|
+
style={componentStyles.frame}>
|
|
100
|
+
<View style={componentStyles.component}>
|
|
101
|
+
<Text style={componentStyles.frameName}>
|
|
102
|
+
<Text style={componentStyles.bracket}>{'<'}</Text>
|
|
103
|
+
{frame.content}
|
|
104
|
+
<Text style={componentStyles.bracket}>{' />'}</Text>
|
|
105
|
+
</Text>
|
|
106
|
+
</View>
|
|
107
|
+
<Text style={componentStyles.frameLocation}>
|
|
108
|
+
{getPrettyFileName(frame.fileName)}
|
|
109
|
+
{frame.location ? `:${frame.location.row}` : ''}
|
|
110
|
+
</Text>
|
|
111
|
+
</LogBoxButton>
|
|
112
|
+
</View>
|
|
113
|
+
))}
|
|
114
|
+
<View style={componentStyles.collapseContainer}>
|
|
115
|
+
<LogBoxButton
|
|
116
|
+
backgroundColor={{
|
|
117
|
+
default: 'transparent',
|
|
118
|
+
pressed: LogBoxStyle.getBackgroundColor(1),
|
|
119
|
+
}}
|
|
120
|
+
onPress={() => setCollapsed(!collapsed)}
|
|
121
|
+
style={componentStyles.collapseButton}>
|
|
122
|
+
<Text style={componentStyles.collapse}>{getCollapseMessage()}</Text>
|
|
123
|
+
</LogBoxButton>
|
|
124
|
+
</View>
|
|
125
|
+
</LogBoxInspectorSection>
|
|
126
|
+
);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
const componentStyles = StyleSheet.create({
|
|
130
|
+
collapseContainer: {
|
|
131
|
+
marginLeft: 15,
|
|
132
|
+
flexDirection: 'row',
|
|
133
|
+
},
|
|
134
|
+
collapseButton: {
|
|
135
|
+
borderRadius: 5,
|
|
136
|
+
},
|
|
137
|
+
collapse: {
|
|
138
|
+
color: LogBoxStyle.getTextColor(0.7),
|
|
139
|
+
fontSize: 12,
|
|
140
|
+
fontWeight: '300',
|
|
141
|
+
lineHeight: 20,
|
|
142
|
+
marginTop: 0,
|
|
143
|
+
paddingVertical: 5,
|
|
144
|
+
paddingHorizontal: 10,
|
|
145
|
+
},
|
|
146
|
+
frameContainer: {
|
|
147
|
+
flexDirection: 'row',
|
|
148
|
+
paddingHorizontal: 15,
|
|
149
|
+
},
|
|
150
|
+
frame: {
|
|
151
|
+
flex: 1,
|
|
152
|
+
paddingVertical: 4,
|
|
153
|
+
paddingHorizontal: 10,
|
|
154
|
+
borderRadius: 5,
|
|
155
|
+
},
|
|
156
|
+
component: {
|
|
157
|
+
flexDirection: 'row',
|
|
158
|
+
paddingRight: 10,
|
|
159
|
+
},
|
|
160
|
+
frameName: {
|
|
161
|
+
fontFamily: Platform.select({
|
|
162
|
+
android: 'monospace',
|
|
163
|
+
ios: 'Menlo',
|
|
164
|
+
windows: 'Consolas',
|
|
165
|
+
}),
|
|
166
|
+
color: LogBoxStyle.getTextColor(1),
|
|
167
|
+
fontSize: 14,
|
|
168
|
+
includeFontPadding: false,
|
|
169
|
+
lineHeight: 18,
|
|
170
|
+
},
|
|
171
|
+
bracket: {
|
|
172
|
+
fontFamily: Platform.select({
|
|
173
|
+
android: 'monospace',
|
|
174
|
+
ios: 'Menlo',
|
|
175
|
+
windows: 'Consolas',
|
|
176
|
+
}),
|
|
177
|
+
color: LogBoxStyle.getTextColor(0.4),
|
|
178
|
+
fontSize: 14,
|
|
179
|
+
fontWeight: '500',
|
|
180
|
+
includeFontPadding: false,
|
|
181
|
+
lineHeight: 18,
|
|
182
|
+
},
|
|
183
|
+
frameLocation: {
|
|
184
|
+
color: LogBoxStyle.getTextColor(0.7),
|
|
185
|
+
fontSize: 12,
|
|
186
|
+
fontWeight: '300',
|
|
187
|
+
includeFontPadding: false,
|
|
188
|
+
lineHeight: 16,
|
|
189
|
+
paddingLeft: 10,
|
|
190
|
+
},
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
export default LogBoxInspectorReactFrames;
|
|
@@ -19,10 +19,10 @@ import LogBoxButton from './LogBoxButton';
|
|
|
19
19
|
import * as LogBoxStyle from './LogBoxStyle';
|
|
20
20
|
import * as React from 'react';
|
|
21
21
|
|
|
22
|
-
type Props = $ReadOnly<{
|
|
22
|
+
type Props = $ReadOnly<{
|
|
23
23
|
frame: StackFrame,
|
|
24
24
|
onPress?: ?(event: PressEvent) => void,
|
|
25
|
-
|
|
25
|
+
}>;
|
|
26
26
|
|
|
27
27
|
function LogBoxInspectorStackFrame(props: Props): React.Node {
|
|
28
28
|
const {frame, onPress} = props;
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
* @flow strict-local
|
|
8
|
+
* @format
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import type {StackFrame} from '../../Core/NativeExceptionsManager';
|
|
12
|
+
import type {PressEvent} from '../../Types/CoreEventTypes';
|
|
13
|
+
|
|
14
|
+
import View from '../../Components/View/View';
|
|
15
|
+
import StyleSheet from '../../StyleSheet/StyleSheet';
|
|
16
|
+
import Text from '../../Text/Text';
|
|
17
|
+
import Platform from '../../Utilities/Platform';
|
|
18
|
+
import LogBoxButton from './LogBoxButton';
|
|
19
|
+
import * as LogBoxStyle from './LogBoxStyle';
|
|
20
|
+
import * as React from 'react';
|
|
21
|
+
|
|
22
|
+
type Props = $ReadOnly<{
|
|
23
|
+
frame: StackFrame,
|
|
24
|
+
onPress?: ?(event: PressEvent) => void,
|
|
25
|
+
}>;
|
|
26
|
+
|
|
27
|
+
function LogBoxInspectorStackFrame(props: Props): React.Node {
|
|
28
|
+
const {frame, onPress} = props;
|
|
29
|
+
const column = frame.column != null && parseInt(frame.column, 10);
|
|
30
|
+
const location =
|
|
31
|
+
getFileName(frame.file) +
|
|
32
|
+
(frame.lineNumber != null
|
|
33
|
+
? ':' +
|
|
34
|
+
frame.lineNumber +
|
|
35
|
+
(column && !isNaN(column) ? ':' + (column + 1) : '')
|
|
36
|
+
: '');
|
|
37
|
+
return (
|
|
38
|
+
<View style={styles.frameContainer}>
|
|
39
|
+
<LogBoxButton
|
|
40
|
+
backgroundColor={{
|
|
41
|
+
default: 'transparent',
|
|
42
|
+
pressed: onPress ? LogBoxStyle.getBackgroundColor(1) : 'transparent',
|
|
43
|
+
}}
|
|
44
|
+
onPress={onPress}
|
|
45
|
+
style={styles.frame}>
|
|
46
|
+
<Text style={[styles.name, frame.collapse === true && styles.dim]}>
|
|
47
|
+
{frame.methodName}
|
|
48
|
+
</Text>
|
|
49
|
+
<Text
|
|
50
|
+
ellipsizeMode="middle"
|
|
51
|
+
numberOfLines={1}
|
|
52
|
+
style={[styles.location, frame.collapse === true && styles.dim]}>
|
|
53
|
+
{location}
|
|
54
|
+
</Text>
|
|
55
|
+
</LogBoxButton>
|
|
56
|
+
</View>
|
|
57
|
+
);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
function getFileName(file: ?string) {
|
|
61
|
+
if (file == null) {
|
|
62
|
+
return '<unknown>';
|
|
63
|
+
}
|
|
64
|
+
const queryIndex = file.indexOf('?');
|
|
65
|
+
return file.substring(
|
|
66
|
+
file.lastIndexOf('/') + 1,
|
|
67
|
+
queryIndex === -1 ? file.length : queryIndex,
|
|
68
|
+
);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const styles = StyleSheet.create({
|
|
72
|
+
frameContainer: {
|
|
73
|
+
flexDirection: 'row',
|
|
74
|
+
paddingHorizontal: 15,
|
|
75
|
+
},
|
|
76
|
+
frame: {
|
|
77
|
+
flex: 1,
|
|
78
|
+
paddingVertical: 4,
|
|
79
|
+
paddingHorizontal: 10,
|
|
80
|
+
borderRadius: 5,
|
|
81
|
+
},
|
|
82
|
+
lineLocation: {
|
|
83
|
+
flexDirection: 'row',
|
|
84
|
+
},
|
|
85
|
+
name: {
|
|
86
|
+
color: LogBoxStyle.getTextColor(1),
|
|
87
|
+
fontSize: 14,
|
|
88
|
+
includeFontPadding: false,
|
|
89
|
+
lineHeight: 18,
|
|
90
|
+
fontWeight: '400',
|
|
91
|
+
fontFamily: Platform.select({
|
|
92
|
+
android: 'monospace',
|
|
93
|
+
ios: 'Menlo',
|
|
94
|
+
windows: 'Consolas',
|
|
95
|
+
}),
|
|
96
|
+
},
|
|
97
|
+
location: {
|
|
98
|
+
color: LogBoxStyle.getTextColor(0.8),
|
|
99
|
+
fontSize: 12,
|
|
100
|
+
fontWeight: '300',
|
|
101
|
+
includeFontPadding: false,
|
|
102
|
+
lineHeight: 16,
|
|
103
|
+
paddingLeft: 10,
|
|
104
|
+
},
|
|
105
|
+
dim: {
|
|
106
|
+
color: LogBoxStyle.getTextColor(0.4),
|
|
107
|
+
fontWeight: '300',
|
|
108
|
+
},
|
|
109
|
+
line: {
|
|
110
|
+
color: LogBoxStyle.getTextColor(0.8),
|
|
111
|
+
fontSize: 12,
|
|
112
|
+
fontWeight: '300',
|
|
113
|
+
includeFontPadding: false,
|
|
114
|
+
lineHeight: 16,
|
|
115
|
+
},
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
export default LogBoxInspectorStackFrame;
|