import { FC, useEffect } from 'react'; import { RouteComponentProps } from 'react-router'; import Message from '../../utils/Message'; import { isNotFoundServer, SelectedServer } from '../data'; import { NoMenuLayout } from '../../common/NoMenuLayout'; interface WithSelectedServerProps extends RouteComponentProps<{ serverId: string }> { selectServer: (serverId: string) => void; selectedServer: SelectedServer; } export function withSelectedServer(WrappedComponent: FC, ServerError: FC) { return (props: WithSelectedServerProps & T) => { const { selectServer, selectedServer, match } = props; useEffect(() => { selectServer(match.params.serverId); }, [ match.params.serverId ]); if (!selectedServer) { return ( ); } if (isNotFoundServer(selectedServer)) { return ; } return ; }; }