-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathApp.js
More file actions
79 lines (68 loc) · 1.95 KB
/
App.js
File metadata and controls
79 lines (68 loc) · 1.95 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
import React, { Component } from 'react';
import { BrowserRouter as Router, Route, Redirect } from "react-router-dom";
// Component imports
import NavBar from './components/NavBar'
import Footer from './components/Footer'
// Page imports
import Home from './Pages/Home'
import Accounts from './Pages/Accounts'
import Account from './Pages/Account'
import Login from './Pages/Login'
// User Context
import { UserContext } from './UserContext'
class App extends Component {
state = {
userData: {
isLoggedIn: false,
userId: null,
token: null,
},
}
// Method to login user and update state with details
logInUser = (email, password) => {
console.log("LOGGING IN USER")
fetch('/api/signin', {
method: 'POST',
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
},
body: JSON.stringify({ email, password})
})
.then((response) => response.json())
.then((payload) => {
this.setState({
userData: {
isLoggedIn: true,
...payload
}
});
})
.catch((error) => console.error(error))
}
render() {
return (
// Pass down user context
<UserContext.Provider value={{
userData: this.state.userData,
logInUser: this.logInUser,
}}>
{/* If logged in, render main routes else render login page */}
<Router >
<NavBar isUserLoggedIn={this.state.userData.isLoggedIn} />
<main>
{this.state.userData.isLoggedIn ?
<>
<Route path="/" component={Home} exact />
<Route path="/accounts" component={Accounts} exact />
<Route path="/accounts/:name" component={Account} />
</>
: <Login /> }
</main>
<Footer />
</Router>
</UserContext.Provider>
)
}
}
export default App;