import classNames from 'classnames'; import React from 'react'; import { NavLink } from 'react-router-dom'; import { Icon, Text, Counter } from './ui'; interface ISidebarNavigationLink { /** Notification count, if any. */ count?: number, /** URL to an SVG icon. */ icon: string, /** Link label. */ text: React.ReactElement, /** Route to an internal page. */ to?: string, /** Callback when the link is clicked. */ onClick?: React.EventHandler, } /** Desktop sidebar navigation link. */ const SidebarNavigationLink = React.forwardRef((props: ISidebarNavigationLink, ref: React.ForwardedRef): JSX.Element => { const { icon, text, to = '', count, onClick } = props; const isActive = location.pathname === to; const withCounter = typeof count !== 'undefined'; const handleClick: React.EventHandler = (e) => { if (onClick) { onClick(e); e.preventDefault(); e.stopPropagation(); } }; return ( {withCounter && count > 0 ? ( ) : null} {text} ); }); export default SidebarNavigationLink;