From 9554450446f41878cb198b66ff0ca18986da1908 Mon Sep 17 00:00:00 2001 From: Cee Chen <549407+cee-chen@users.noreply.github.com> Date: Tue, 3 Oct 2023 11:10:19 -0700 Subject: [PATCH] [EuiCollapsibleNavBeta] Add global CSS variable for width offset (#7248) --- .../collapsible_nav_beta.stories.tsx | 19 +++++++++++++++++++ .../collapsible_nav_beta.tsx | 18 ++++++++++++++++-- 2 files changed, 35 insertions(+), 2 deletions(-) diff --git a/src/components/collapsible_nav_beta/collapsible_nav_beta.stories.tsx b/src/components/collapsible_nav_beta/collapsible_nav_beta.stories.tsx index b8a21163188..15c1b1148f7 100644 --- a/src/components/collapsible_nav_beta/collapsible_nav_beta.stories.tsx +++ b/src/components/collapsible_nav_beta/collapsible_nav_beta.stories.tsx @@ -11,6 +11,7 @@ import type { Meta, StoryObj } from '@storybook/react'; import { EuiHeader, EuiHeaderSection, EuiHeaderSectionItem } from '../header'; import { EuiPageTemplate } from '../page_template'; +import { EuiBottomBar } from '../bottom_bar'; import { EuiFlyout } from '../flyout'; import { EuiButton } from '../button'; import { EuiTitle } from '../title'; @@ -469,6 +470,24 @@ export const FlyoutInFixedHeaders: Story = { }, }; +export const GlobalCSSVariable: Story = { + render: ({ ...args }) => ( + <> + + + + This story tests the global `--euiCollapsibleNavOffset` CSS variable + + + + + This text should be visible at all times and the bar position should + update dynamically based on the nav width (including on mobile) + + + ), +}; + export const CollapsedStateInLocalStorage: Story = { render: () => { const key = 'EuiCollapsibleNav__isCollapsed'; diff --git a/src/components/collapsible_nav_beta/collapsible_nav_beta.tsx b/src/components/collapsible_nav_beta/collapsible_nav_beta.tsx index 5d3a62e91a7..121e594b47d 100644 --- a/src/components/collapsible_nav_beta/collapsible_nav_beta.tsx +++ b/src/components/collapsible_nav_beta/collapsible_nav_beta.tsx @@ -18,7 +18,12 @@ import React, { } from 'react'; import classNames from 'classnames'; -import { useEuiTheme, useGeneratedHtmlId, throttle } from '../../services'; +import { + useEuiTheme, + useEuiThemeCSSVariables, + useGeneratedHtmlId, + throttle, +} from '../../services'; import { CommonProps } from '../common'; import { EuiFlyout, EuiFlyoutProps } from '../flyout'; @@ -88,6 +93,7 @@ const _EuiCollapsibleNavBeta: FunctionComponent = ({ focusTrapProps: _focusTrapProps, ...rest }) => { + const { setGlobalCSSVariables } = useEuiThemeCSSVariables(); const euiTheme = useEuiTheme(); const headerHeight = euiHeaderVariables(euiTheme).height; @@ -138,9 +144,17 @@ const _EuiCollapsibleNavBeta: FunctionComponent = ({ const width = useMemo(() => { if (isOverlayFullWidth) return '100%'; if (isPush && isCollapsed) return headerHeight; - return _width; + return `${_width}px`; }, [_width, isOverlayFullWidth, isPush, isCollapsed, headerHeight]); + // Other UI elements may need to account for the nav width - + // set a global CSS variable that they can use + useEffect(() => { + setGlobalCSSVariables({ + '--euiCollapsibleNavOffset': isOverlay ? '0' : width, + }); + }, [width, isOverlay, setGlobalCSSVariables]); + /** * Prop setup */