App.tsx 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. import 'react-native-gesture-handler';
  2. import 'expo-splash-screen';
  3. import { QueryClientProvider } from '@tanstack/react-query';
  4. import { NavigationContainer } from '@react-navigation/native';
  5. import { queryClient } from 'src/utils/queryClient';
  6. import * as Sentry from '@sentry/react-native';
  7. import Route from './Route';
  8. import { ConnectionProvider } from 'src/contexts/ConnectionContext';
  9. import ConnectionBanner from 'src/components/ConnectionBanner/ConnectionBanner';
  10. import { RegionProvider } from 'src/contexts/RegionContext';
  11. import { ErrorProvider, useError } from 'src/contexts/ErrorContext';
  12. import { useEffect } from 'react';
  13. import { setupInterceptors } from 'src/utils/request';
  14. import { ErrorModal } from 'src/components';
  15. import { NotificationProvider } from 'src/contexts/NotificationContext';
  16. import React from 'react';
  17. const routingInstrumentation = new Sentry.ReactNavigationInstrumentation({
  18. enableTimeToInitialDisplay: true
  19. });
  20. Sentry.init({
  21. dsn: 'https://c9b37005f4be22a17a582603ebc17598@o4507781200543744.ingest.de.sentry.io/4507781253824592',
  22. integrations: [new Sentry.ReactNativeTracing({ routingInstrumentation })],
  23. debug: false,
  24. ignoreErrors: ['Network Error', 'ECONNABORTED', 'timeout of 10000ms exceeded']
  25. });
  26. const App = () => {
  27. return (
  28. <QueryClientProvider client={queryClient}>
  29. <NotificationProvider>
  30. <ErrorProvider>
  31. <InnerApp />
  32. </ErrorProvider>
  33. </NotificationProvider>
  34. </QueryClientProvider>
  35. );
  36. };
  37. const InnerApp = () => {
  38. const errorContext = useError();
  39. const navigation = React.useRef(null);
  40. useEffect(() => {
  41. setupInterceptors(errorContext);
  42. }, [errorContext]);
  43. return (
  44. <ConnectionProvider>
  45. <RegionProvider>
  46. <NavigationContainer
  47. ref={navigation}
  48. onReady={() => {
  49. routingInstrumentation.registerNavigationContainer(navigation);
  50. }}
  51. >
  52. <Route />
  53. <ConnectionBanner />
  54. <ErrorModal />
  55. </NavigationContainer>
  56. </RegionProvider>
  57. </ConnectionProvider>
  58. );
  59. };
  60. export default Sentry.wrap(App);