mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-05-14 06:50:38 -05:00
62 lines
2.0 KiB
TypeScript
62 lines
2.0 KiB
TypeScript
import { useState } from "react";
|
|
import { HamburgerButton } from "./HamburgerButton";
|
|
import { MobileNav } from "./MobileNav";
|
|
import { SearchInput } from "./SearchInput";
|
|
import { UserItem } from "./UserItem";
|
|
import { Link } from "remix";
|
|
import { navItems } from "~/constants";
|
|
|
|
export function Layout({ children }: { children: React.ReactNode }) {
|
|
const [menuExpanded, setMenuExpanded] = useState(false);
|
|
|
|
return (
|
|
<>
|
|
<header className="layout__header">
|
|
<div className="layout__header__logo-container">
|
|
<Link to="/">
|
|
<img className="layout__logo" src="/img/layout/logo.webp" />
|
|
</Link>
|
|
</div>
|
|
<div className="layout__header__search-container">
|
|
<SearchInput />
|
|
</div>
|
|
<div className="layout__header__right-container">
|
|
<UserItem />
|
|
<HamburgerButton
|
|
expanded={menuExpanded}
|
|
onClick={() => setMenuExpanded((e) => !e)}
|
|
/>
|
|
</div>
|
|
</header>
|
|
<MobileNav
|
|
expanded={menuExpanded}
|
|
closeMenu={() => setMenuExpanded(false)}
|
|
/>
|
|
<nav className="layout__nav">
|
|
<div className="layout__nav__items">
|
|
{navItems.map((navGroup) => (
|
|
<div key={navGroup.title} className="layout__nav__items__column">
|
|
<div className="layout__nav__column__title">{navGroup.title}</div>
|
|
{navGroup.items.map((navItem) => (
|
|
<Link
|
|
key={navItem}
|
|
className="layout__nav__link"
|
|
to={navItem}
|
|
data-cy={`nav-link-${navItem}`}
|
|
>
|
|
<img
|
|
src={`/img/layout/${navItem.replace(" ", "")}.webp`}
|
|
className="layout__nav__link__icon"
|
|
/>
|
|
{navItem}
|
|
</Link>
|
|
))}
|
|
</div>
|
|
))}
|
|
</div>
|
|
</nav>
|
|
<main className="layout__main">{children}</main>
|
|
</>
|
|
);
|
|
}
|