refactor: Extract Sidebar Link to component

This commit is contained in:
Arvid Norlin
2024-04-11 13:44:04 +02:00
parent 3d2fafff6d
commit c0b68f9e5b
7 changed files with 102 additions and 22 deletions

View File

@@ -1,38 +1,29 @@
"use client"
import { LogOut } from "react-feather"
import Link from "next/link"
import Link from "../../TempDesignSystem/Link"
import styles from "./sidebar.module.css"
import { SidebarProps } from "@/types/requests/myPages/navigation"
import { usePathname } from "next/navigation"
import { Fragment } from "react"
export default function Sidebar({ menuItems }: SidebarProps) {
const currentPageSlug = `/${usePathname()
.split("/")
.filter((v) => v)
.at(-1)}`
return (
<aside className={styles.sidebar}>
<nav className={styles.nav}>
{menuItems.map((item) => (
<Fragment key={item.uid}>
<Link
className={`${styles.link} ${currentPageSlug === item.url ? styles.active : ""}`}
href={item.url}
>
{item.linkText || item.title}
<Link variant={"sidebar"} href={item.url}>
{item.linkText}
</Link>
{item.subItems
? item.subItems.map((subItem) => {
return (
<Link
key={subItem.uid}
className={`${styles.link} ${currentPageSlug === subItem.url ? styles.active : ""}`}
href={subItem.url}
variant={"sidebar"}
>
{subItem.linkText || subItem.title}
{subItem.linkText}
</Link>
)
})