feat: add telegram-style resource stream

This commit is contained in:
TerryM
2026-05-25 05:25:57 +08:00
parent aaebd7ccd1
commit a784f159fe
45 changed files with 3201 additions and 1160 deletions

View File

@@ -6,12 +6,13 @@ import { Home } from "./pages/Home";
import { Browse } from "./pages/Browse";
import { CategoryPage } from "./pages/CategoryPage";
import { SearchPage } from "./pages/SearchPage";
import { FavoritesPage } from "./pages/FavoritesPage";
import { ResourceDetail } from "./pages/ResourceDetail";
import { PostRedirect } from "./pages/PostRedirect";
import { AboutPage } from "./pages/AboutPage";
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";
const WalletPage = lazy(() =>
import("./pages/WalletPage").then((module) => ({
@@ -25,38 +26,41 @@ export default function App() {
return (
<I18nProvider>
<AdminRouterModeProvider value="absolute">
<BrowserRouter>
<Routes>
<Route element={<PublicLayout />}>
<Route path="/" element={<Home />} />
<Route path="/browse" element={<Browse />} />
<Route path="/category/:slug" element={<CategoryPage />} />
<Route path="/search" element={<SearchPage />} />
<Route path="/favorites" element={<FavoritesPage />} />
<Route path="/resource/:id" element={<ResourceDetail />} />
<Route
path="/wallet"
element={
<Suspense fallback={null}>
<WalletPage />
</Suspense>
}
/>
<Route path="/about" element={<AboutPage />} />
</Route>
<ImageLightboxProvider>
<VideoPlayerProvider>
<BrowserRouter>
<Routes>
<Route element={<PublicLayout />}>
<Route path="/" element={<Home />} />
<Route path="/browse" element={<Browse />} />
<Route path="/category/:slug" element={<CategoryPage />} />
<Route path="/search" element={<SearchPage />} />
<Route path="/resource/:id" element={<PostRedirect />} />
<Route
path="/wallet"
element={
<Suspense fallback={null}>
<WalletPage />
</Suspense>
}
/>
<Route path="/about" element={<AboutPage />} />
</Route>
{adminEnabled ? (
AdminRouteTree()
) : (
<Route
path={`${adminUiPrefix}/*`}
element={<Navigate to="/" replace />}
/>
)}
{adminEnabled ? (
AdminRouteTree()
) : (
<Route
path={`${adminUiPrefix}/*`}
element={<Navigate to="/" replace />}
/>
)}
<Route path="*" element={<Navigate to="/" replace />} />
</Routes>
</BrowserRouter>
<Route path="*" element={<Navigate to="/" replace />} />
</Routes>
</BrowserRouter>
</VideoPlayerProvider>
</ImageLightboxProvider>
</AdminRouterModeProvider>
</I18nProvider>
);