routes.tsx 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import React from 'react';
  2. import { createBrowserRouter, Navigate } from 'react-router';
  3. import { ProtectedRoute } from './components/ProtectedRoute';
  4. import { ErrorPage } from './components/ErrorPage';
  5. import { NotFoundPage } from './components/NotFoundPage';
  6. import HomePage from './pages/HomePage';
  7. import { MainLayout } from './layouts/MainLayout';
  8. import LoginPage from './pages/LoginPage';
  9. import RegisterPage from './pages/RegisterPage';
  10. import MemberPage from './pages/MemberPage';
  11. export const router = createBrowserRouter([
  12. {
  13. path: '/',
  14. element: <HomePage />
  15. },
  16. {
  17. path: '/login',
  18. element: <LoginPage />
  19. },
  20. {
  21. path: '/register',
  22. element: <RegisterPage />
  23. },
  24. {
  25. path: '/member',
  26. element: (
  27. <ProtectedRoute>
  28. <MainLayout />
  29. </ProtectedRoute>
  30. ),
  31. children: [
  32. {
  33. path: '',
  34. element: <MemberPage />
  35. },
  36. {
  37. path: '*',
  38. element: <NotFoundPage />,
  39. errorElement: <ErrorPage />
  40. },
  41. ],
  42. },
  43. {
  44. path: '*',
  45. element: <NotFoundPage />,
  46. errorElement: <ErrorPage />
  47. },
  48. ]);