sendou.ink/app/components/Layout/index.tsx
Kalle (Sendou) 7fbcdd196c Tweaks
2021-11-27 03:32:02 +02:00

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>
</>
);
}