This repository was archived by the owner on Aug 20, 2024. It is now read-only.
forked from gothinkster/react-redux-realworld-example-app
-
Notifications
You must be signed in to change notification settings - Fork 54
Expand file tree
/
Copy pathHeader.js
More file actions
91 lines (74 loc) · 2.03 KB
/
Header.js
File metadata and controls
91 lines (74 loc) · 2.03 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
84
85
86
87
88
89
90
91
import React from 'react';
import { Link } from 'react-router-dom';
const LoggedOutView = props => {
if (!props.currentUser) {
return (
<ul className="nav navbar-nav pull-xs-right">
<li className="nav-item">
<Link to="/" className="nav-link">
Music
</Link>
</li>
<li className="nav-item">
<Link to="/login" className="nav-link">
Videos
</Link>
</li>
<li className="nav-item">
<Link to="/register" className="nav-link">
Start Free Trial
</Link>
</li>
</ul>
);
}
return null;
};
const LoggedInView = props => {
if (props.currentUser) {
return (
<ul className="nav navbar-nav pull-xs-right">
<li className="nav-item">
<Link to="/" className="nav-link">
ART PLATFORM
</Link>
</li>
<li className="nav-item">
<Link to="/editor" className="nav-link">
<i className="ion-compose"></i> New Post
</Link>
</li>
<li className="nav-item">
<Link to="/settings" className="nav-link">
<i className="ion-gear-a"></i> Settings
</Link>
</li>
<li className="nav-item">
<Link
to={`/@${props.currentUser.username}`}
className="nav-link">
<img src={props.currentUser.image} className="user-pic" alt={props.currentUser.username} />
{props.currentUser.username}
</Link>
</li>
</ul>
);
}
return null;
};
class Header extends React.Component {
render() {
return (
<nav className="navbar navbar-light">
<div className="container">
<Link to="/" className="navbar-brand">
{this.props.appName.toLowerCase()}
</Link>
<LoggedOutView currentUser={this.props.currentUser} />
<LoggedInView currentUser={this.props.currentUser} />
</div>
</nav>
);
}
}
export default Header;