diff --git a/src/navigation-bar.css.ts b/src/navigation-bar.css.ts index 1581b038d..6acfa945a 100644 --- a/src/navigation-bar.css.ts +++ b/src/navigation-bar.css.ts @@ -369,36 +369,35 @@ export const burgerMenuButton = style({ }, }); -export const burgerMenu = style([ - sprinkles({ - position: 'fixed', - top: NAVBAR_HEIGHT_MOBILE, - left: 0, - right: 0, - background: vars.colors.background, - }), - { - height: `calc(100vh - ${NAVBAR_HEIGHT_MOBILE}px)`, - }, -]); +export const burgerMenu = sprinkles({ + position: 'fixed', + top: NAVBAR_HEIGHT_MOBILE, + left: 0, + right: 0, + bottom: 0, + background: vars.colors.background, +}); -export const burgerMainMenuContainer = style([ - sprinkles({overflowY: 'auto'}), - { - height: `calc(100vh - ${NAVBAR_HEIGHT_MOBILE}px)`, - }, -]); +export const burgerMenuContainer = sprinkles({ + height: '100%', + position: 'relative', +}); -export const burgerSubMenuContainer = style([ +export const burgerMenuContentContainer = style([ sprinkles({ overflowY: 'auto', width: '100%', + height: '100%', position: 'absolute', top: 0, }), { - height: `calc(100vh - ${NAVBAR_HEIGHT_MOBILE}px)`, - left: '100vw', + transition: `transform ${BURGER_MENU_ANIMATION_DURATION_MS}ms ease-out`, + '@media': { + ['(prefers-reduced-motion)']: { + transition: 'none', + }, + }, }, ]); diff --git a/src/navigation-bar.tsx b/src/navigation-bar.tsx index 2984cd4cc..ca41ecd59 100644 --- a/src/navigation-bar.tsx +++ b/src/navigation-bar.tsx @@ -644,15 +644,14 @@ const MainNavigationBarBurgerMenu = ({ nodeRef={menuContentRef} > {(transitionStatus) => ( -
- {transitionStatus !== 'entered' && ( -
+
+
+ {transitionStatus !== 'entered' && ( @@ -680,14 +679,19 @@ const MainNavigationBarBurgerMenu = ({ {extra && {extra}} -
- )} + )} +
- {transitionStatus !== 'exited' && openedSection !== -1 && ( -
- {renderSection(openedSection)} -
- )} +
+ {transitionStatus !== 'exited' && + openedSection !== -1 && + renderSection(openedSection)} +
)}