40 lines
1.5 KiB
JavaScript
40 lines
1.5 KiB
JavaScript
// debug
|
|
import "./warnFilter";
|
|
|
|
import "expo-splash-screen";
|
|
|
|
import BackgroundGeolocation from "react-native-background-geolocation";
|
|
|
|
import notifee from "@notifee/react-native";
|
|
import messaging from "@react-native-firebase/messaging";
|
|
|
|
import "~/sentry";
|
|
|
|
import { registerRootComponent } from "expo";
|
|
|
|
import App from "~/app";
|
|
|
|
import { onBackgroundEvent as notificationBackgroundEvent } from "~/notifications/onEvent";
|
|
import onMessageReceived from "~/notifications/onMessageReceived";
|
|
|
|
// setup notification, this have to stay in index.js
|
|
notifee.onBackgroundEvent(notificationBackgroundEvent);
|
|
messaging().setBackgroundMessageHandler(onMessageReceived);
|
|
|
|
// Android Headless Mode for react-native-background-geolocation.
|
|
//
|
|
// We currently run with `enableHeadless: false` (see
|
|
// [`BASE_GEOLOCATION_CONFIG.enableHeadless`](src/location/backgroundGeolocationConfig.js:16)),
|
|
// meaning we do not rely on JS callbacks while the app is terminated.
|
|
//
|
|
// This registration is kept only as a safety-net: if `enableHeadless` is ever turned on again,
|
|
// we'll at least have a minimal handler.
|
|
BackgroundGeolocation.registerHeadlessTask(async (event) => {
|
|
// eslint-disable-next-line no-console
|
|
console.log("[BGGeo HeadlessTask]", event?.name, event?.params);
|
|
});
|
|
|
|
// registerRootComponent calls AppRegistry.registerComponent('main', () => App);
|
|
// It also ensures that whether you load the app in Expo Go or in a native build,
|
|
// the environment is set up appropriately
|
|
registerRootComponent(App);
|