routes.tsx 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. import React from 'react';
  2. import { createBrowserRouter, Navigate } from 'react-router';
  3. import { ProtectedRoute } from './components/ProtectedRoute';
  4. import { MainLayout } from './layouts/MainLayout';
  5. import { ErrorPage } from './components/ErrorPage';
  6. import { NotFoundPage } from './components/NotFoundPage';
  7. import { DashboardPage } from './pages/Dashboard';
  8. import { UsersPage } from './pages/Users';
  9. import { LoginPage } from './pages/Login';
  10. import { FilesPage } from './pages/Files';
  11. export const router = createBrowserRouter([
  12. {
  13. path: '/',
  14. element: <Navigate to="/admin" replace />
  15. },
  16. {
  17. path: '/admin/login',
  18. element: <LoginPage />
  19. },
  20. {
  21. path: '/admin',
  22. element: (
  23. <ProtectedRoute>
  24. <MainLayout />
  25. </ProtectedRoute>
  26. ),
  27. children: [
  28. {
  29. index: true,
  30. element: <Navigate to="/admin/dashboard" />
  31. },
  32. {
  33. path: 'dashboard',
  34. element: <DashboardPage />,
  35. errorElement: <ErrorPage />
  36. },
  37. {
  38. path: 'users',
  39. element: <UsersPage />,
  40. errorElement: <ErrorPage />
  41. },
  42. {
  43. path: 'files',
  44. element: <FilesPage />,
  45. errorElement: <ErrorPage />
  46. },
  47. {
  48. path: '*',
  49. element: <NotFoundPage />,
  50. errorElement: <ErrorPage />
  51. },
  52. ],
  53. },
  54. {
  55. path: '*',
  56. element: <NotFoundPage />,
  57. errorElement: <ErrorPage />
  58. },
  59. ]);