import { StatusBar } from 'expo-status-bar'; import React, { useState, useRef, useEffect } from 'react'; import { NavigationContainer } from '@react-navigation/native'; import { createNativeStackNavigator } from '@react-navigation/native-stack'; import { createBottomTabNavigator } from '@react-navigation/bottom-tabs'; import { Provider as PaperProvider, DefaultTheme, Appbar, Button } from 'react-native-paper'; import MaterialIcons from 'react-native-vector-icons/MaterialIcons'; import Login from "./Views/Login.js" import Feed from "./Views/Feed.js" import Profile from "./Views/Profile.js" import Search from './Views/Search.js'; import Groups from './Views/Groups.js'; import Courses from './Views/Courses.js'; import NotificationsView from './Views/NotificationsView.js'; import SinglePost from './Views/SinglePost.js' import * as Device from 'expo-device'; import * as Notifications from 'expo-notifications'; import API from './API.js'; import i18n from "./i18nMessages.js"; import NewPostView from './Views/NewPost.js'; import { TouchableOpacity, View, Image } from 'react-native'; import MenuView from './Views/Menu.js'; import ProfileSettings from './Views/ProfileSettings.js'; import InviteView from './Views/Invite.js'; const Tab = createBottomTabNavigator(); const Stack = createNativeStackNavigator(); const theme = { ...DefaultTheme, roundness: 2, colors: { ...DefaultTheme.colors, primary: '#000000', accent: '#0d6efd', background: "#edf2f7", }, }; Notifications.setNotificationHandler({ handleNotification: async () => { //console.log("notif background"); return { shouldShowAlert: true, shouldPlaySound: true, shouldSetBadge: true, }; }, }); async function registerForPushNotificationsAsync() { if (Platform.OS === 'android') { Notifications.setNotificationChannelAsync('default', { name: 'default', importance: Notifications.AndroidImportance.MAX, vibrationPattern: [0, 250, 250, 250], lightColor: '#FF231F7C', }); } let token; if (Device.isDevice) { const { status: existingStatus } = await Notifications.getPermissionsAsync(); let finalStatus = existingStatus; if (existingStatus !== 'granted') { const { status } = await Notifications.requestPermissionsAsync(); finalStatus = status; } if (finalStatus !== 'granted') { alert('Failed to get push token for push notification!'); return; } token = (await Notifications.getExpoPushTokenAsync({ projectId: "c2bb4d4e-4d4d-4f34-a873-7cad78c6023c", })).data; } else { //alert('Must use physical device for Push Notifications'); } return token; } const MainNavigation = () => { const [expoPushToken, setExpoPushToken] = useState(''); const [notification, setNotification] = useState(false); const notificationListener = useRef(); const responseListener = useRef(); useEffect(() => { registerForPushNotificationsAsync().then(async (token) => { let isLoggedIn = await API.isLoggedIn(); if (!isLoggedIn) return false; API.registerToken(token); return setExpoPushToken(token); }); // This listener is fired whenever a notification is received while the app is foregrounded notificationListener.current = Notifications.addNotificationReceivedListener(notification => { //console.log("got notif", notification) setNotification(notification); }); // This listener is fired whenever a user taps on or interacts with a notification (works when app is foregrounded, backgrounded, or killed) responseListener.current = Notifications.addNotificationResponseReceivedListener(response => { //console.log("got notif click", notification) console.log(response); }); return () => { Notifications.removeNotificationSubscription(notificationListener.current); Notifications.removeNotificationSubscription(responseListener.current); }; }, []); return ( ( ), header: () => { <> }, }} listeners={({ navigation, route }) => ({ tabPress: e => { navigation.navigate('Feed') }, })} /> ( ), header: () => { <> }, }} /> ( ), tabBarButton: (props) => ( {props.children} ), header: () => { <> }, }} /> ( ), header: () => { <> }, }} /> ( ), header: () => { <> }, }} /> {/* ( ), header: () => { <> }, }} />*/} ) } export default function App() { return ( , }} theme={theme}> { return ( {props.navigation.canGoBack() ? { props.navigation.goBack(); }} /> : <>} ( )} mode="text" >EMI Fellowship } titleStyle={{}}/> {alert("Chats are comming soon.")}} /> {props.navigation.navigate("Search")}} /> {props.navigation.navigate("Notifications")}} /> ) }, }}> ); }