-
Notifications
You must be signed in to change notification settings - Fork 0
/
App.tsx
executable file
·104 lines (94 loc) · 2.35 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
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import React from 'react';
import * as Font from 'expo-font';
import { setCustomText } from 'react-native-global-props';
import { Fonts } from './assets/fonts/Fonts';
import { AppContainer } from './components/Navbar';
import { UserRecord } from './utils/airtable/interface';
import { Contact } from './screens/Messages/data';
import ContextProvider from './components/ContextProvider';
import { storeUser } from '@utils/airtable/requests';
import { UserMock } from '@utils/airtable/mocks';
interface GlobalProps {
loggedIn: boolean;
user: UserRecord;
pocs: { [rid: string]: Contact };
setUser: Function;
setPocs: Function;
setNavigation: Function;
}
interface AppState {
isLoaded: boolean;
globalProps: GlobalProps;
}
export default class App extends React.Component<{}, AppState> {
constructor(props) {
super(props);
this.state = {
isLoaded: false,
globalProps: {
loggedIn: false,
user: UserMock,
pocs: null,
setUser: this.setUser,
setPocs: this.setPocs,
setNavigation: this.setNavigation,
},
};
this.setUser = this.setUser.bind(this);
this.setPocs = this.setPocs.bind(this);
this.setNavigation = this.setNavigation.bind(this);
}
async componentDidMount() {
await this.setDefaultFont();
this.setState({
isLoaded: true,
});
}
setUser = async (user: UserRecord) => {
await storeUser(user);
const { globalProps } = this.state;
this.setState({
globalProps: {
...globalProps,
loggedIn: true,
user,
},
});
};
setPocs = (pocs): void => {
const { globalProps } = this.state;
this.setState({
globalProps: {
...globalProps,
pocs,
},
});
};
setNavigation = (navigation): void => {
const { globalProps } = this.state;
this.setState({
globalProps: {
...globalProps,
navigation,
},
});
};
setDefaultFont = async () => {
await Font.loadAsync(Fonts);
const customTextProps = {
style: { fontFamily: 'source-sans-pro-regular' },
};
setCustomText(customTextProps);
};
render(): JSX.Element {
const { isLoaded, globalProps } = this.state;
if (!isLoaded) {
return null;
}
return (
<ContextProvider state={globalProps}>
<AppContainer />
</ContextProvider>
);
}
}