2022-12-13 07:00:49 -05:00
|
|
|
import { m, Variants } from "framer-motion";
|
2022-12-22 11:23:04 -05:00
|
|
|
import { useRouter } from "next/router";
|
2022-12-13 07:00:49 -05:00
|
|
|
import Link from "next/link";
|
|
|
|
|
|
|
|
function NavBar() {
|
|
|
|
return (
|
2022-12-22 11:23:04 -05:00
|
|
|
<div className="m-3">
|
2022-12-20 09:38:26 -05:00
|
|
|
<m.div
|
2022-12-24 18:38:59 -05:00
|
|
|
className="flex min-h-[5rem] w-full flex-row items-center justify-between rounded-2xl bg-zinc-800 bg-opacity-70 p-1 lg:h-full lg:w-24 lg:flex-col"
|
2022-12-22 11:23:04 -05:00
|
|
|
variants={navContainerVariants}
|
|
|
|
initial="initial"
|
|
|
|
animate="animate"
|
2022-12-20 09:38:26 -05:00
|
|
|
>
|
2022-12-22 11:23:04 -05:00
|
|
|
<m.div
|
|
|
|
className="flex flex-row items-center justify-center pl-5 lg:flex-col lg:pl-0 lg:pt-5"
|
|
|
|
variants={navStripVariants}
|
|
|
|
>
|
|
|
|
<m.div variants={navIconVariants} className="pr-5 lg:pr-0 lg:pb-3">
|
|
|
|
<ActiveLink href="/dashboard">
|
|
|
|
<DashIcon />
|
|
|
|
</ActiveLink>
|
|
|
|
</m.div>
|
|
|
|
<m.div
|
|
|
|
variants={navIconVariants}
|
|
|
|
className="pr-5 lg:pr-0 lg:pt-3 lg:pb-3"
|
|
|
|
>
|
2023-01-19 22:23:27 -05:00
|
|
|
<ActiveLink href="/ranking">
|
2022-12-22 11:23:04 -05:00
|
|
|
<RankingIcon />
|
|
|
|
</ActiveLink>
|
|
|
|
</m.div>
|
2022-12-13 07:00:49 -05:00
|
|
|
</m.div>
|
2022-12-22 11:23:04 -05:00
|
|
|
<m.div
|
|
|
|
className="flex flex-row items-center justify-center pr-5 lg:w-full lg:flex-col lg:pr-0 lg:pb-5"
|
|
|
|
variants={navStripVariants}
|
|
|
|
>
|
|
|
|
<m.div
|
|
|
|
className="fill-white stroke-white"
|
|
|
|
whileHover={{
|
|
|
|
color: "#fca311",
|
|
|
|
}}
|
|
|
|
whileTap={{
|
|
|
|
color: "#dd4444",
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<Link href="/">
|
|
|
|
<ExitIcon />
|
|
|
|
</Link>
|
|
|
|
</m.div>
|
2022-12-13 07:00:49 -05:00
|
|
|
</m.div>
|
|
|
|
</m.div>
|
2022-12-22 11:23:04 -05:00
|
|
|
</div>
|
2022-12-13 07:00:49 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const NavSvgWrap = (props: { children: React.ReactNode }) => {
|
|
|
|
return (
|
|
|
|
<m.svg
|
|
|
|
className="cursor-pointer"
|
|
|
|
viewBox="0 0 24 24"
|
|
|
|
width="32"
|
|
|
|
height="32"
|
|
|
|
x={0}
|
|
|
|
y={0}
|
|
|
|
origin="center"
|
2022-12-22 11:23:04 -05:00
|
|
|
whileHover={{
|
|
|
|
scale: 1.1,
|
|
|
|
}}
|
|
|
|
whileTap={{
|
|
|
|
scale: 0.9,
|
|
|
|
}}
|
2022-12-13 07:00:49 -05:00
|
|
|
>
|
|
|
|
{props.children}
|
|
|
|
</m.svg>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const DashIcon = () => {
|
|
|
|
return (
|
|
|
|
<NavSvgWrap>
|
|
|
|
<m.path
|
|
|
|
d="M3 13h8V3H3v10zm0 8h8v-6H3v6zm10 0h8V11h-8v10zm0-18v6h8V3h-8z"
|
|
|
|
strokeWidth="1"
|
2022-12-22 11:23:04 -05:00
|
|
|
stroke="currentColor"
|
|
|
|
fill="currentColor"
|
2022-12-13 07:00:49 -05:00
|
|
|
/>
|
|
|
|
</NavSvgWrap>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const ExitIcon = () => {
|
|
|
|
return (
|
|
|
|
<NavSvgWrap>
|
|
|
|
<m.path
|
|
|
|
d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"
|
|
|
|
strokeWidth="1"
|
2022-12-22 11:23:04 -05:00
|
|
|
stroke="currentColor"
|
|
|
|
fill="currentColor"
|
2022-12-13 07:00:49 -05:00
|
|
|
/>
|
|
|
|
</NavSvgWrap>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const RankingIcon = () => {
|
|
|
|
return (
|
|
|
|
<NavSvgWrap>
|
|
|
|
<m.path
|
|
|
|
d="M7.5 21H2V9h5.5v12zm7.25-18h-5.5v18h5.5V3zM22 11h-5.5v10H22V11z"
|
|
|
|
strokeWidth="1"
|
2022-12-22 11:23:04 -05:00
|
|
|
stroke="currentColor"
|
|
|
|
fill="currentColor"
|
2022-12-13 07:00:49 -05:00
|
|
|
/>
|
|
|
|
</NavSvgWrap>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-12-22 11:23:04 -05:00
|
|
|
const ActiveLink = (props: { href: string; children: React.ReactNode }) => {
|
|
|
|
const router = useRouter();
|
|
|
|
let styling = "text-white";
|
|
|
|
if (router.pathname === props.href) {
|
|
|
|
styling = "text-[#a855f7]";
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<Link href={props.href} className={styling}>
|
|
|
|
{props.children}
|
|
|
|
</Link>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-12-13 07:00:49 -05:00
|
|
|
const navContainerVariants: Variants = {
|
|
|
|
initial: {
|
|
|
|
opacity: 0,
|
|
|
|
x: -100,
|
|
|
|
},
|
|
|
|
animate: {
|
|
|
|
opacity: 1,
|
|
|
|
x: 0,
|
|
|
|
transition: {
|
|
|
|
delay: 0.5,
|
|
|
|
duration: 1.0,
|
|
|
|
type: "spring",
|
|
|
|
bounce: 0.5,
|
|
|
|
stiffness: 80,
|
|
|
|
delayChildren: 1.25,
|
|
|
|
staggerChildren: 0.25,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const navStripVariants: Variants = {
|
|
|
|
initial: {
|
|
|
|
opacity: 0,
|
|
|
|
y: 100,
|
|
|
|
},
|
|
|
|
animate: {
|
|
|
|
opacity: 1,
|
|
|
|
y: 0,
|
|
|
|
transition: {
|
|
|
|
duration: 1.0,
|
|
|
|
type: "spring",
|
|
|
|
bounce: 0.5,
|
|
|
|
stiffness: 80,
|
|
|
|
staggerChildren: 0.25,
|
|
|
|
delayChildren: 0.1,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const navIconVariants: Variants = {
|
|
|
|
initial: {
|
|
|
|
opacity: 0,
|
|
|
|
},
|
|
|
|
animate: {
|
|
|
|
opacity: 1,
|
|
|
|
transition: {
|
|
|
|
duration: 1.0,
|
|
|
|
type: "spring",
|
|
|
|
bounce: 0.5,
|
|
|
|
stiffness: 80,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
export default NavBar;
|