From 1ff0d0dbcfd1a4c12ded88ace9aff8a04223e0fc Mon Sep 17 00:00:00 2001 From: Onkar Jadhav Date: Wed, 20 Dec 2023 11:14:19 +0530 Subject: [PATCH 1/3] Fix mispositioned active link indicator --- src/Components/Common/Sidebar/Sidebar.tsx | 52 ++------ src/Components/Common/Sidebar/SidebarItem.tsx | 126 ++++++++++-------- 2 files changed, 82 insertions(+), 96 deletions(-) diff --git a/src/Components/Common/Sidebar/Sidebar.tsx b/src/Components/Common/Sidebar/Sidebar.tsx index 10b5c6d04fa..69ab9b226f9 100644 --- a/src/Components/Common/Sidebar/Sidebar.tsx +++ b/src/Components/Common/Sidebar/Sidebar.tsx @@ -55,6 +55,7 @@ const StatelessSidebar = ({ const { dashboard_url } = useConfig(); const indicatorRef = useRef(null); + const activeLinkRef = useRef(null); const [lastIndicatorPosition, setLastIndicatorPosition] = useState(0); const [isOverflowVisible, setOverflowVisisble] = useState(false); @@ -65,47 +66,19 @@ const StatelessSidebar = ({ // 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.3 * itemHeight}px`; + setTimeout(() => { + e.style.bottom = `${itemHeight * (NavItems.length - index + 1.3)}px`; + }, 50); } else { - e.style.bottom = - itemHeight * (NavItems.length + bottomItemOffset) - - lastIndicatorPosition * itemHeight - - 28 + - "px"; - e.style.top = "auto"; + e.style.bottom = `${itemHeight * (NavItems.length - index + 1.3)}px`; + setTimeout(() => { + e.style.top = `${itemHeight * index + 0.3 * itemHeight}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"; } @@ -147,6 +120,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) => ( + + ) ); From 4790327cb2c571dc59ccb7da3f0d11320185655b Mon Sep 17 00:00:00 2001 From: Onkar Jadhav Date: Sun, 24 Dec 2023 19:33:08 +0530 Subject: [PATCH 2/3] Make indicator height 26% of link element height. --- src/Components/Common/Sidebar/Sidebar.tsx | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/Components/Common/Sidebar/Sidebar.tsx b/src/Components/Common/Sidebar/Sidebar.tsx index 69ab9b226f9..2f33979763a 100644 --- a/src/Components/Common/Sidebar/Sidebar.tsx +++ b/src/Components/Common/Sidebar/Sidebar.tsx @@ -68,21 +68,22 @@ const StatelessSidebar = ({ const e = indicatorRef.current; const itemHeight = activeLinkRef.current?.clientHeight || 0; if (lastIndicatorPosition > index) { - e.style.top = `${itemHeight * index + 0.3 * itemHeight}px`; + e.style.top = `${itemHeight * (index + 0.37)}px`; setTimeout(() => { - e.style.bottom = `${itemHeight * (NavItems.length - index + 1.3)}px`; + e.style.bottom = `${itemHeight * (NavItems.length + 1.37 - index)}px`; }, 50); } else { - e.style.bottom = `${itemHeight * (NavItems.length - index + 1.3)}px`; + e.style.bottom = `${itemHeight * (NavItems.length + 1.37 - index)}px`; setTimeout(() => { - e.style.top = `${itemHeight * index + 0.3 * itemHeight}px`; + e.style.top = `${itemHeight * (index + 0.37)}px`; }, 50); } setLastIndicatorPosition(index); } else { indicatorRef.current.style.display = "none"; } - }, [activeLink]); + }, [activeLink, lastIndicatorPosition]); + const handleOverflow = (value: boolean) => { setOverflowVisisble(value); }; From e32b7d65a2a06cde1aa69cda2edbd5f0e63adb70 Mon Sep 17 00:00:00 2001 From: Onkar Jadhav Date: Sun, 24 Dec 2023 20:49:08 +0530 Subject: [PATCH 3/3] Extract 'navItemCount' as variable --- src/Components/Common/Sidebar/Sidebar.tsx | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/Components/Common/Sidebar/Sidebar.tsx b/src/Components/Common/Sidebar/Sidebar.tsx index 2f33979763a..fa809571772 100644 --- a/src/Components/Common/Sidebar/Sidebar.tsx +++ b/src/Components/Common/Sidebar/Sidebar.tsx @@ -62,6 +62,7 @@ const StatelessSidebar = ({ 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 @@ -70,10 +71,10 @@ const StatelessSidebar = ({ if (lastIndicatorPosition > index) { e.style.top = `${itemHeight * (index + 0.37)}px`; setTimeout(() => { - e.style.bottom = `${itemHeight * (NavItems.length + 1.37 - index)}px`; + e.style.bottom = `${itemHeight * (navItemCount - 0.63 - index)}px`; }, 50); } else { - e.style.bottom = `${itemHeight * (NavItems.length + 1.37 - index)}px`; + e.style.bottom = `${itemHeight * (navItemCount - 0.63 - index)}px`; setTimeout(() => { e.style.top = `${itemHeight * (index + 0.37)}px`; }, 50);