fix: add logic for Link active styles

This commit is contained in:
Arvid Norlin
2024-04-08 13:14:15 +02:00
parent 3630598f03
commit 56ccce346d

View File

@@ -1,20 +1,27 @@
"use client"
import { LogOut } from "react-feather" import { LogOut } from "react-feather"
import Link from "next/link" import Link from "next/link"
import styles from "./sidebar.module.css" import styles from "./sidebar.module.css"
import { SidebarProps } from "@/types/requests/myPages/navigation" import { SidebarProps } from "@/types/requests/myPages/navigation"
import { usePathname } from "next/navigation"
import { Fragment } from "react"
export default function Sidebar({ menuItems }: SidebarProps) { export default function Sidebar({ menuItems }: SidebarProps) {
const currentPageSlug = `/${usePathname()
.split("/")
.filter((v) => v)
.at(-1)}`
return ( return (
<aside className={styles.sidebar}> <aside className={styles.sidebar}>
<nav className={styles.nav}> <nav className={styles.nav}>
{/* <Link className={`${styles.link} ${styles.active}`} href="#">
My Scandic
</Link> */}
{/* Base styles.active on menuItem href and current path */}
{menuItems.map((item) => ( {menuItems.map((item) => (
<> <Fragment key={item.uid}>
<Link key={item.uid} className={styles.link} href={item.url}> <Link
className={`${styles.link} ${currentPageSlug === item.url ? styles.active : ""}`}
href={item.url}
>
{item.linkText || item.title} {item.linkText || item.title}
</Link> </Link>
{item.subItems {item.subItems
@@ -22,7 +29,7 @@ export default function Sidebar({ menuItems }: SidebarProps) {
return ( return (
<Link <Link
key={subItem.uid} key={subItem.uid}
className={styles.link} className={`${styles.link} ${currentPageSlug === subItem.url ? styles.active : ""}`}
href={subItem.url} href={subItem.url}
> >
{subItem.linkText || subItem.title} {subItem.linkText || subItem.title}
@@ -30,7 +37,7 @@ export default function Sidebar({ menuItems }: SidebarProps) {
) )
}) })
: null} : null}
</> </Fragment>
))} ))}
<Link className={styles.link} href="/api/auth/signout"> <Link className={styles.link} href="/api/auth/signout">