swimtracker-app/App.js

50 lines
1.3 KiB
JavaScript
Raw Normal View History

2019-09-17 20:24:01 +02:00
import React from 'react';
import { AppLoading } from 'expo';
import { Ionicons } from '@expo/vector-icons';
2020-06-04 18:46:15 +02:00
import * as Font from 'expo-font';
// Redux
import swimtrackerReducer from './state/Reducer';
import { createStore } from 'redux';
import { DeviceReduxCoupling } from './state/DeviceReduxCoupling';
2020-06-04 18:46:15 +02:00
import { Provider } from 'react-redux';
import ThemedStackNavigation from './components/ThemedStackNavigation';
const store = createStore(swimtrackerReducer);
2020-06-28 22:10:54 +02:00
//const deviceReduxCoupling = new DeviceReduxCoupling(store);
2019-09-17 20:24:01 +02:00
export default class App extends React.Component {
constructor(props) {
super(props);
this.state = {
isReady: false,
2020-05-17 15:57:26 +02:00
};
2019-09-17 20:24:01 +02:00
}
async componentDidMount() {
await Font.loadAsync({
Roboto: require('native-base/Fonts/Roboto.ttf'),
Roboto_medium: require('native-base/Fonts/Roboto_medium.ttf'),
...Ionicons.font,
});
this.setState({ isReady: true });
2020-06-28 22:10:54 +02:00
this.device = new DeviceReduxCoupling(store);
2019-09-17 20:24:01 +02:00
}
render() {
if (!this.state.isReady) {
return <AppLoading />;
}
return (
2020-06-04 18:46:15 +02:00
<Provider store={store}>
<ThemedStackNavigation/>
</Provider>
2019-09-17 20:24:01 +02:00
);
}
}