Menu.jsx 837 B

12345678910111213141516171819202122232425262728293031323334
  1. import React, { Component } from "react";
  2. import PropTypes from "prop-types";
  3. import { connect } from "react-redux";
  4. import { NavLink } from "react-router-dom";
  5. @connect(state => ({
  6. loggedIn: state.user.get("loggedIn"),
  7. }))
  8. export default class Menu extends Component {
  9. static propTypes = {
  10. loggedIn: PropTypes.bool,
  11. };
  12. static defaultProps = {
  13. loggedIn: false,
  14. };
  15. getLink(to, text, canShow = true) {
  16. return (canShow) ? <NavLink to={ to } >{ text }</NavLink> : "";
  17. }
  18. render() {
  19. return (
  20. <div className="Menu">
  21. {this.getLink("/", "Home")}
  22. {this.getLink("/login", "Login", !this.props.loggedIn)}
  23. {this.getLink("/register", "Register", !this.props.loggedIn)}
  24. {this.getLink("/settings", "Settings", this.props.loggedIn)}
  25. {this.getLink("/logout", "Logout", this.props.loggedIn)}
  26. </div>
  27. );
  28. }
  29. }