aboutsummaryrefslogtreecommitdiffstats
path: root/frontend/src/components/NavBar.tsx
diff options
context:
space:
mode:
authorPinapelz <yukais@pinapelz.com>2025-09-23 15:05:48 -0700
committerPinapelz <yukais@pinapelz.com>2025-09-23 15:05:48 -0700
commit6df78f254d98453520e8644996b917d673ee3978 (patch)
tree9e2ed1a8cea6bbab145191e8f40b5b2c59b6c51c /frontend/src/components/NavBar.tsx
parentabca372d8ef3d9ab0154c3706d88e0c3772bacc3 (diff)
initial mobile CSS style
Diffstat (limited to 'frontend/src/components/NavBar.tsx')
-rw-r--r--frontend/src/components/NavBar.tsx59
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
send patches to the email below
yukais@pinapelz.com
include the subject [PATCH repo_name]
pinapelz.com
homepage