2023-05-15 08:51:32 +08:00
|
|
|
'use client'
|
2023-08-28 19:48:53 +08:00
|
|
|
|
2023-05-15 08:51:32 +08:00
|
|
|
import { useSelectedLayoutSegment } from 'next/navigation'
|
|
|
|
import classNames from 'classnames'
|
|
|
|
import Link from 'next/link'
|
|
|
|
|
2023-08-28 19:48:53 +08:00
|
|
|
export type NavIcon = React.ComponentType<
|
|
|
|
React.PropsWithoutRef<React.ComponentProps<'svg'>> & {
|
|
|
|
title?: string | undefined
|
|
|
|
titleId?: string | undefined
|
|
|
|
}
|
|
|
|
>
|
|
|
|
|
|
|
|
export type NavLinkProps = {
|
|
|
|
name: string
|
|
|
|
href: string
|
|
|
|
iconMap: {
|
|
|
|
selected: NavIcon
|
|
|
|
normal: NavIcon
|
|
|
|
}
|
2023-11-27 11:47:48 +08:00
|
|
|
mode?: 'expand' | 'collapse'
|
2023-08-28 19:48:53 +08:00
|
|
|
}
|
|
|
|
|
2023-05-15 08:51:32 +08:00
|
|
|
export default function NavLink({
|
|
|
|
name,
|
|
|
|
href,
|
|
|
|
iconMap,
|
2023-11-27 11:47:48 +08:00
|
|
|
mode = 'expand',
|
2023-08-28 19:48:53 +08:00
|
|
|
}: NavLinkProps) {
|
2023-05-15 08:51:32 +08:00
|
|
|
const segment = useSelectedLayoutSegment()
|
|
|
|
const isActive = href.toLowerCase().split('/')?.pop() === segment?.toLowerCase()
|
|
|
|
const NavIcon = isActive ? iconMap.selected : iconMap.normal
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Link
|
|
|
|
key={name}
|
|
|
|
href={href}
|
|
|
|
className={classNames(
|
|
|
|
isActive ? 'bg-primary-50 text-primary-600 font-semibold' : 'text-gray-700 hover:bg-gray-100 hover:text-gray-700',
|
|
|
|
'group flex items-center rounded-md px-2 py-2 text-sm font-normal',
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
<NavIcon
|
|
|
|
className={classNames(
|
|
|
|
'mr-2 h-4 w-4 flex-shrink-0',
|
|
|
|
isActive ? 'text-primary-600' : 'text-gray-700',
|
|
|
|
)}
|
|
|
|
aria-hidden="true"
|
|
|
|
/>
|
2023-11-27 11:47:48 +08:00
|
|
|
{mode === 'expand' && name}
|
2023-05-15 08:51:32 +08:00
|
|
|
</Link>
|
|
|
|
)
|
|
|
|
}
|