mirror of
https://github.com/timmypidashev/web.git
synced 2026-04-14 11:03:50 +00:00
rework tabs
This commit is contained in:
@@ -25,7 +25,7 @@ const tabColors = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Individual tab links
|
// Individual tab links
|
||||||
function Tab({ tab, activeTab, setActiveTab }) {
|
function MenuTab({ tab, activeTab, setActiveTab }) {
|
||||||
return (
|
return (
|
||||||
<Link href={`/${tab.id}`} passHref>
|
<Link href={`/${tab.id}`} passHref>
|
||||||
<motion.a
|
<motion.a
|
||||||
@@ -84,39 +84,42 @@ function TabMenu({ tabs, activeTab, setActiveTab }) {
|
|||||||
className="hidden 2xl:flex xl:flex lg:flex md:flex space-x-1" // Hide on small screens
|
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} />
|
<MenuTab key={tab.id} tab={tab} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
))}
|
))}
|
||||||
</motion.div>
|
</motion.div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function CollapsibleMenu({ tabs, activeTab, setActiveTab }) {
|
function CollapsibleTab({ tab }) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function CollapsibleTabMenu() {
|
||||||
|
const [isOpen, setIsOpen] = useState(false);
|
||||||
|
|
||||||
|
const toggleMenu = () => {
|
||||||
|
setIsOpen(!isOpen);
|
||||||
|
};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<motion.div
|
<div className="flex items-center justify-end lg:hidden">
|
||||||
initial="hidden"
|
<button onClick={toggleMenu} className="focus:outline-none">
|
||||||
animate="visible"
|
<FaBars size={24} />
|
||||||
exit="hidden"
|
</button>
|
||||||
variants={{
|
{isOpen && (
|
||||||
visible: {
|
<div className="fixed top-16 right-4 flex flex-col items-center space-y-4 bg-gray-200 dark:bg-gray-800 rounded-md p-4 shadow-lg z-10">
|
||||||
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) => (
|
{tabs.map((tab) => (
|
||||||
<motion.div
|
<button
|
||||||
key={tab.id}
|
key={tab.id}
|
||||||
variants={{
|
onClick={() => console.log(`Clicked ${tab.label}`)} // Example onClick function
|
||||||
visible: { opacity: 1, y: 0 },
|
className={`text-lg font-bold text-white ${tabColors[tab.color]} rounded-full px-4 py-2 focus:outline-none`}
|
||||||
hidden: { opacity: 0, y: -20 }
|
|
||||||
}}
|
|
||||||
>
|
>
|
||||||
<Tab tab={tab} activeTab={activeTab} setActiveTab={setActiveTab} />
|
{tab.label}
|
||||||
</motion.div>
|
</button>
|
||||||
))}
|
))}
|
||||||
</motion.div>
|
</div>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -134,7 +137,7 @@ function Header() {
|
|||||||
{mounted && (
|
{mounted && (
|
||||||
<>
|
<>
|
||||||
<TabMenu tabs={tabs} activeTab={activeTab} setActiveTab={setActiveTab} />
|
<TabMenu tabs={tabs} activeTab={activeTab} setActiveTab={setActiveTab} />
|
||||||
<CollapsibleMenu tabs={tabs} activeTab={activeTab} setActiveTab={setActiveTab} />
|
<CollapsibleTabMenu />
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
</AnimatePresence>
|
</AnimatePresence>
|
||||||
|
|||||||
Reference in New Issue
Block a user