bigbuffet-rw/app/soapbox/components/sidebar-navigation-link.tsx

56 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-03-21 11:09:01 -07:00
import classNames from 'classnames';
import React from 'react';
import { NavLink } from 'react-router-dom';
import { Icon, Text } from './ui';
2022-03-21 11:09:01 -07:00
interface ISidebarNavigationLink {
count?: number,
icon: string,
text: string | React.ReactElement,
to?: string,
onClick?: React.EventHandler<React.MouseEvent>,
2022-03-21 11:09:01 -07:00
}
const SidebarNavigationLink = React.forwardRef((props: ISidebarNavigationLink, ref: React.ForwardedRef<HTMLAnchorElement>): JSX.Element => {
const { icon, text, to = '', count, onClick } = props;
2022-03-21 11:09:01 -07:00
const isActive = location.pathname === to;
const handleClick: React.EventHandler<React.MouseEvent> = (e) => {
if (onClick) {
onClick(e);
e.preventDefault();
e.stopPropagation();
}
};
2022-03-21 11:09:01 -07:00
return (
<NavLink
exact
to={to}
ref={ref}
onClick={handleClick}
2022-03-21 11:09:01 -07:00
className={classNames({
2022-05-16 05:58:16 -07:00
'flex items-center p-3 text-sm font-semibold space-x-4 rounded-full group hover:bg-primary-200/80 dark:hover:bg-primary-900/60 hover:text-primary-600 dark:hover:text-gray-200': true,
'text-gray-500 dark:text-gray-400': !isActive,
'text-primary-600 dark:text-white': isActive,
2022-03-21 11:09:01 -07:00
})}
>
2022-05-16 05:58:16 -07:00
<span className='relative'>
<Icon
src={icon}
count={count}
className={classNames({
2022-05-16 05:58:16 -07:00
'h-5 w-5 dark:group-hover:text-primary-500': true,
'dark:text-primary-500': isActive,
})}
/>
2022-03-21 11:09:01 -07:00
</span>
<Text weight='semibold' theme='inherit'>{text}</Text>
</NavLink>
);
});
2022-03-21 11:09:01 -07:00
export default SidebarNavigationLink;