App.tsx 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import { BrowserRouter, Routes, Route } from 'react-router-dom';
  2. import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
  3. import { Layout } from './components/Layout';
  4. import { PrintersPage } from './pages/PrintersPage';
  5. import { ArchivesPage } from './pages/ArchivesPage';
  6. import { QueuePage } from './pages/QueuePage';
  7. import { StatsPage } from './pages/StatsPage';
  8. import { SettingsPage } from './pages/SettingsPage';
  9. import { ProfilesPage } from './pages/ProfilesPage';
  10. import { MaintenancePage } from './pages/MaintenancePage';
  11. import { CameraPage } from './pages/CameraPage';
  12. import { ExternalLinkPage } from './pages/ExternalLinkPage';
  13. import { useWebSocket } from './hooks/useWebSocket';
  14. import { ThemeProvider } from './contexts/ThemeContext';
  15. import { ToastProvider } from './contexts/ToastContext';
  16. const queryClient = new QueryClient({
  17. defaultOptions: {
  18. queries: {
  19. staleTime: 1000 * 60,
  20. retry: 1,
  21. },
  22. },
  23. });
  24. function WebSocketProvider({ children }: { children: React.ReactNode }) {
  25. useWebSocket();
  26. return <>{children}</>;
  27. }
  28. function App() {
  29. return (
  30. <ThemeProvider>
  31. <ToastProvider>
  32. <QueryClientProvider client={queryClient}>
  33. <WebSocketProvider>
  34. <BrowserRouter>
  35. <Routes>
  36. {/* Camera page - standalone, no layout */}
  37. <Route path="/camera/:printerId" element={<CameraPage />} />
  38. <Route path="/" element={<Layout />}>
  39. <Route index element={<PrintersPage />} />
  40. <Route path="archives" element={<ArchivesPage />} />
  41. <Route path="queue" element={<QueuePage />} />
  42. <Route path="stats" element={<StatsPage />} />
  43. <Route path="profiles" element={<ProfilesPage />} />
  44. <Route path="maintenance" element={<MaintenancePage />} />
  45. <Route path="settings" element={<SettingsPage />} />
  46. <Route path="external/:id" element={<ExternalLinkPage />} />
  47. </Route>
  48. </Routes>
  49. </BrowserRouter>
  50. </WebSocketProvider>
  51. </QueryClientProvider>
  52. </ToastProvider>
  53. </ThemeProvider>
  54. );
  55. }
  56. export default App;