-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathApp.tsx
More file actions
83 lines (77 loc) · 3.53 KB
/
App.tsx
File metadata and controls
83 lines (77 loc) · 3.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import React from 'react';
import { NavigationContainer } from '@react-navigation/native';
import { Provider as AuthProvider } from './src/contexts/AuthContext';
import { Provider as MeetingProvider } from './src/contexts/MeetingContext';
import { Provider as MinistryMeetingProvider } from './src/contexts/MinistryMeetingContext';
import { Provider as CartsScheduleProvider } from './src/contexts/CartsScheduleContext';
import { Provider as AudioVideoProvider } from './src/contexts/AudioVideoContext';
import { Provider as OrdinalsProvider } from './src/contexts/AttendantsContext';
import { Provider as PreachersProvider } from './src/contexts/PreachersContext';
import { Provider as MinistryGroupProvider } from './src/contexts/MinistryGroupContext';
import { Provider as SettingsProvider } from './src/contexts/SettingsContext';
import { Provider as TerritoriesProvider } from './src/contexts/TerritoriesContext';
import { Alert, StatusBar } from 'react-native';
import { useFonts } from 'expo-font';
import { navigationRef } from './src/RootNavigation';
import SwitchNavigator from './src/navigators/Switch';
import FlashMessage from 'react-native-flash-message';
import * as Calendar from 'expo-calendar';
import { useContext, useEffect, useState } from 'react';
import { SafeAreaProvider } from 'react-native-safe-area-context';
import { AppContent } from './AppContent';
StatusBar.setBarStyle('light-content')
function App() {
const [fontsLoaded] = useFonts({
'FontAwesome': require('./assets/fonts/FontAwesome.ttf'),
'InterThin': require('./assets/fonts/inter/Inter-Thin.ttf'),
'InterRegular': require('./assets/fonts/inter/Inter-Regular.ttf'),
'InterSemiBold': require('./assets/fonts/inter/Inter-SemiBold.ttf'),
'MontserratRegular': require('./assets/fonts/montserrat/Montserrat-Regular.ttf'),
'MontserratSemiBold': require('./assets/fonts/montserrat/Montserrat-SemiBold.ttf'),
'PoppinsThin': require('./assets/fonts/Poppins/Poppins-Thin.ttf'),
'PoppinsSemiBold': require('./assets/fonts/Poppins/Poppins-SemiBold.ttf'),
'PoppinsRegular': require('./assets/fonts/Poppins/Poppins-Regular.ttf'),
'SatisfyRegular': require('./assets/fonts/Satisfy/Satisfy-Regular.ttf')
});
const [permissionStatus, setPermissionStatus] = useState<string>('')
const loadCalendarPermission = async () => {
const {status} = await Calendar.requestCalendarPermissionsAsync();
const { status: remindersStatus } = await Calendar.requestRemindersPermissionsAsync();
if (status === 'granted' && remindersStatus === 'granted') {
setPermissionStatus(status)
}
}
useEffect(() => {
loadCalendarPermission()
}, [])
if(!fontsLoaded && permissionStatus === 'granted') {
return null;
}
return (
<SafeAreaProvider>
<AudioVideoProvider>
<AuthProvider>
<CartsScheduleProvider>
<MeetingProvider>
<MinistryMeetingProvider>
<OrdinalsProvider>
<PreachersProvider>
<MinistryGroupProvider>
<SettingsProvider>
<TerritoriesProvider>
<AppContent />
</TerritoriesProvider>
</SettingsProvider>
</MinistryGroupProvider>
</PreachersProvider>
</OrdinalsProvider>
</MinistryMeetingProvider>
</MeetingProvider>
</CartsScheduleProvider>
</AuthProvider>
<FlashMessage position={'bottom'} />
</AudioVideoProvider>
</SafeAreaProvider>
);
}
export default App;