From 1969ec3178879cee11c906be6141ff07201a1f11 Mon Sep 17 00:00:00 2001 From: Robin Cussol Date: Thu, 5 Dec 2024 15:09:53 +0100 Subject: [PATCH] feat(NavigationBar): allow for transparent background when at the top of the screen This was requested on Slack. --- .../NavigationBar/NavigationBar.stories.tsx | 1 + .../src/NavigationBar/index.tsx | 21 ++++++++++++++----- .../src/NavigationBar/types.d.ts | 1 + 3 files changed, 18 insertions(+), 5 deletions(-) diff --git a/packages/orbit-components/src/NavigationBar/NavigationBar.stories.tsx b/packages/orbit-components/src/NavigationBar/NavigationBar.stories.tsx index bf7f88ce48..4c32fa35a6 100644 --- a/packages/orbit-components/src/NavigationBar/NavigationBar.stories.tsx +++ b/packages/orbit-components/src/NavigationBar/NavigationBar.stories.tsx @@ -33,6 +33,7 @@ const meta: Meta = { onShow: action("onShow"), onHide: action("onHide"), bottomStyle: "shadow", + transparentBgAtTop: false, }, argTypes: { diff --git a/packages/orbit-components/src/NavigationBar/index.tsx b/packages/orbit-components/src/NavigationBar/index.tsx index 907bb9ee83..a8946bb15a 100644 --- a/packages/orbit-components/src/NavigationBar/index.tsx +++ b/packages/orbit-components/src/NavigationBar/index.tsx @@ -20,6 +20,7 @@ const NavigationBar = ({ onHide, hideOnScroll = true, bottomStyle = "shadow", + transparentBgAtTop = false, }: Props) => { const resolveCallback = React.useCallback( state => { @@ -31,6 +32,7 @@ const NavigationBar = ({ const [shown, setShown] = useStateWithCallback(true, resolveCallback); const [prevScrollPosition, setPrevScrollPosition] = React.useState(0); + const [isTransparentBg, setTransparentBg] = React.useState(transparentBgAtTop); const handleNavigationBarPosition = React.useCallback(() => { const currentScrollPosition = @@ -38,6 +40,10 @@ const NavigationBar = ({ window.pageYOffset || (document.documentElement && document.documentElement.scrollTop); + if (transparentBgAtTop) { + setTransparentBg(currentScrollPosition <= 0); + } + if (!hideOnScroll) return; if ( @@ -50,7 +56,7 @@ const NavigationBar = ({ } setPrevScrollPosition(currentScrollPosition); - }, [prevScrollPosition, setShown, hideOnScroll]); + }, [prevScrollPosition, setShown, hideOnScroll, transparentBgAtTop, setTransparentBg]); React.useEffect(() => { window.addEventListener("scroll", handleNavigationBarPosition); @@ -64,12 +70,17 @@ const NavigationBar = ({ data-test={dataTest} id={id} className={cx( - "bg-white-normal p-300 z-navigation-bar fixed inset-x-0 top-0 box-border flex w-full translate-x-0 items-center", - "duration-normal transform-gpu transition-transform ease-in-out", + "p-300 z-navigation-bar fixed inset-x-0 top-0 box-border flex w-full translate-x-0 items-center", + "duration-normal transform-gpu ease-in-out", + transparentBgAtTop + ? "transition-[transform_background-color_border-color]" + : "transition-transform", "tb:h-1600 h-[52px]", // As defined on the const above shown ? "translate-y-0" : "tb:-translate-y-1600 translate-y-[-52px]", // As defined on the const above - bottomStyle === "shadow" && "shadow-fixed", - bottomStyle === "border" && "border-cloud-normal border-b", + !isTransparentBg && bottomStyle === "shadow" && "shadow-fixed", + isTransparentBg && bottomStyle === "border" && "border-transparent", // important for the transition to work well + !isTransparentBg && bottomStyle === "border" && "border-cloud-normal border-b", + isTransparentBg ? "bg-transparent" : "bg-white-normal", )} >
{children}
diff --git a/packages/orbit-components/src/NavigationBar/types.d.ts b/packages/orbit-components/src/NavigationBar/types.d.ts index 50aa826ea4..615368ff8b 100644 --- a/packages/orbit-components/src/NavigationBar/types.d.ts +++ b/packages/orbit-components/src/NavigationBar/types.d.ts @@ -12,4 +12,5 @@ export interface Props extends Common.Globals { readonly openTitle?: string; readonly hideOnScroll?: boolean; readonly bottomStyle?: "shadow" | "border"; + transparentBgAtTop?: boolean; }