feat(ui): show user and logout

This commit is contained in:
u1
2026-01-06 14:30:39 +01:00
parent 8217bae067
commit 5f8c2efe30
4 changed files with 96 additions and 1 deletions

View File

@@ -9,6 +9,7 @@ import Tabs from './ui/Tabs';
import MarketHeader from './features/market/MarketHeader';
import Button from './ui/Button';
import TopNav from './layout/TopNav';
import AuthStatus from './layout/AuthStatus';
function envNumber(name: string, fallback: number): number {
const v = (import.meta as any).env?.[name];
@@ -155,7 +156,7 @@ export default function App() {
return (
<AppShell
header={<TopNav active="trade" />}
header={<TopNav active="trade" rightSlot={<AuthStatus />} />}
top={<TickerBar items={topItems} />}
main={
<div className="tradeMain">

View File

@@ -0,0 +1,55 @@
import { useEffect, useState } from 'react';
import Button from '../ui/Button';
type WhoamiResponse = {
ok?: boolean;
user?: string | null;
};
export default function AuthStatus() {
const [user, setUser] = useState<string | null>(null);
const [loading, setLoading] = useState(true);
useEffect(() => {
let cancelled = false;
fetch('/whoami', { cache: 'no-store' })
.then(async (res) => {
const json = (await res.json().catch(() => null)) as WhoamiResponse | null;
const u = typeof json?.user === 'string' ? json.user.trim() : '';
return u || null;
})
.then((u) => {
if (cancelled) return;
setUser(u);
})
.catch(() => {
if (cancelled) return;
setUser(null);
})
.finally(() => {
if (cancelled) return;
setLoading(false);
});
return () => {
cancelled = true;
};
}, []);
const logout = () => {
window.location.href = '/logout';
};
return (
<div className="authStatus">
<Button size="sm" variant="ghost" type="button" onClick={logout}>
Wyloguj
</Button>
<div className="topNav__account">
<div className="topNav__accountName">{loading ? '…' : user || 'unknown'}</div>
<div className="topNav__accountSub">zalogowany</div>
</div>
</div>
);
}

View File

@@ -282,6 +282,12 @@ a:hover {
align-items: center;
}
.authStatus {
display: flex;
gap: 10px;
align-items: center;
}
.topNav__iconBtn {
background: rgba(255, 255, 255, 0.02);
border: 1px solid rgba(255, 255, 255, 0.12);