diff options
| author | Pinapelz <yukais@pinapelz.com> | 2025-09-23 15:05:48 -0700 |
|---|---|---|
| committer | Pinapelz <yukais@pinapelz.com> | 2025-09-23 15:05:48 -0700 |
| commit | 6df78f254d98453520e8644996b917d673ee3978 (patch) | |
| tree | 9e2ed1a8cea6bbab145191e8f40b5b2c59b6c51c /frontend/src/components/NavBar.tsx | |
| parent | abca372d8ef3d9ab0154c3706d88e0c3772bacc3 (diff) | |
initial mobile CSS style
Diffstat (limited to 'frontend/src/components/NavBar.tsx')
| -rw-r--r-- | frontend/src/components/NavBar.tsx | 59 |
1 files changed, 57 insertions, 2 deletions
diff --git a/frontend/src/components/NavBar.tsx b/frontend/src/components/NavBar.tsx index 4be8607..ac70dfb 100644 --- a/frontend/src/components/NavBar.tsx +++ b/frontend/src/components/NavBar.tsx @@ -1,10 +1,13 @@ import { Link } from "react-router"; +import { useState } from "react"; export const NavBar = ({ currentPage, user, handleLogout }: { currentPage: string; user: { username: string }; handleLogout: () => void; }) => { + const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false); + const menuOptions = ( <> <Link @@ -14,6 +17,7 @@ export const NavBar = ({ currentPage, user, handleLogout }: { ? 'bg-violet-600 text-white shadow-lg shadow-violet-500/25' : 'text-slate-300 hover:text-white hover:bg-slate-800/50' }`} + onClick={() => setIsMobileMenuOpen(false)} > Home </Link> @@ -24,6 +28,7 @@ export const NavBar = ({ currentPage, user, handleLogout }: { ? 'bg-violet-600 text-white shadow-lg shadow-violet-500/25' : 'text-slate-300 hover:text-white hover:bg-slate-800/50' }`} + onClick={() => setIsMobileMenuOpen(false)} > Import Data </Link> @@ -34,6 +39,7 @@ export const NavBar = ({ currentPage, user, handleLogout }: { ? 'bg-violet-600 text-white shadow-lg shadow-violet-500/25' : 'text-slate-300 hover:text-white hover:bg-slate-800/50' }`} + onClick={() => setIsMobileMenuOpen(false)} > Community Scores </Link> @@ -44,13 +50,16 @@ export const NavBar = ({ currentPage, user, handleLogout }: { <nav className="border-b border-slate-800/50 bg-slate-950/95 backdrop-blur-sm sticky top-0 z-50"> <div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8"> <div className="flex items-center justify-between h-16"> + {/* Logo */} <div className="flex items-center space-x-3"> <div className="w-8 h-8 bg-gradient-to-r from-violet-600 to-violet-700 rounded-lg flex items-center justify-center shadow-lg"> <span className="text-white font-bold text-sm">M</span> </div> <span className="text-white font-semibold text-lg">Mirage</span> </div> - <div className="flex items-center space-x-4"> + + {/* Desktop Menu */} + <div className="hidden md:flex items-center space-x-4"> {menuOptions} <span className="text-slate-300 text-sm"> Welcome back,{" "} @@ -65,8 +74,54 @@ export const NavBar = ({ currentPage, user, handleLogout }: { Sign Out </button> </div> + + {/* Mobile menu button */} + <div className="flex md:hidden"> + <button + onClick={() => setIsMobileMenuOpen(!isMobileMenuOpen)} + className="inline-flex items-center justify-center p-2 rounded-md text-slate-300 hover:text-white hover:bg-slate-800/50 focus:outline-none focus:ring-2 focus:ring-inset focus:ring-violet-500" + aria-expanded={isMobileMenuOpen} + > + <span className="sr-only">Open main menu</span> + {isMobileMenuOpen ? ( + <svg className="block h-6 w-6" fill="none" viewBox="0 0 24 24" stroke="currentColor"> + <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M6 18L18 6M6 6l12 12" /> + </svg> + ) : ( + <svg className="block h-6 w-6" fill="none" viewBox="0 0 24 24" stroke="currentColor"> + <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M4 6h16M4 12h16M4 18h16" /> + </svg> + )} + </button> + </div> </div> + + {/* Mobile Menu */} + {isMobileMenuOpen && ( + <div className="md:hidden"> + <div className="px-2 pt-2 pb-3 space-y-1"> + {menuOptions} + <div className="border-t border-slate-800/50 mt-3 pt-3"> + <div className="text-slate-300 text-sm px-4 py-2"> + Welcome back,{" "} + <span className="text-violet-400 font-medium"> + {user.username} + </span> + </div> + <button + onClick={() => { + handleLogout(); + setIsMobileMenuOpen(false); + }} + className="w-full text-left text-slate-300 hover:text-white px-4 py-2 rounded-lg text-sm font-medium transition-all duration-200 hover:bg-slate-800/50" + > + Sign Out + </button> + </div> + </div> + </div> + )} </div> </nav> ); -}; +};
\ No newline at end of file |
