Listory/frontend/src/App.tsx

47 lines
1.8 KiB
TypeScript
Raw Normal View History

import React from "react";
import { Route, Routes } from "react-router-dom";
import { Footer } from "./components/Footer";
import { LoginFailure } from "./components/LoginFailure";
import { LoginLoading } from "./components/LoginLoading";
import { LoginSuccess } from "./components/LoginSuccess";
import { NavBar } from "./components/NavBar";
import { RecentListens } from "./components/RecentListens";
import { ReportListens } from "./components/ReportListens";
import { ReportTopAlbums } from "./components/ReportTopAlbums";
import { ReportTopArtists } from "./components/ReportTopArtists";
2021-10-26 20:09:52 +02:00
import { ReportTopGenres } from "./components/ReportTopGenres";
2021-05-22 14:57:28 +02:00
import { ReportTopTracks } from "./components/ReportTopTracks";
import { useAuth } from "./hooks/use-auth";
export function App() {
const { isLoaded } = useAuth();
if (!isLoaded) {
return <LoginLoading />;
}
return (
2022-07-24 17:45:29 +02:00
<div className="flex flex-col min-h-screen justify-between dark:bg-gray-900">
<header>
<NavBar />
</header>
<main className="mb-auto" /* mb-auto is for sticky footer */>
<Routes>
<Route path="/" />
<Route path="/login/success" element={<LoginSuccess />} />
<Route path="/login/failure" element={<LoginFailure />} />
<Route path="/listens" element={<RecentListens />} />
<Route path="/reports/listens" element={<ReportListens />} />
<Route path="/reports/top-artists" element={<ReportTopArtists />} />
<Route path="/reports/top-albums" element={<ReportTopAlbums />} />
<Route path="/reports/top-tracks" element={<ReportTopTracks />} />
<Route path="/reports/top-genres" element={<ReportTopGenres />} />
</Routes>
</main>
<footer>
<Footer />
</footer>
</div>
);
}