Partypack/src/App.tsx
2024-02-04 22:28:42 +01:00

72 lines
2.9 KiB
TypeScript

import "./utils/Requests";
import { useState } from "react";
import { ToastContainer } from "react-toastify";
import { BaseStyles, ThemeProvider, theme } from "@primer/react";
import { SiteHeader } from "./components/SiteHeader";
import { VerifyAdmin } from "./components/VerifyAdmin";
import { VerifyRole } from "./components/VerifyRole";
import { UserPermissions } from "./utils/Extensions";
import { BrowserRouter, Route, Routes } from "react-router-dom";
import { CookiesProvider } from "react-cookie";
import { Home } from "./routes/Home";
import { Download } from "./routes/Download";
import { Tracks } from "./routes/Tracks";
import { TrackSubmission } from "./routes/TrackSubmission";
import { Profile } from "./routes/Profile";
import { NotFound } from "./routes/404";
import { Credits } from "./routes/Credits";
import { AdminHome } from "./routes/AdminHome";
import { AdminTrackList } from "./routes/AdminTrackList";
import { AdminSubmissions } from "./routes/AdminSubmissions";
import { AdminFeaturedTab } from "./routes/AdminFeaturedTab";
import { SiteContext, SiteState } from "./utils/State";
import merge from "deepmerge";
import "react-toastify/dist/ReactToastify.css";
import "./css/index.css";
import { FrequentlyAskedQuestions } from "./routes/FrequentlyAskedQuestions";
const DefaultTheme = merge(theme, {}); // we'll use this!! eventually!!!
function App() {
const [reactState, setReactState] = useState<SiteState>({} as SiteState);
return (
<ThemeProvider colorMode="dark" theme={DefaultTheme}>
<BaseStyles>
<div>
<CookiesProvider />
<ToastContainer theme="dark" position="bottom-right" draggable={false} pauseOnHover={false} pauseOnFocusLoss={false} />
<BrowserRouter>
<SiteContext.Provider value={{ state: reactState, setState: setReactState }}>
<SiteHeader />
<div className="content">
<Routes>
{/* User-accessible routes */}
<Route path="/" element={<Home />} />
<Route path="/download" element={<Download />} />
<Route path="/faq" element={<FrequentlyAskedQuestions />} />
<Route path="/tracks" element={<Tracks />} />
<Route path="/submissions" element={<TrackSubmission />} />
<Route path="/profile" element={<Profile />} />
<Route path="/credits" element={<Credits />} />
<Route path="*" element={<NotFound />} />
{/* Staff routes */}
<Route path="/mod/submissions" element={<VerifyRole role={UserPermissions.TrackVerifier}><AdminSubmissions /></VerifyRole>} />
{/* Admin routes */}
<Route path="/admin" element={<VerifyAdmin><AdminHome /></VerifyAdmin>} />
<Route path="/admin/tracks" element={<VerifyAdmin><AdminTrackList /></VerifyAdmin>} />
<Route path="/admin/featured" element={<VerifyAdmin><AdminFeaturedTab /></VerifyAdmin>} />
</Routes>
</div>
</SiteContext.Provider>
</BrowserRouter>
</div>
</BaseStyles>
</ThemeProvider>
);
}
export default App;