Files
pse.dev/components/site-header-mobile.tsx
Kalidou Diagne 31763f7662 feat: PageSpeed Insights improvements (#545)
* feat: PageSpeed Insights improvements
2025-09-01 06:01:00 +02:00

144 lines
4.5 KiB
TypeScript

"use client"
import { AppLink } from "./app-link"
import { Icons } from "./icons"
import { LABELS } from "@/app/labels"
import { useGlobalProvider } from "@/app/providers/GlobalProvider"
import {
Discord,
Github,
Mirror,
Twitter,
} from "@/components/svgs/social-medias"
import { siteConfig } from "@/config/site"
import { useAppSettings } from "@/hooks/useAppSettings"
import { interpolate } from "@/lib/utils"
import CloseVector from "@/public/icons/close-fill.svg"
import { NavItem } from "@/types/nav"
import { SunMedium as SunIcon, Moon as MoonIcon } from "lucide-react"
import NextImage from "next/image"
import { useState } from "react"
export const SiteHeaderMobile = () => {
const [header, setHeader] = useState(false)
const { isDarkMode, setIsDarkMode } = useGlobalProvider()
const { MAIN_NAV } = useAppSettings()
return (
<div className="flex items-center lg:hidden">
<button
type="button"
onClick={() => setHeader(true)}
aria-label="Open navigation menu"
aria-expanded={header}
>
<Icons.Burgher
size={24}
className="text-[#171C1B] dark:text-anakiwa-400"
/>
</button>
{header && (
<div
className="z-40 fixed inset-0 flex justify-end bg-black opacity-50"
onClick={() => setHeader(false)}
></div>
)}
{header && (
<div className="fixed inset-y-0 right-0 z-50 flex w-[257px] flex-col bg-black text-white">
<div className="flex justify-end p-[37px]">
<button
onClick={() => setHeader(false)}
aria-label="Close navigation menu"
className="cursor-pointer"
>
<NextImage src={CloseVector} alt="" width={24} height={24} />
</button>
</div>
<div className="flex w-full flex-col px-[16px] text-base font-medium">
{MAIN_NAV.map((item: NavItem, index) => {
if (item.onlyFooter) return null
return (
<AppLink
key={index}
href={item.href}
onClick={() => setHeader(false)}
target={item?.external ? "_blank" : undefined}
className="border-b-2 border-white p-4 uppercase"
variant="nav"
>
{item.title}
</AppLink>
)
})}
<button
onClick={() => setIsDarkMode(!isDarkMode)}
className="ml-auto mt-10"
aria-label={
isDarkMode ? "Switch to light mode" : "Switch to dark mode"
}
>
{isDarkMode ? (
<SunIcon
className="text-white dark:text-anakiwa-400"
size={20}
/>
) : (
<MoonIcon
className="text-white dark:text-anakiwa-400"
size={20}
/>
)}
</button>
</div>
<div className="flex h-full w-full flex-col items-center justify-end gap-5 py-[40px] text-sm">
<div className="flex gap-5">
<AppLink
href={siteConfig.links.twitter}
external
aria-label="Follow us on Twitter/X"
>
<Twitter color="white" />{" "}
</AppLink>
<AppLink
href={siteConfig.links.discord}
external
aria-label="Join our Discord community"
>
<Discord color="white" />{" "}
</AppLink>
<AppLink
href={siteConfig.links.github}
external
aria-label="View our code on GitHub"
>
<Github color="white" />{" "}
</AppLink>
<AppLink
href={siteConfig.links.articles}
external
aria-label="Read our articles on Mirror"
>
<Mirror color="white" />{" "}
</AppLink>
</div>
<div className="flex gap-5 text-white">
<span>{LABELS.COMMON.FOOTER.PRIVACY_POLICY}</span>
<span>{LABELS.COMMON.FOOTER.TERMS_OF_USE}</span>
</div>
<p className="text-center text-gray-400">
{interpolate(LABELS.COMMON.LAST_UPDATED_AT, {
date: "January 16, 2024",
})}
</p>
</div>
</div>
)}
</div>
)
}