2020-08-29 14:51:53 +03:00
|
|
|
import React, { FC, useEffect } from 'react';
|
2020-09-04 20:05:41 +03:00
|
|
|
import { RouteComponentProps } from 'react-router';
|
2020-08-29 14:51:53 +03:00
|
|
|
import Message from '../../utils/Message';
|
2020-08-29 19:51:03 +03:00
|
|
|
import { isNotFoundServer, SelectedServer } from '../data';
|
2020-08-29 14:51:53 +03:00
|
|
|
|
2020-09-04 20:05:41 +03:00
|
|
|
interface WithSelectedServerProps extends RouteComponentProps<{ serverId: string }> {
|
2020-08-29 14:51:53 +03:00
|
|
|
selectServer: (serverId: string) => void;
|
|
|
|
selectedServer: SelectedServer;
|
|
|
|
}
|
|
|
|
|
2020-08-29 21:20:45 +03:00
|
|
|
export function withSelectedServer<T = {}>(WrappedComponent: FC<WithSelectedServerProps & T>, ServerError: FC) {
|
|
|
|
return (props: WithSelectedServerProps & T) => {
|
|
|
|
const { selectServer, selectedServer, match } = props;
|
2020-08-29 14:51:53 +03:00
|
|
|
|
2020-08-29 21:20:45 +03:00
|
|
|
useEffect(() => {
|
2020-09-04 20:05:41 +03:00
|
|
|
selectServer(match.params.serverId);
|
|
|
|
}, [ match.params.serverId ]);
|
2020-08-29 14:51:53 +03:00
|
|
|
|
2020-08-29 21:20:45 +03:00
|
|
|
if (!selectedServer) {
|
2020-09-06 13:47:14 +03:00
|
|
|
return (
|
|
|
|
<div className="row">
|
|
|
|
<Message loading />
|
|
|
|
</div>
|
|
|
|
);
|
2020-08-29 21:20:45 +03:00
|
|
|
}
|
2020-08-29 14:51:53 +03:00
|
|
|
|
2020-08-29 21:20:45 +03:00
|
|
|
if (isNotFoundServer(selectedServer)) {
|
|
|
|
return <ServerError />;
|
|
|
|
}
|
2020-08-29 14:51:53 +03:00
|
|
|
|
2020-08-29 21:20:45 +03:00
|
|
|
return <WrappedComponent {...props} />;
|
|
|
|
};
|
|
|
|
}
|