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
*/