forked from codinger41/pengscores
-
Notifications
You must be signed in to change notification settings - Fork 0
/
App.tsx
37 lines (34 loc) · 1.29 KB
/
App.tsx
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
import React, { useState, useEffect, useReducer } from 'react'
import { View } from 'react-native'
import * as Font from 'expo-font'
import Navigation from './app/navigator'
import MatchesContext from './app/contexts/matches'
import combined from './app/reducers'
import { getLiveMatches, getSingleMatch, getSingleMatchStats, getSingleMatchEvents, changeLeague, getUpcomingMatches } from './app/actions/matches'
import { initialState } from './app/utils/constants'
export default function App() {
const [fontLoaded, setFontLoaded] = useState(false)
const [state, dispatch] = useReducer(combined, initialState);
useEffect(() => {
Font.loadAsync({
'ubuntu': require('./assets/Ubuntu-Regular.ttf'),
}).then(() => setFontLoaded(true))
})
if (!fontLoaded) {
return <View />
}
return (
<MatchesContext.Provider
value={{
...state,
getLiveMatches: getLiveMatches.bind(null, dispatch),
getMatchDetails: getSingleMatch.bind(null, dispatch),
getMatchStat: getSingleMatchStats.bind(null, dispatch),
getMatchEvents: getSingleMatchEvents.bind(null, dispatch),
getUpcomingMatches: getUpcomingMatches.bind(null, dispatch),
changeLeague: changeLeague.bind(null, dispatch)
}}>
<Navigation />
</MatchesContext.Provider>
);
}