feat(SW-187): simplify dropdown menu

This commit is contained in:
Pontus Dreij
2024-09-09 14:58:22 +02:00
parent ef33d082d8
commit 07eb0401bb
9 changed files with 93 additions and 158 deletions

View File

@@ -18,6 +18,7 @@ import LoginButton from "../LoginButton"
import styles from "./mainMenu.module.css"
import type { MainMenuProps } from "@/types/components/current/header/mainMenu"
import { DropdownType } from "@/types/components/dropdown/dropdown"
export function MainMenu({
frontpageLinkText,
@@ -61,12 +62,11 @@ export function MainMenu({
"/sv/current-content-page",
].includes(pathname)
const {
isHamburgerMenuOpen,
isMyPagesMobileMenuOpen,
toggleHamburgerMenu,
toggleMyPagesMobileMenu,
} = useDropdownStore()
const { toggleDropdown, openDropdown } = useDropdownStore()
const isMyPagesMobileMenuOpen =
openDropdown === DropdownType.MyPagesMobileMenu
const isHamburgerMenuOpen = openDropdown === DropdownType.HamburgerMenu
function handleMyPagesMobileMenuClick() {
// Only track click when opening it
@@ -74,7 +74,7 @@ export function MainMenu({
trackClick("profile picture icon")
}
toggleMyPagesMobileMenu()
toggleDropdown(DropdownType.MyPagesMobileMenu)
}
return (
@@ -89,7 +89,7 @@ export function MainMenu({
<button
aria-pressed="false"
className={`${styles.expanderBtn} ${isHamburgerMenuOpen ? styles.expanded : ""}`}
onClick={toggleHamburgerMenu}
onClick={() => toggleDropdown(DropdownType.HamburgerMenu)}
type="button"
>
<span className={styles.iconBars}></span>