import React, { useState } from "react"; import { NavigationContainer } from "@react-navigation/native"; import navigationTheme from "./app/navigation/navigationTheme"; import "./app/config/globals.js"; import openDatabase from "./app/database/database-connection"; import { AppLoading } from "expo"; import initDatabase from "./app/database/database-init"; import FlashMessage from "react-native-flash-message"; import AppNavigator from "./app/navigation/AppNavigator"; import EventLocationProvider from "./app/context/EventLocationContext"; import CurrentLocationProvider from "./app/context/CurrentLocationContext"; import AuthNavigator from "./app/navigation/AuthNavigator"; import { AuthContext } from "./app/auth/context"; import authStorage from "./app/auth/storage"; import MapDataProvider from "./app/context/MapDataContext"; import { getLocation } from "./app/hooks/useLocation"; import { useFiltering } from "./app/hooks/useFiltering"; import NoInternetConnectionScreen from "./app/screens/NoInternetConnectionScreen"; import NetInfo, { useNetInfo } from "@react-native-community/netinfo"; export default function App() { const [user, setUser] = useState(); const [isReady, setIsReady] = useState(); const netInfo = useNetInfo(); const restoreUser = async () => { const user = await authStorage.getUser(); global.location = { lat: -23.623, long: -46.5637 }; // await getLocation(); if (user) setUser(user); }; if (!isReady && netInfo.isInternetReachable) { return ( setIsReady(true)} /> ); } else if (netInfo.isInternetReachable) { global.userDataBase = openDatabase(); initDatabase(global.userDataBase); global.formsSockets = useFiltering(global.location); return ( {user ? : } ); } else return ; }