|
|
|
@ -1,23 +1,26 @@
|
|
|
|
|
import { Suspense, lazy } from "react";
|
|
|
|
|
import { createBrowserRouter } from "react-router-dom";
|
|
|
|
|
import App from "@/App";
|
|
|
|
|
import HomeLayout from "@/layouts/HomeLayout";
|
|
|
|
|
import RootLayout from "@/layouts/RootLayout";
|
|
|
|
|
import About from "@/pages/About";
|
|
|
|
|
import AdminSignIn from "@/pages/AdminSignIn";
|
|
|
|
|
import Archived from "@/pages/Archived";
|
|
|
|
|
import AuthCallback from "@/pages/AuthCallback";
|
|
|
|
|
import Explore from "@/pages/Explore";
|
|
|
|
|
import Home from "@/pages/Home";
|
|
|
|
|
import Inboxes from "@/pages/Inboxes";
|
|
|
|
|
import MemoDetail from "@/pages/MemoDetail";
|
|
|
|
|
import NotFound from "@/pages/NotFound";
|
|
|
|
|
import PermissionDenied from "@/pages/PermissionDenied";
|
|
|
|
|
import Resources from "@/pages/Resources";
|
|
|
|
|
import Setting from "@/pages/Setting";
|
|
|
|
|
import SignIn from "@/pages/SignIn";
|
|
|
|
|
import SignUp from "@/pages/SignUp";
|
|
|
|
|
import UserProfile from "@/pages/UserProfile";
|
|
|
|
|
import MemoDetailRedirect from "./MemoDetailRedirect";
|
|
|
|
|
import Loading from "@/pages/Loading";
|
|
|
|
|
|
|
|
|
|
const About = lazy(() => import("@/pages/About"));
|
|
|
|
|
const AdminSignIn = lazy(() => import("@/pages/AdminSignIn"));
|
|
|
|
|
const Archived = lazy(() => import("@/pages/Archived"));
|
|
|
|
|
const AuthCallback = lazy(() => import("@/pages/AuthCallback"));
|
|
|
|
|
const Explore = lazy(() => import("@/pages/Explore"));
|
|
|
|
|
const Inboxes = lazy(() => import("@/pages/Inboxes"));
|
|
|
|
|
const MemoDetail = lazy(() => import("@/pages/MemoDetail"));
|
|
|
|
|
const NotFound = lazy(() => import("@/pages/NotFound"));
|
|
|
|
|
const PermissionDenied = lazy(() => import("@/pages/PermissionDenied"));
|
|
|
|
|
const Resources = lazy(() => import("@/pages/Resources"));
|
|
|
|
|
const Setting = lazy(() => import("@/pages/Setting"));
|
|
|
|
|
const SignIn = lazy(() => import("@/pages/SignIn"));
|
|
|
|
|
const SignUp = lazy(() => import("@/pages/SignUp"));
|
|
|
|
|
const UserProfile = lazy(() => import("@/pages/UserProfile"));
|
|
|
|
|
const MemoDetailRedirect = lazy(() => import("./MemoDetailRedirect"));
|
|
|
|
|
|
|
|
|
|
export enum Routes {
|
|
|
|
|
ROOT = "/",
|
|
|
|
@ -40,19 +43,35 @@ const router = createBrowserRouter([
|
|
|
|
|
children: [
|
|
|
|
|
{
|
|
|
|
|
path: "",
|
|
|
|
|
element: <SignIn />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<SignIn />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "admin",
|
|
|
|
|
element: <AdminSignIn />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<AdminSignIn />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "signup",
|
|
|
|
|
element: <SignUp />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<SignUp />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "callback",
|
|
|
|
|
element: <AuthCallback />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<AuthCallback />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
},
|
|
|
|
@ -69,54 +88,102 @@ const router = createBrowserRouter([
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: Routes.EXPLORE,
|
|
|
|
|
element: <Explore />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<Explore />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: Routes.ARCHIVED,
|
|
|
|
|
element: <Archived />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<Archived />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "u/:username",
|
|
|
|
|
element: <UserProfile />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<UserProfile />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: Routes.RESOURCES,
|
|
|
|
|
element: <Resources />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<Resources />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: Routes.INBOX,
|
|
|
|
|
element: <Inboxes />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<Inboxes />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: Routes.SETTING,
|
|
|
|
|
element: <Setting />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<Setting />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "memos/:uid",
|
|
|
|
|
element: <MemoDetail />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<MemoDetail />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: Routes.ABOUT,
|
|
|
|
|
element: <About />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<About />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
// Redirect old path to new path.
|
|
|
|
|
{
|
|
|
|
|
path: "m/:uid",
|
|
|
|
|
element: <MemoDetailRedirect />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<MemoDetailRedirect />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "403",
|
|
|
|
|
element: <PermissionDenied />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<PermissionDenied />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "404",
|
|
|
|
|
element: <NotFound />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<NotFound />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
path: "*",
|
|
|
|
|
element: <NotFound />,
|
|
|
|
|
element: (
|
|
|
|
|
<Suspense fallback={<Loading />}>
|
|
|
|
|
<NotFound />
|
|
|
|
|
</Suspense>
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|