anvil/striker-ui/components/Hosts/index.tsx
2023-07-03 04:46:06 -04:00

50 lines
1.3 KiB
TypeScript

import { useContext } from 'react';
import API_BASE_URL from '../../lib/consts/API_BASE_URL';
import { AnvilContext } from '../AnvilContext';
import AnvilHost from './AnvilHost';
import hostsSanitizer from '../../lib/sanitizers/hostsSanitizer';
import { Panel } from '../Panels';
import periodicFetch from '../../lib/fetchers/periodicFetch';
import { HeaderText } from '../Text';
import Spinner from '../Spinner';
const Hosts = ({ anvil }: { anvil: AnvilListItem[] }): JSX.Element => {
const { uuid } = useContext(AnvilContext);
const { data, isLoading } = periodicFetch<AnvilStatus>(
`${API_BASE_URL}/anvil/${uuid}`,
);
const anvilIndex = anvil.findIndex((a) => a.anvil_uuid === uuid);
return (
<Panel>
<HeaderText text="Nodes" />
{!isLoading ? (
<>
{anvilIndex !== -1 && data && (
<AnvilHost
hosts={hostsSanitizer(anvil[anvilIndex].hosts).reduce<
Array<AnvilStatusHost>
>((reducedHosts, host, index) => {
const hostStatus = data.hosts[index];
if (hostStatus) {
reducedHosts.push(hostStatus);
}
return reducedHosts;
}, [])}
/>
)}
</>
) : (
<Spinner />
)}
</Panel>
);
};
export default Hosts;