PrivateRoute.jsx 1.2KB

12345678910111213141516171819202122232425262728
  1. import React from 'react'
  2. import PropTypes from 'prop-types'
  3. import { connect } from 'react-redux'
  4. import { Route, Redirect, withRouter } from 'react-router-dom'
  5. // component inspired from https://reacttraining.com/react-router/web/example/auth-workflow
  6. // /!\ you shall destruct props.component otherwise you get a warning:
  7. // "You should not use <Route component> and <Route render> in the same route; <Route render> will be ignored
  8. const PrivateRoute = ({ component: Component, ...rest }) => (
  9. <Route {...rest} render={props => rest.user.logged
  10. ? <Component {...props} /> // user logged, return component
  11. : rest.user.logged === null
  12. ? <div /> // dont know if user logged yet (waiting for api to respond), do nothing @TODO display loader
  13. : <Redirect to={{pathname: '/login', state: {from: props.location}}} /> // // user not logged, redirect to login page
  14. } />
  15. )
  16. const mapStateToProps = ({ user }) => ({ user })
  17. export default withRouter(connect(mapStateToProps)(PrivateRoute))
  18. PrivateRoute.propTypes = {
  19. component: PropTypes.func.isRequired,
  20. user: PropTypes.shape({ // user is get with redux connect
  21. logged: PropTypes.any // can be true, false or null
  22. })
  23. }