Files
GSM/temp/App.jsx
Alexander Zielonka 2b1fbb9f02 Initial commit: Homelab documentation
- infrastructure.md: Network topology, server overview, credentials
- gsm.md: Gameserver Monitor detailed documentation
- todo.md: Project roadmap and completed tasks
- CLAUDE.md: AI assistant context
- temp/: Frontend component backups

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-05 06:16:05 +01:00

39 lines
1.0 KiB
JavaScript

import { useState } from 'react'
import { BrowserRouter, Routes, Route, Navigate } from 'react-router-dom'
import { UserProvider } from './context/UserContext'
import Login from './pages/Login'
import Dashboard from './pages/Dashboard'
import ServerDetail from './pages/ServerDetail'
function App() {
const [token, setToken] = useState(localStorage.getItem('token'))
const handleLogin = (newToken) => {
localStorage.setItem('token', newToken)
setToken(newToken)
}
const handleLogout = () => {
localStorage.removeItem('token')
setToken(null)
}
if (!token) {
return <Login onLogin={handleLogin} />
}
return (
<UserProvider token={token} onLogout={handleLogout}>
<BrowserRouter>
<Routes>
<Route path="/" element={<Dashboard onLogout={handleLogout} />} />
<Route path="/server/:serverId" element={<ServerDetail />} />
<Route path="*" element={<Navigate to="/" replace />} />
</Routes>
</BrowserRouter>
</UserProvider>
)
}
export default App