42 lines
1.6 KiB
TypeScript
42 lines
1.6 KiB
TypeScript
import { Toaster } from "@/components/ui/toaster";
|
|
import { Toaster as Sonner } from "@/components/ui/sonner";
|
|
import { TooltipProvider } from "@/components/ui/tooltip";
|
|
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
|
|
import { BrowserRouter, Routes, Route } from "react-router-dom";
|
|
import { ThemeProvider } from "@/components/ThemeProvider";
|
|
import { AnalyticsProvider } from "@/components/AnalyticsProvider";
|
|
import Index from "./pages/Index";
|
|
import ContactPage from "./pages/Contact";
|
|
import AGBPage from "./pages/AGB";
|
|
import ImpressumPage from "./pages/Impressum";
|
|
import AboutPage from "./pages/About";
|
|
import NotFound from "./pages/NotFound";
|
|
|
|
const queryClient = new QueryClient();
|
|
|
|
const App = () => (
|
|
<ThemeProvider>
|
|
<QueryClientProvider client={queryClient}>
|
|
<TooltipProvider>
|
|
<Toaster />
|
|
<Sonner />
|
|
<BrowserRouter future={{ v7_startTransition: true, v7_relativeSplatPath: true }}>
|
|
<AnalyticsProvider>
|
|
<Routes>
|
|
<Route path="/" element={<Index />} />
|
|
<Route path="/kontakt" element={<ContactPage />} />
|
|
<Route path="/agb" element={<AGBPage />} />
|
|
<Route path="/impressum" element={<ImpressumPage />} />
|
|
<Route path="/ueber-uns" element={<AboutPage />} />
|
|
{/* ADD ALL CUSTOM ROUTES ABOVE THE CATCH-ALL "*" ROUTE */}
|
|
<Route path="*" element={<NotFound />} />
|
|
</Routes>
|
|
</AnalyticsProvider>
|
|
</BrowserRouter>
|
|
</TooltipProvider>
|
|
</QueryClientProvider>
|
|
</ThemeProvider>
|
|
);
|
|
|
|
export default App;
|