anvil/striker-ui/components/Hosts/index.tsx
Tsu-ba-me 7d4e791565 fix(striker-ui): remove undefined hosts after host sanitize
The back-end is currently ignoring requests for status on the DR
host(s) because we don't need to show DR status in the UI (for now).
The front-end gets undefined when trying to match a DR host array index
to the AnvilStatusHost[].

This change filters out the undefined item(s) to prevent crashing.
2022-02-23 23:35:41 -05:00

48 lines
1.3 KiB
TypeScript

import { useContext } from 'react';
import { Panel } from '../Panels';
import { HeaderText } from '../Text';
import AnvilHost from './AnvilHost';
import PeriodicFetch from '../../lib/fetchers/periodicFetch';
import { AnvilContext } from '../AnvilContext';
import Spinner from '../Spinner';
import hostsSanitizer from '../../lib/sanitizers/hostsSanitizer';
const Hosts = ({ anvil }: { anvil: AnvilListItem[] }): JSX.Element => {
const { uuid } = useContext(AnvilContext);
const { data, isLoading } = PeriodicFetch<AnvilStatus>(
`${process.env.NEXT_PUBLIC_API_URL}/get_status?anvil_uuid=${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;