Portfolio-v3/components/navbar.js
2024-05-06 16:02:44 -04:00

57 lines
2.3 KiB
JavaScript

import Link from "next/link";
import { useState } from "react";
import NavLink from "./navlink";
export default function Navbar() {
const [active, setActive] = useState(false);
const handleClick = () => {
setActive(!active);
};
return (
<>
<nav className="container mx-auto flex flex-wrap p-5 flex-col md:flex-row">
<div className="flex">
<Link href="/">
<span className="flex font-medium items-center mb-4 md:mb-0 cursor-pointer">
<span className="text-2xl font-bold duration-200">Josh S.</span>
</span>
</Link>
<button
className="inline-block md:hidden w-8 h-8 text-gray-400 focus:text-white p-1 ml-auto"
onClick={handleClick}
aria-label="Navigation menu"
>
<svg
className="w-6 h-6"
fill="none"
stroke="currentColor"
viewBox="0 0 24 24"
xmlns="http://www.w3.org/2000/svg"
>
<path
strokeLinecap="round"
strokeLinejoin="round"
strokeWidth={2}
d="M4 6h16M4 12h16M4 18h16"
/>
</svg>
</button>
</div>
<div
className={`${
active ? "flex" : "hidden"
} md:ml-auto md:flex flex-wrap flex-col md:flex-row md:space-x-4 items-center w-full pt-2 md:pt-0 md:w-auto text-lg justify-center font-semibold`}
>
<NavLink href="/" text="Home" />
<NavLink href="/work" text="Work" />
<NavLink href="/about" text="About" />
<NavLink href="/contact" text="Contact" />
<NavLink href="/donate" text="Donate" />
<NavLink href="/certifications" text="Certifications" />
</div>
</nav>
</>
);
}