mirror of
https://github.com/timmypidashev/web.git
synced 2026-04-14 19:13:51 +00:00
Work on collapsible menu
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 (
|
||||||
<div></div>
|
<HeroSection1 />
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,8 @@
|
|||||||
import { useState, useEffect } from "react";
|
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 { FaBars } from "react-icons/fa"; // Import hamburger icon
|
||||||
|
|
||||||
|
|
||||||
// Tabs(links to be converted into a tab menu)
|
// Tabs(links to be converted into a tab menu)
|
||||||
const tabs = [
|
const tabs = [
|
||||||
@@ -79,7 +81,7 @@ function TabMenu({ tabs, activeTab, setActiveTab }) {
|
|||||||
},
|
},
|
||||||
hidden: { opacity: 0 }
|
hidden: { opacity: 0 }
|
||||||
}}
|
}}
|
||||||
className="flex space-x-1"
|
className="hidden 2xl:flex xl:flex lg:flex md:flex space-x-1" // Hide on small screens
|
||||||
>
|
>
|
||||||
{tabs.map((tab) => (
|
{tabs.map((tab) => (
|
||||||
<Tab key={tab.id} tab={tab} activeTab={activeTab} setActiveTab={setActiveTab} />
|
<Tab key={tab.id} tab={tab} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
@@ -88,6 +90,36 @@ function TabMenu({ tabs, activeTab, setActiveTab }) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function CollapsibleMenu({ tabs, activeTab, setActiveTab }) {
|
||||||
|
return (
|
||||||
|
<motion.div
|
||||||
|
initial="hidden"
|
||||||
|
animate="visible"
|
||||||
|
exit="hidden"
|
||||||
|
variants={{
|
||||||
|
visible: {
|
||||||
|
opacity: 1,
|
||||||
|
transition: { staggerChildren: 0.1 }
|
||||||
|
},
|
||||||
|
hidden: { opacity: 0 }
|
||||||
|
}}
|
||||||
|
className="2xl:hidden xl:hidden lg:hidden md:hidden sm:flex-col space-y-4" // Flex column layout
|
||||||
|
>
|
||||||
|
{tabs.map((tab) => (
|
||||||
|
<motion.div
|
||||||
|
key={tab.id}
|
||||||
|
variants={{
|
||||||
|
visible: { opacity: 1, y: 0 },
|
||||||
|
hidden: { opacity: 0, y: -20 }
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<Tab tab={tab} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
|
</motion.div>
|
||||||
|
))}
|
||||||
|
</motion.div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
function Header() {
|
function Header() {
|
||||||
const [mounted, setMounted] = useState(false);
|
const [mounted, setMounted] = useState(false);
|
||||||
const [activeTab, setActiveTab] = useState(tabs[0].id);
|
const [activeTab, setActiveTab] = useState(tabs[0].id);
|
||||||
@@ -100,7 +132,10 @@ function Header() {
|
|||||||
<div className="flex justify-center items-center">
|
<div className="flex justify-center items-center">
|
||||||
<AnimatePresence>
|
<AnimatePresence>
|
||||||
{mounted && (
|
{mounted && (
|
||||||
<TabMenu tabs={tabs} activeTab={activeTab} setActiveTab={setActiveTab} />
|
<>
|
||||||
|
<TabMenu tabs={tabs} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
|
<CollapsibleMenu tabs={tabs} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
|
</>
|
||||||
)}
|
)}
|
||||||
</AnimatePresence>
|
</AnimatePresence>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user