45 lines
1.6 KiB
TypeScript
45 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 { AuthProvider } from "@/hooks/useAuth";
|
|
import { CartProvider } from "@/contexts/CartContext";
|
|
import Index from "./pages/Index";
|
|
import Auth from "./pages/Auth";
|
|
import Products from "./pages/Products";
|
|
import ProductDetail from "./pages/ProductDetail";
|
|
import Checkout from "./pages/Checkout";
|
|
import Dashboard from "./pages/Dashboard";
|
|
import Admin from "./pages/Admin";
|
|
import NotFound from "./pages/NotFound";
|
|
|
|
const queryClient = new QueryClient();
|
|
|
|
const App = () => (
|
|
<QueryClientProvider client={queryClient}>
|
|
<TooltipProvider>
|
|
<AuthProvider>
|
|
<CartProvider>
|
|
<Toaster />
|
|
<Sonner />
|
|
<BrowserRouter>
|
|
<Routes>
|
|
<Route path="/" element={<Index />} />
|
|
<Route path="/auth" element={<Auth />} />
|
|
<Route path="/products" element={<Products />} />
|
|
<Route path="/products/:slug" element={<ProductDetail />} />
|
|
<Route path="/checkout" element={<Checkout />} />
|
|
<Route path="/dashboard" element={<Dashboard />} />
|
|
<Route path="/admin" element={<Admin />} />
|
|
<Route path="*" element={<NotFound />} />
|
|
</Routes>
|
|
</BrowserRouter>
|
|
</CartProvider>
|
|
</AuthProvider>
|
|
</TooltipProvider>
|
|
</QueryClientProvider>
|
|
);
|
|
|
|
export default App;
|