App.tsx 2.0 KB

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