App.tsx 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  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. import * as Notifications from 'expo-notifications';
  18. import { Platform } from 'react-native';
  19. const routingInstrumentation = new Sentry.ReactNavigationInstrumentation({
  20. enableTimeToInitialDisplay: true
  21. });
  22. Sentry.init({
  23. dsn: 'https://c9b37005f4be22a17a582603ebc17598@o4507781200543744.ingest.de.sentry.io/4507781253824592',
  24. integrations: [new Sentry.ReactNativeTracing({ routingInstrumentation })],
  25. debug: false,
  26. ignoreErrors: ['Network Error', 'ECONNABORTED', 'timeout of 10000ms exceeded']
  27. });
  28. const App = () => {
  29. async function setupNotificationChannels() {
  30. if (Platform.OS === 'android') {
  31. await Notifications.setNotificationChannelAsync('default', {
  32. name: 'default',
  33. importance: Notifications.AndroidImportance.MAX,
  34. vibrationPattern: [0, 250, 250, 250],
  35. lightColor: '#FF231F7C'
  36. });
  37. }
  38. }
  39. useEffect(() => {
  40. setupNotificationChannels();
  41. }, []);
  42. useEffect(() => {
  43. let notificationListener: any;
  44. let responseListener: any;
  45. const checkLastNotificationResponse = async () => {
  46. const lastNotificationResponse = await Notifications.getLastNotificationResponseAsync();
  47. if (lastNotificationResponse) {
  48. const data = lastNotificationResponse.notification.request.content.data;
  49. console.log('lastNotificationResponse', lastNotificationResponse.notification.request);
  50. console.log('dataLast', data);
  51. }
  52. };
  53. checkLastNotificationResponse();
  54. notificationListener = Notifications.addNotificationReceivedListener((notification) => {
  55. console.log('notification', notification.request);
  56. });
  57. responseListener = Notifications.addNotificationResponseReceivedListener((response) => {
  58. const data = response.notification.request.content.data;
  59. console.log('payload', response.notification.request.trigger?.payload);
  60. console.log('data', data);
  61. });
  62. return () => {
  63. if (notificationListener) notificationListener.remove();
  64. if (responseListener) responseListener.remove();
  65. };
  66. }, []);
  67. return (
  68. <QueryClientProvider client={queryClient}>
  69. <NotificationProvider>
  70. <ErrorProvider>
  71. <InnerApp />
  72. </ErrorProvider>
  73. </NotificationProvider>
  74. </QueryClientProvider>
  75. );
  76. };
  77. const InnerApp = () => {
  78. const errorContext = useError();
  79. const navigation = React.useRef(null);
  80. useEffect(() => {
  81. setupInterceptors(errorContext);
  82. }, [errorContext]);
  83. return (
  84. <ConnectionProvider>
  85. <RegionProvider>
  86. <NavigationContainer
  87. ref={navigation}
  88. onReady={() => {
  89. routingInstrumentation.registerNavigationContainer(navigation);
  90. }}
  91. >
  92. <Route />
  93. <ConnectionBanner />
  94. <ErrorModal />
  95. </NavigationContainer>
  96. </RegionProvider>
  97. </ConnectionProvider>
  98. );
  99. };
  100. export default Sentry.wrap(App);