mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-04-18 21:20:55 -05:00
60 lines
1.8 KiB
TypeScript
60 lines
1.8 KiB
TypeScript
import { Link } from "solid-app-router";
|
|
import { createSignal, For, JSXElement } from "solid-js";
|
|
import s from "../styles/Layout.module.css";
|
|
import { navItems } from "../utils";
|
|
import { HamburgerButton } from "./HamburgerButton";
|
|
import { MobileNav } from "./MobileNav";
|
|
import { SearchInput } from "./SearchInput";
|
|
import { UserItem } from "./UserItem";
|
|
|
|
export function Layout(p: { children: JSXElement }) {
|
|
const [menuExpanded, setMenuExpanded] = createSignal(false);
|
|
|
|
function toggleMenu() {
|
|
setMenuExpanded((expanded) => !expanded);
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<header class={s.header}>
|
|
<Link href="/">
|
|
<div class={s.logoContainer}>
|
|
<img class={s.logo} src="/img/layout/logo.webp" />
|
|
</div>
|
|
</Link>
|
|
<div class={s.searchContainer}>
|
|
<SearchInput />
|
|
</div>
|
|
<div class={s.rightContainer}>
|
|
<HamburgerButton isExpanded={menuExpanded()} onClick={toggleMenu} />
|
|
<UserItem />
|
|
</div>
|
|
</header>
|
|
<MobileNav isExpanded={menuExpanded()} />
|
|
<nav class={s.nav}>
|
|
<div class={s.navItems}>
|
|
<For each={navItems}>
|
|
{(navGroup) => (
|
|
<div class={s.navItemColumn}>
|
|
<div class={s.navGroupTitle}>{navGroup.title}</div>
|
|
<For each={navGroup.items}>
|
|
{(navItem) => (
|
|
<Link class={s.navLink} href="/">
|
|
<img
|
|
src={`/img/layout/${navItem.replace(" ", "")}.webp`}
|
|
class={s.navIcon}
|
|
/>
|
|
{navItem}
|
|
</Link>
|
|
)}
|
|
</For>
|
|
</div>
|
|
)}
|
|
</For>
|
|
</div>
|
|
</nav>
|
|
<main class={s.main}>{p.children}</main>
|
|
</>
|
|
);
|
|
}
|