5f476542e2
- Add Login page with email/password form - Add Register page with email validation - Add forgot password link to login page - Update App.tsx with auth routes and AuthProvider - Add email validation in registration form
76 lines
2.4 KiB
TypeScript
76 lines
2.4 KiB
TypeScript
import { BrowserRouter as Router, Routes, Route, Navigate } from 'react-router-dom';
|
|
import { Dashboard } from './pages/Dashboard';
|
|
import { Editor } from './pages/Editor';
|
|
import { Settings } from './pages/Settings';
|
|
import { Profile } from './pages/Profile';
|
|
import { Login } from './pages/Login';
|
|
import { Register } from './pages/Register';
|
|
import { PasswordResetRequest } from './pages/PasswordResetRequest';
|
|
import { PasswordResetConfirm } from './pages/PasswordResetConfirm';
|
|
import { ThemeProvider } from './context/ThemeContext';
|
|
import { UploadProvider } from './context/UploadContext';
|
|
import { AuthProvider } from './context/AuthContext';
|
|
import { ProtectedRoute } from './components/ProtectedRoute';
|
|
|
|
function App() {
|
|
return (
|
|
<ThemeProvider>
|
|
<Router>
|
|
<AuthProvider>
|
|
<UploadProvider>
|
|
<Routes>
|
|
<Route path="/login" element={<Login />} />
|
|
<Route path="/register" element={<Register />} />
|
|
<Route path="/reset-password" element={<PasswordResetRequest />} />
|
|
<Route path="/reset-password-confirm" element={<PasswordResetConfirm />} />
|
|
<Route
|
|
path="/"
|
|
element={
|
|
<ProtectedRoute>
|
|
<Dashboard />
|
|
</ProtectedRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path="/collections"
|
|
element={
|
|
<ProtectedRoute>
|
|
<Dashboard />
|
|
</ProtectedRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path="/settings"
|
|
element={
|
|
<ProtectedRoute>
|
|
<Settings />
|
|
</ProtectedRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path="/profile"
|
|
element={
|
|
<ProtectedRoute>
|
|
<Profile />
|
|
</ProtectedRoute>
|
|
}
|
|
/>
|
|
<Route
|
|
path="/editor/:id"
|
|
element={
|
|
<ProtectedRoute>
|
|
<Editor />
|
|
</ProtectedRoute>
|
|
}
|
|
/>
|
|
<Route path="*" element={<Navigate to="/" replace />} />
|
|
</Routes>
|
|
</UploadProvider>
|
|
</AuthProvider>
|
|
</Router>
|
|
</ThemeProvider>
|
|
);
|
|
}
|
|
|
|
export default App;
|