2025-12-17 11:12:10 +00:00
|
|
|
import { useState } from 'react';
|
|
|
|
|
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 Header from "@/components/layout/Header";
|
|
|
|
|
import BottomNav from "@/components/layout/BottomNav";
|
2025-12-19 20:14:20 +00:00
|
|
|
import Footer from "@/components/layout/Footer";
|
2025-12-17 11:12:10 +00:00
|
|
|
import SearchModal from "@/components/layout/SearchModal";
|
|
|
|
|
import MenuSheet from "@/components/layout/MenuSheet";
|
|
|
|
|
import Home from "./pages/Index";
|
|
|
|
|
import SoporteVital from "./pages/SoporteVital";
|
|
|
|
|
import Patologias from "./pages/Patologias";
|
|
|
|
|
import Escena from "./pages/Escena";
|
|
|
|
|
import Farmacos from "./pages/Farmacos";
|
|
|
|
|
import Herramientas from "./pages/Herramientas";
|
|
|
|
|
import Material from "./pages/Material";
|
|
|
|
|
import Telefono from "./pages/Telefono";
|
|
|
|
|
import Comunicacion from "./pages/Comunicacion";
|
|
|
|
|
import ManualIndex from "./pages/ManualIndex";
|
|
|
|
|
import ManualViewer from "./pages/ManualViewer";
|
|
|
|
|
import NotFound from "./pages/NotFound";
|
2025-12-17 14:19:57 +00:00
|
|
|
import RCP from "./pages/RCP";
|
|
|
|
|
import Ictus from "./pages/Ictus";
|
|
|
|
|
import Shock from "./pages/Shock";
|
|
|
|
|
import ViaAerea from "./pages/ViaAerea";
|
2025-12-17 11:12:10 +00:00
|
|
|
|
|
|
|
|
const queryClient = new QueryClient();
|
|
|
|
|
|
|
|
|
|
const App = () => {
|
|
|
|
|
const [isSearchOpen, setIsSearchOpen] = useState(false);
|
|
|
|
|
const [isMenuOpen, setIsMenuOpen] = useState(false);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<QueryClientProvider client={queryClient}>
|
|
|
|
|
<TooltipProvider>
|
|
|
|
|
<Toaster />
|
|
|
|
|
<Sonner />
|
|
|
|
|
<BrowserRouter>
|
2025-12-19 20:14:20 +00:00
|
|
|
<div className="min-h-screen bg-background flex flex-col">
|
2025-12-17 11:12:10 +00:00
|
|
|
<Header
|
|
|
|
|
onSearchClick={() => setIsSearchOpen(true)}
|
|
|
|
|
onMenuClick={() => setIsMenuOpen(true)}
|
|
|
|
|
/>
|
|
|
|
|
|
2025-12-19 20:14:20 +00:00
|
|
|
<main className="pt-14 pb-safe flex-1">
|
2025-12-17 11:12:10 +00:00
|
|
|
<div className="container max-w-2xl py-4">
|
|
|
|
|
<Routes>
|
|
|
|
|
<Route
|
|
|
|
|
path="/"
|
|
|
|
|
element={<Home onSearchClick={() => setIsSearchOpen(true)} />}
|
|
|
|
|
/>
|
|
|
|
|
<Route path="/soporte-vital" element={<SoporteVital />} />
|
|
|
|
|
<Route path="/patologias" element={<Patologias />} />
|
|
|
|
|
<Route path="/escena" element={<Escena />} />
|
|
|
|
|
<Route path="/farmacos" element={<Farmacos />} />
|
|
|
|
|
<Route path="/herramientas" element={<Herramientas />} />
|
|
|
|
|
<Route path="/material" element={<Material />} />
|
|
|
|
|
<Route path="/telefono" element={<Telefono />} />
|
|
|
|
|
<Route path="/comunicacion" element={<Comunicacion />} />
|
|
|
|
|
<Route path="/manual" element={<ManualIndex />} />
|
|
|
|
|
<Route path="/manual/:parte/:bloque/:capitulo" element={<ManualViewer />} />
|
2025-12-17 14:19:57 +00:00
|
|
|
<Route path="/rcp" element={<RCP />} />
|
|
|
|
|
<Route path="/ictus" element={<Ictus />} />
|
|
|
|
|
<Route path="/shock" element={<Shock />} />
|
|
|
|
|
<Route path="/via-aerea" element={<ViaAerea />} />
|
2025-12-17 11:12:10 +00:00
|
|
|
<Route path="*" element={<NotFound />} />
|
|
|
|
|
</Routes>
|
|
|
|
|
</div>
|
|
|
|
|
</main>
|
|
|
|
|
|
|
|
|
|
<BottomNav />
|
|
|
|
|
|
2025-12-19 20:14:20 +00:00
|
|
|
<Footer />
|
|
|
|
|
|
2025-12-17 11:12:10 +00:00
|
|
|
<SearchModal
|
|
|
|
|
isOpen={isSearchOpen}
|
|
|
|
|
onClose={() => setIsSearchOpen(false)}
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
|
|
<MenuSheet
|
|
|
|
|
isOpen={isMenuOpen}
|
|
|
|
|
onClose={() => setIsMenuOpen(false)}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</BrowserRouter>
|
|
|
|
|
</TooltipProvider>
|
|
|
|
|
</QueryClientProvider>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default App;
|