App.tsx 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. import 'react-native-gesture-handler';
  2. import { QueryClientProvider } from '@tanstack/react-query';
  3. import { NavigationContainer } from '@react-navigation/native';
  4. import { queryClient } from 'src/utils/queryClient';
  5. import Route from './Route';
  6. import { ConnectionProvider } from 'src/contexts/ConnectionContext';
  7. import ConnectionBanner from 'src/components/ConnectionBanner/ConnectionBanner';
  8. import { RegionProvider } from 'src/contexts/RegionContext';
  9. import { ErrorProvider, useError } from 'src/contexts/ErrorContext';
  10. import { useEffect } from 'react';
  11. import { setupInterceptors } from 'src/utils/request';
  12. import { ErrorModal } from 'src/components';
  13. import { NotificationProvider } from 'src/contexts/NotificationContext';
  14. const App = () => {
  15. return (
  16. <QueryClientProvider client={queryClient}>
  17. <NotificationProvider>
  18. <ErrorProvider>
  19. <InnerApp />
  20. </ErrorProvider>
  21. </NotificationProvider>
  22. </QueryClientProvider>
  23. );
  24. };
  25. const InnerApp = () => {
  26. const errorContext = useError();
  27. useEffect(() => {
  28. setupInterceptors(errorContext);
  29. }, [errorContext]);
  30. return (
  31. <ConnectionProvider>
  32. <RegionProvider>
  33. <NavigationContainer>
  34. <ConnectionBanner />
  35. <Route />
  36. <ErrorModal />
  37. </NavigationContainer>
  38. </RegionProvider>
  39. </ConnectionProvider>
  40. );
  41. };
  42. export default App;