From bd558bdbab8ac525146e4c424f5f75376abffb6e Mon Sep 17 00:00:00 2001 From: Cristiano Tofani Date: Thu, 5 Dec 2024 19:00:35 +0100 Subject: [PATCH] fix: Status banner contains extra space on header (#6510) --- ts/components/ui/IOScrollView.tsx | 16 ++++++++++++++-- ts/components/ui/IOScrollViewWithLargeHeader.tsx | 2 -- ts/hooks/useHeaderSecondLevel.tsx | 2 +- .../__tests__/cie/ActivateNfcScreen.test.tsx | 4 ++++ .../__test__/LanguagesPreferencesScreen.test.tsx | 5 +++++ 5 files changed, 24 insertions(+), 5 deletions(-) diff --git a/ts/components/ui/IOScrollView.tsx b/ts/components/ui/IOScrollView.tsx index 67ca0a9c719..a693e6a8173 100644 --- a/ts/components/ui/IOScrollView.tsx +++ b/ts/components/ui/IOScrollView.tsx @@ -44,6 +44,7 @@ import Animated, { } from "react-native-reanimated"; import { useSafeAreaInsets } from "react-native-safe-area-context"; import { WithTestID } from "../../types/WithTestID"; +import { useStatusAlertProps } from "../../hooks/useStatusAlertProps"; export type IOScrollViewActions = | { @@ -160,6 +161,7 @@ export const IOScrollView = ({ contentContainerStyle, testID }: IOScrollView) => { + const alertProps = useStatusAlertProps(); const theme = useIOTheme(); /* Navigation */ @@ -255,12 +257,22 @@ export const IOScrollView = ({ if (headerConfig) { navigation.setOptions({ header: () => ( - + ), headerTransparent: headerConfig.transparent }); } - }, [headerConfig, navigation, scrollPositionAbsolute, snapOffset]); + }, [ + headerConfig, + navigation, + scrollPositionAbsolute, + snapOffset, + alertProps + ]); const RefreshControlComponent = refreshControlProps ? ( diff --git a/ts/components/ui/IOScrollViewWithLargeHeader.tsx b/ts/components/ui/IOScrollViewWithLargeHeader.tsx index 7439b7f5fc6..44a377582ee 100644 --- a/ts/components/ui/IOScrollViewWithLargeHeader.tsx +++ b/ts/components/ui/IOScrollViewWithLargeHeader.tsx @@ -64,7 +64,6 @@ export const IOScrollViewWithLargeHeader = forwardRef( contextualHelp, contextualHelpMarkdown, faqCategories, - ignoreSafeAreaMargin = false, includeContentMargins = false, headerActionsProp = {}, excludeEndContentMargin, @@ -91,7 +90,6 @@ export const IOScrollViewWithLargeHeader = forwardRef( }; const headerProps: ComponentProps = { - ignoreSafeAreaMargin, ...useHeaderProps( canGoback ? { diff --git a/ts/hooks/useHeaderSecondLevel.tsx b/ts/hooks/useHeaderSecondLevel.tsx index ddcc319b81d..e916aa751c6 100644 --- a/ts/hooks/useHeaderSecondLevel.tsx +++ b/ts/hooks/useHeaderSecondLevel.tsx @@ -132,7 +132,6 @@ export const useHeaderSecondLevel = ({ const enableDiscreteTransitionProps = enableDiscreteTransition && animatedRef ? { - ignoreSafeAreaMargin: !!alertProps, enableDiscreteTransition, animatedRef } @@ -142,6 +141,7 @@ export const useHeaderSecondLevel = ({ scrollValues, variant, backgroundColor, + ignoreSafeAreaMargin: !!alertProps, ...enableDiscreteTransitionProps }; }, [ diff --git a/ts/screens/authentication/__tests__/cie/ActivateNfcScreen.test.tsx b/ts/screens/authentication/__tests__/cie/ActivateNfcScreen.test.tsx index dd3344140b9..bd673c83259 100644 --- a/ts/screens/authentication/__tests__/cie/ActivateNfcScreen.test.tsx +++ b/ts/screens/authentication/__tests__/cie/ActivateNfcScreen.test.tsx @@ -23,6 +23,10 @@ jest.mock("../../../../store/hooks", () => ({ useIOStore: jest.fn() })); +jest.mock("../../../../hooks/useStatusAlertProps", () => ({ + useStatusAlertProps: jest.fn() +})); + const mockNavigate = jest.fn(); const mockReplace = jest.fn(); jest.mock("@react-navigation/native", () => { diff --git a/ts/screens/profile/__test__/LanguagesPreferencesScreen.test.tsx b/ts/screens/profile/__test__/LanguagesPreferencesScreen.test.tsx index 9d4cdc62962..e5eece77712 100644 --- a/ts/screens/profile/__test__/LanguagesPreferencesScreen.test.tsx +++ b/ts/screens/profile/__test__/LanguagesPreferencesScreen.test.tsx @@ -17,6 +17,11 @@ jest.mock("../../../store/hooks", () => ({ useIOStore: jest.fn() })); +// Mock the useStatusAlertProps hook +jest.mock("../../../hooks/useStatusAlertProps", () => ({ + useStatusAlertProps: jest.fn() +})); + describe("LanguagesPreferencesScreen", () => { beforeAll(() => { jest.spyOn(Alert, "alert");