Files
Arkie-Library-Frontend/src/App.tsx

139 lines
6.2 KiB
TypeScript
Raw Normal View History

2026-05-16 00:18:22 +08:00
import { BrowserRouter, Navigate, Route, Routes } from "react-router-dom";
import { I18nProvider } from "./i18n";
import { MotionProvider } from "./motion";
import { ToastProvider } from "./components/Toast";
2026-06-01 23:00:28 +08:00
import { SaveToAlbumGuideProvider } from "./components/SaveToAlbumGuide";
2026-06-02 00:28:22 +08:00
import { RainbowWalletProvider } from "./wallet/RainbowWalletProvider";
import { WalletProvider } from "./wallet/WalletProvider";
2026-05-16 00:18:22 +08:00
import { PublicLayout } from "./layouts/PublicLayout";
2026-06-01 15:09:58 +08:00
import { LocalizedHomePage } from "./pages/LocalizedHome";
2026-05-16 00:18:22 +08:00
import { Browse } from "./pages/Browse";
import { CategoriesPage } from "./pages/Categories";
2026-05-28 22:36:08 +08:00
import { CategoryPage } from "./pages/Category";
import { OfficialRecommendationsPage } from "./pages/OfficialRecommendations";
2026-05-26 14:46:05 +08:00
import { SearchPage } from "./pages/Search";
import { PostRedirect } from "./pages/PostRedirect";
import { ScrollToTop } from "./components/ScrollToTop";
import { PageTitleProvider } from "./components/PageTitleContext";
import Favorites from "./pages/Favorites";
2026-05-16 00:18:22 +08:00
import { adminUiPrefix } from "./adminPaths";
import { AdminRouteTree } from "./adminRouteTree";
import { AdminRouterModeProvider } from "./adminRouterMode";
import { ImageLightboxProvider } from "./components/messageStream/overlays/ImageLightbox";
import { VideoPlayerProvider } from "./components/messageStream/overlays/VideoPlayer";
2026-06-01 15:09:58 +08:00
import { localizedHomeRoutes } from "./languageRoutes";
2026-05-16 00:18:22 +08:00
const adminEnabled = import.meta.env.VITE_DISABLE_ADMIN !== "true";
export default function App() {
return (
<I18nProvider>
<MotionProvider>
<ToastProvider>
2026-06-02 00:28:22 +08:00
<RainbowWalletProvider>
<WalletProvider>
<SaveToAlbumGuideProvider>
<AdminRouterModeProvider value="absolute">
<ImageLightboxProvider>
<VideoPlayerProvider>
<PageTitleProvider>
<BrowserRouter>
<ScrollToTop />
<Routes>
<Route element={<PublicLayout />}>
{/* English (root, no prefix) */}
2026-06-01 23:00:28 +08:00
<Route
2026-06-02 00:28:22 +08:00
path="/"
element={<LocalizedHomePage targetLang="en" />}
2026-06-01 23:00:28 +08:00
/>
2026-06-02 00:28:22 +08:00
<Route path="/browse" element={<Browse />} />
2026-06-01 23:00:28 +08:00
<Route
2026-06-02 00:28:22 +08:00
path="/categories"
2026-06-01 23:00:28 +08:00
element={<CategoriesPage />}
/>
<Route
2026-06-02 00:28:22 +08:00
path="/official-recommendations"
2026-06-01 23:00:28 +08:00
element={<OfficialRecommendationsPage />}
/>
<Route
2026-06-02 00:28:22 +08:00
path="/category/:slug"
2026-06-01 23:00:28 +08:00
element={<CategoryPage />}
/>
2026-06-02 00:28:22 +08:00
<Route path="/search" element={<SearchPage />} />
2026-06-01 23:00:28 +08:00
<Route
2026-06-02 00:28:22 +08:00
path="/resource/:id"
2026-06-01 23:00:28 +08:00
element={<PostRedirect />}
/>
2026-06-02 00:28:22 +08:00
<Route
path="/favorites"
element={<Favorites />}
/>
{/* Each non-English language gets its own nested tree. */}
{localizedHomeRoutes.map((route) => (
<Route key={route.path} path={route.path}>
<Route
index
element={
<LocalizedHomePage
targetLang={route.lang}
/>
}
/>
<Route path="browse" element={<Browse />} />
<Route
path="categories"
element={<CategoriesPage />}
/>
<Route
path="official-recommendations"
element={<OfficialRecommendationsPage />}
/>
<Route
path="category/:slug"
element={<CategoryPage />}
/>
<Route
path="search"
element={<SearchPage />}
/>
<Route
path="resource/:id"
element={<PostRedirect />}
/>
<Route
path="favorites"
element={<Favorites />}
/>
</Route>
))}
2026-06-01 23:00:28 +08:00
</Route>
2026-05-16 00:18:22 +08:00
2026-06-02 00:28:22 +08:00
{adminEnabled ? (
AdminRouteTree()
) : (
<Route
path={`${adminUiPrefix}/*`}
element={<Navigate to="/" replace />}
/>
)}
2026-05-16 00:18:22 +08:00
2026-06-02 00:28:22 +08:00
<Route
path="*"
element={<Navigate to="/" replace />}
/>
</Routes>
</BrowserRouter>
</PageTitleProvider>
</VideoPlayerProvider>
</ImageLightboxProvider>
</AdminRouterModeProvider>
</SaveToAlbumGuideProvider>
</WalletProvider>
</RainbowWalletProvider>
</ToastProvider>
</MotionProvider>
2026-05-16 00:18:22 +08:00
</I18nProvider>
);
}