2019-12-07 13:28:52 +02:00
|
|
|
import React, { ComponentType } from 'react';
|
|
|
|
import { Route, Redirect, RouteProps } from 'react-router-dom';
|
|
|
|
import { Location } from 'history';
|
2020-07-22 13:01:12 +03:00
|
|
|
|
|
|
|
import { connect } from 'app/functions';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { getActiveAccount } from 'app/components/accounts/reducer';
|
|
|
|
import { Account } from 'app/components/accounts';
|
2019-12-07 13:28:52 +02:00
|
|
|
|
|
|
|
interface Props extends RouteProps {
|
2020-05-24 02:08:24 +03:00
|
|
|
component: ComponentType<any>;
|
|
|
|
account: Account | null;
|
2019-12-07 13:28:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const PrivateRoute = ({ account, component: Component, ...rest }: Props) => (
|
2020-05-24 02:08:24 +03:00
|
|
|
<Route
|
|
|
|
{...rest}
|
|
|
|
render={(props: { location: Location }) =>
|
|
|
|
!account || !account.token ? <Redirect to="/login" /> : <Component {...props} />
|
|
|
|
}
|
|
|
|
/>
|
2019-12-07 13:28:52 +02:00
|
|
|
);
|
|
|
|
|
2020-07-22 13:01:12 +03:00
|
|
|
export default connect((state) => ({
|
2020-05-24 02:08:24 +03:00
|
|
|
account: getActiveAccount(state),
|
2019-12-07 13:28:52 +02:00
|
|
|
}))(PrivateRoute);
|