rework tabs

This commit is contained in:
Timothy Pidashev
2024-03-19 22:31:41 -07:00
parent 55391f7ee5
commit a2555d1940

View File

@@ -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>