2019-12-07 13:28:52 +02:00
|
|
|
import React from 'react';
|
2019-12-10 09:47:32 +02:00
|
|
|
import { Redirect, RouteComponentProps } from 'react-router-dom';
|
2017-05-25 22:11:57 +03:00
|
|
|
|
2019-12-07 21:02:00 +02:00
|
|
|
import authFlow from 'app/services/authFlow';
|
2017-05-25 22:11:57 +03:00
|
|
|
|
2019-12-10 09:47:32 +02:00
|
|
|
interface Props {
|
2020-05-24 02:08:24 +03:00
|
|
|
component: React.ComponentType<RouteComponentProps<any>> | React.ComponentType<any>;
|
|
|
|
routerProps: RouteComponentProps;
|
2019-12-10 09:47:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
interface State {
|
2020-05-24 02:08:24 +03:00
|
|
|
access: null | 'rejected' | 'allowed';
|
|
|
|
component: React.ReactElement | null;
|
2019-12-10 09:47:32 +02:00
|
|
|
}
|
2017-06-12 22:10:18 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
export default class AuthFlowRouteContents extends React.Component<Props, State> {
|
|
|
|
state: State = {
|
|
|
|
access: null,
|
|
|
|
component: null,
|
|
|
|
};
|
|
|
|
|
|
|
|
mounted = false;
|
|
|
|
|
|
|
|
shouldComponentUpdate({ routerProps: nextRoute, component: nextComponent }: Props, state: State) {
|
|
|
|
const { component: prevComponent, routerProps: prevRoute } = this.props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
prevRoute.location.pathname !== nextRoute.location.pathname ||
|
|
|
|
prevRoute.location.search !== nextRoute.location.search ||
|
|
|
|
prevComponent !== nextComponent ||
|
|
|
|
this.state.access !== state.access
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
this.mounted = true;
|
|
|
|
this.handleProps(this.props);
|
2017-05-25 22:11:57 +03:00
|
|
|
}
|
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
componentDidUpdate() {
|
|
|
|
this.handleProps(this.props);
|
|
|
|
}
|
2017-05-25 22:11:57 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
componentWillUnmount() {
|
|
|
|
this.mounted = false;
|
2017-05-25 22:11:57 +03:00
|
|
|
}
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
render() {
|
|
|
|
return this.state.component;
|
|
|
|
}
|
2019-12-10 09:47:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
handleProps(props: Props) {
|
|
|
|
const { routerProps } = props;
|
|
|
|
|
|
|
|
authFlow.handleRequest(
|
|
|
|
{
|
|
|
|
path: routerProps.location.pathname,
|
|
|
|
params: routerProps.match.params,
|
|
|
|
query: new URLSearchParams(routerProps.location.search),
|
|
|
|
},
|
|
|
|
this.onRedirect.bind(this),
|
|
|
|
this.onRouteAllowed.bind(this, props),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
onRedirect(path: string) {
|
|
|
|
if (!this.mounted) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.setState({
|
|
|
|
access: 'rejected',
|
|
|
|
component: <Redirect to={path} />,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
onRouteAllowed(props: Props) {
|
|
|
|
if (!this.mounted) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const { component: Component } = props;
|
|
|
|
|
|
|
|
this.setState({
|
|
|
|
access: 'allowed',
|
|
|
|
component: <Component {...props.routerProps} />,
|
|
|
|
});
|
|
|
|
}
|
2017-05-25 22:11:57 +03:00
|
|
|
}
|