mirror of
https://github.com/timmypidashev/web.git
synced 2026-04-14 19:13:51 +00:00
Split up header into multiple readable parts
This commit is contained in:
@@ -6,6 +6,6 @@ import { HeroSection1, HeroSection2, HeroSection3 } from "@/components/hero";
|
|||||||
// Exports
|
// Exports
|
||||||
export default function Index() {
|
export default function Index() {
|
||||||
return (
|
return (
|
||||||
<HeroSection1 />
|
<div></div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,11 @@
|
|||||||
"use client";
|
"use client";
|
||||||
|
|
||||||
import ThemeToggle from "@/components/theme-toggle"
|
import { useState, useEffect } from "react";
|
||||||
import Link from "next/link";
|
import Link from "next/link";
|
||||||
import { motion, AnimatePresence } from "framer-motion";
|
import { motion, AnimatePresence } from "framer-motion";
|
||||||
import { useState, useEffect } from "react";
|
|
||||||
|
|
||||||
|
// Tabs(links to be converted into a tab menu)
|
||||||
let tabs = [
|
const tabs = [
|
||||||
{ id: "/", label: "Home", color: "green" },
|
{ id: "/", label: "Home", color: "green" },
|
||||||
{ id: "projects", label: "Projects", color: "yellow" },
|
{ id: "projects", label: "Projects", color: "yellow" },
|
||||||
{ id: "resume", label: "Resume", color: "blue" },
|
{ id: "resume", label: "Resume", color: "blue" },
|
||||||
@@ -14,17 +13,84 @@ let tabs = [
|
|||||||
{ id: "shop", label: "Shop", color: "aqua" }
|
{ id: "shop", label: "Shop", color: "aqua" }
|
||||||
];
|
];
|
||||||
|
|
||||||
|
// Tab theme colors
|
||||||
const tabColors = {
|
const tabColors = {
|
||||||
"green": "bg-light-green-1 dark:bg-dark-green-1",
|
green: "bg-light-green-1 dark:bg-dark-green-1",
|
||||||
"yellow": "bg-light-yellow-1 dark:bg-dark-yellow-1",
|
yellow: "bg-light-yellow-1 dark:bg-dark-yellow-1",
|
||||||
"blue": "bg-light-blue-1 dark:bg-dark-blue-1",
|
blue: "bg-light-blue-1 dark:bg-dark-blue-1",
|
||||||
"purple": "bg-light-purple-1 dark:bg-dark-purple-1",
|
purple: "bg-light-purple-1 dark:bg-dark-purple-1",
|
||||||
"aqua": "bg-light-aqua-1 dark:bg-dark-aqua-1"
|
aqua: "bg-light-aqua-1 dark:bg-dark-aqua-1"
|
||||||
|
};
|
||||||
|
|
||||||
|
// Individual tab links
|
||||||
|
function Tab({ tab, activeTab, setActiveTab }) {
|
||||||
|
return (
|
||||||
|
<Link href={`/${tab.id}`} passHref>
|
||||||
|
<motion.a
|
||||||
|
onClick={() => setActiveTab(tab.id)}
|
||||||
|
className={`${
|
||||||
|
activeTab === tab.id ? "" : ""
|
||||||
|
}
|
||||||
|
relative rounded-full
|
||||||
|
lg:px-6 md:px-5 sm:px-4 lg:py-1.5 md:py-1.5 sm:py-1.5
|
||||||
|
lg:mr-8 md:mr-4 sm:mr-2 lg:mb-1 md:mb-1 sm:mb-1
|
||||||
|
lg:text-4xl md:text-3xl sm:text-2xl font-bold text-light-foreground dark:text-dark-foreground
|
||||||
|
transition-all focus-visible:outline-2
|
||||||
|
`}
|
||||||
|
style={{
|
||||||
|
WebkitTapHighlightColor: "transparent"
|
||||||
|
}}
|
||||||
|
variants={{
|
||||||
|
visible: { opacity: 1, x: 0 },
|
||||||
|
hidden: { opacity: 0, x: -50 }
|
||||||
|
}}
|
||||||
|
transition={{ duration: 0.3 }}
|
||||||
|
>
|
||||||
|
{activeTab === tab.id && (
|
||||||
|
<motion.div
|
||||||
|
layoutId="underline"
|
||||||
|
className={`
|
||||||
|
absolute inset-x-0
|
||||||
|
lg:bottom-0.5 md:bottom-0.5 sm:bottom-0.5
|
||||||
|
lg:h-1.5 md:h-1.5 sm:h-1
|
||||||
|
${tabColors[tab.color]}
|
||||||
|
`}
|
||||||
|
style={{ marginLeft: "0.75em", marginRight: "0.75em", borderRadius: 9999 }}
|
||||||
|
transition={{ type: "spring", bounce: 0.2, duration: 0.6 }}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
{tab.label}
|
||||||
|
</motion.a>
|
||||||
|
</Link>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// List of tabs
|
||||||
|
function TabMenu({ tabs, activeTab, setActiveTab }) {
|
||||||
|
return (
|
||||||
|
<motion.div
|
||||||
|
initial="hidden"
|
||||||
|
animate="visible"
|
||||||
|
exit="hidden"
|
||||||
|
variants={{
|
||||||
|
visible: {
|
||||||
|
opacity: 1,
|
||||||
|
transition: { staggerChildren: 0.1 }
|
||||||
|
},
|
||||||
|
hidden: { opacity: 0 }
|
||||||
|
}}
|
||||||
|
className="flex space-x-1"
|
||||||
|
>
|
||||||
|
{tabs.map((tab) => (
|
||||||
|
<Tab key={tab.id} tab={tab} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
|
))}
|
||||||
|
</motion.div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function Header() {
|
function Header() {
|
||||||
const [mounted, setMounted] = useState(false);
|
const [mounted, setMounted] = useState(false);
|
||||||
let [activeTab, setActiveTab] = useState(tabs[0].id);
|
const [activeTab, setActiveTab] = useState(tabs[0].id);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
setMounted(true);
|
setMounted(true);
|
||||||
@@ -34,62 +100,11 @@ function Header() {
|
|||||||
<div className="flex justify-center items-center">
|
<div className="flex justify-center items-center">
|
||||||
<AnimatePresence>
|
<AnimatePresence>
|
||||||
{mounted && (
|
{mounted && (
|
||||||
<motion.div
|
<TabMenu tabs={tabs} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
initial="hidden"
|
|
||||||
animate="visible"
|
|
||||||
exit="hidden"
|
|
||||||
variants={{
|
|
||||||
visible: {
|
|
||||||
opacity: 1,
|
|
||||||
transition: { staggerChildren: 0.1 }
|
|
||||||
},
|
|
||||||
hidden: { opacity: 0 }
|
|
||||||
}}
|
|
||||||
className="flex space-x-1"
|
|
||||||
>
|
|
||||||
{tabs.map((tab, index) => (
|
|
||||||
<Link key={tab.id} href={`/${tab.id}`} passHref>
|
|
||||||
<motion.a
|
|
||||||
onClick={() => setActiveTab(tab.id)}
|
|
||||||
className={`${
|
|
||||||
activeTab === tab.id ? "" : ""
|
|
||||||
}
|
|
||||||
relative rounded-full
|
|
||||||
lg:px-6 md:px-5 sm:px-4 lg:py-1.5 md:py-1.5 sm:py-1.5
|
|
||||||
lg:mr-8 md:mr-4 sm:mr-2 lg:mb-1 md:mb-1 sm:mb-1
|
|
||||||
lg:text-4xl md:text-3xl sm:text-2xl font-bold text-light-foreground dark:text-dark-foreground
|
|
||||||
transition-all focus-visible:outline-2
|
|
||||||
`}
|
|
||||||
style={{
|
|
||||||
WebkitTapHighlightColor: "transparent",
|
|
||||||
}}
|
|
||||||
variants={{
|
|
||||||
visible: { opacity: 1, x: 0 },
|
|
||||||
hidden: { opacity: 0, x: -50 }
|
|
||||||
}}
|
|
||||||
transition={{ duration: 0.3 }}
|
|
||||||
>
|
|
||||||
{activeTab === tab.id && (
|
|
||||||
<motion.div
|
|
||||||
layoutId="underline"
|
|
||||||
className={`
|
|
||||||
absolute inset-x-0
|
|
||||||
lg:bottom-0.5 md:bottom-0.5 sm:bottom-0.5
|
|
||||||
lg:h-1.5 md:h-1.5 sm:h-1
|
|
||||||
${tabColors[tab.color]}
|
|
||||||
`}
|
|
||||||
style={{ marginLeft: "0.75em", marginRight: "0.75em", borderRadius: 9999 }}
|
|
||||||
transition={{ type: "spring", bounce: 0.2, duration: 0.6 }}
|
|
||||||
/>
|
|
||||||
)}
|
|
||||||
{tab.label}
|
|
||||||
</motion.a>
|
|
||||||
</Link>
|
|
||||||
))}
|
|
||||||
</motion.div>
|
|
||||||
)}
|
)}
|
||||||
</AnimatePresence>
|
</AnimatePresence>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export default Header;
|
export default Header;
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
use client";
|
"use client"
|
||||||
|
|
||||||
import { Suspense, useMemo } from "react";
|
import { Suspense, useMemo } from "react";
|
||||||
import { Canvas } from "@react-three/fiber";
|
import { Canvas } from "@react-three/fiber";
|
||||||
import { motion, AnimatePresence } from "framer-motion";
|
import { motion, AnimatePresence } from "framer-motion";
|
||||||
|
|||||||
Reference in New Issue
Block a user