From 988e383a6246695d4638e30f5ed813189a4755ae Mon Sep 17 00:00:00 2001 From: Onkar Jadhav <56870381+Omkar76@users.noreply.github.com> Date: Thu, 28 Dec 2023 06:58:49 +0530 Subject: [PATCH] Fix mispositioned active link indicator (#6880) * Fix mispositioned active link indicator * Make indicator height 26% of link element height. * Extract 'navItemCount' as variable --- src/Components/Common/Sidebar/Sidebar.tsx | 56 +++----- src/Components/Common/Sidebar/SidebarItem.tsx | 126 ++++++++++-------- 2 files changed, 85 insertions(+), 97 deletions(-) diff --git a/src/Components/Common/Sidebar/Sidebar.tsx b/src/Components/Common/Sidebar/Sidebar.tsx index 10b5c6d04fa..fa809571772 100644 --- a/src/Components/Common/Sidebar/Sidebar.tsx +++ b/src/Components/Common/Sidebar/Sidebar.tsx @@ -55,61 +55,36 @@ const StatelessSidebar = ({ const { dashboard_url } = useConfig(); const indicatorRef = useRef(null); + const activeLinkRef = useRef(null); const [lastIndicatorPosition, setLastIndicatorPosition] = useState(0); const [isOverflowVisible, setOverflowVisisble] = useState(false); useEffect(() => { if (!indicatorRef.current) return; const index = NavItems.findIndex((item) => item.to === activeLink); + const navItemCount = NavItems.length + 2; // +2 for notification and dashboard if (index !== -1) { // Haha math go brrrrrrrrr const e = indicatorRef.current; - - const itemHeight = 44; - const bottomItemOffset = 2; - - const indexDifference = index - lastIndicatorPosition; - e.style.display = "block"; - - if (indexDifference > 0) { - e.style.top = lastIndicatorPosition * itemHeight + 16 + "px"; - e.style.bottom = "auto"; + const itemHeight = activeLinkRef.current?.clientHeight || 0; + if (lastIndicatorPosition > index) { + e.style.top = `${itemHeight * (index + 0.37)}px`; + setTimeout(() => { + e.style.bottom = `${itemHeight * (navItemCount - 0.63 - index)}px`; + }, 50); } else { - e.style.bottom = - itemHeight * (NavItems.length + bottomItemOffset) - - lastIndicatorPosition * itemHeight - - 28 + - "px"; - e.style.top = "auto"; + e.style.bottom = `${itemHeight * (navItemCount - 0.63 - index)}px`; + setTimeout(() => { + e.style.top = `${itemHeight * (index + 0.37)}px`; + }, 50); } - - const variableHeight = Math.min( - Math.abs(indexDifference) * itemHeight, - 70 - ); - - e.style.height = `${variableHeight}px`; - setTimeout(() => { - if (!e) return; - if (indexDifference > 0) { - e.style.top = index * itemHeight + 16 + "px"; - e.style.bottom = "auto"; - } else { - e.style.bottom = - itemHeight * (NavItems.length + bottomItemOffset) - - index * itemHeight - - 28 + - "px"; - e.style.top = "auto"; - } - e.style.height = "0.75rem"; - setLastIndicatorPosition(index); - }, 300); + setLastIndicatorPosition(index); } else { indicatorRef.current.style.display = "none"; } - }, [activeLink]); + }, [activeLink, lastIndicatorPosition]); + const handleOverflow = (value: boolean) => { setOverflowVisisble(value); }; @@ -147,6 +122,7 @@ const StatelessSidebar = ({ {NavItems.map((i) => { return ( } diff --git a/src/Components/Common/Sidebar/SidebarItem.tsx b/src/Components/Common/Sidebar/SidebarItem.tsx index e13a1452125..20ffec4217e 100644 --- a/src/Components/Common/Sidebar/SidebarItem.tsx +++ b/src/Components/Common/Sidebar/SidebarItem.tsx @@ -2,10 +2,12 @@ import { Link } from "raviger"; import { useTranslation } from "react-i18next"; import CareIcon from "../../../CAREUI/icons/CareIcon"; import useAppHistory from "../../../Common/hooks/useAppHistory"; +import React, { forwardRef, Ref } from "react"; export type SidebarIcon = React.ReactNode; type SidebarItemProps = { + ref?: React.Ref; text: string; icon: SidebarIcon; external?: true | undefined; @@ -14,74 +16,84 @@ type SidebarItemProps = { handleOverflow?: any; } & ({ to: string; do?: undefined } | { to?: string; do: () => void }); -type SidebarItemBaseProps = SidebarItemProps & { shrinked?: boolean }; -const SidebarItemBase = ({ - shrinked, - external, - ...props -}: SidebarItemBaseProps) => { - const { t } = useTranslation(); - const { resetHistory } = useAppHistory(); +type SidebarItemBaseProps = SidebarItemProps & { + shrinked?: boolean; + ref: Ref; +}; + +const SidebarItemBase = forwardRef( + ( + { shrinked, external, ...props }: SidebarItemBaseProps, + ref: Ref + ) => { + const { t } = useTranslation(); + const { resetHistory } = useAppHistory(); - return ( - { - props.handleOverflow(true); - }} - onMouseLeave={() => { - props.handleOverflow(false); - }} - > - - {t(props.text)} - -
{ + props.handleOverflow(true); + }} + onMouseLeave={() => { + props.handleOverflow(false); + }} > -
{props.icon}
- + {t(props.text)} - {external && !shrinked && ( - - )} -
- - {!!props.badgeCount && ( - - {props.badgeCount > 9 ? "9+" : props.badgeCount} - - )} - - ); -}; +
{props.icon}
+ + {t(props.text)} + + {external && !shrinked && ( + + )} + + + {!!props.badgeCount && ( + + {props.badgeCount > 9 ? "9+" : props.badgeCount} + + )} + + ); + } +); -export const SidebarItem = (props: SidebarItemProps) => ( - +export const SidebarItem = forwardRef( + (props: SidebarItemProps, ref: Ref) => ( + + ) ); -export const ShrinkedSidebarItem = (props: SidebarItemProps) => ( - +export const ShrinkedSidebarItem = forwardRef( + (props: SidebarItemProps, ref: Ref) => ( + + ) );