- 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>
39 lines
1.0 KiB
JavaScript
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
|