|
|
|
import { Panel } from '../Panels';
|
|
|
|
import periodicFetch from '../../lib/fetchers/periodicFetch';
|
|
|
|
import SelectedAnvil from './SelectedAnvil';
|
|
|
|
import AnvilList from './AnvilList';
|
|
|
|
|
|
|
|
import sortAnvils from './sortAnvils';
|
|
|
|
|
|
|
|
const Anvils = ({ list }: { list: AnvilList | undefined }): JSX.Element => {
|
|
|
|
const anvils: AnvilListItem[] = [];
|
|
|
|
|
|
|
|
list?.anvils.forEach((anvil: AnvilListItem) => {
|
|
|
|
const { data } = periodicFetch<AnvilStatus>(
|
|
|
|
`${process.env.NEXT_PUBLIC_API_URL}/get_status?anvil_uuid=${anvil.anvil_uuid}`,
|
|
|
|
);
|
|
|
|
anvils.push({
|
|
|
|
...anvil,
|
|
|
|
...data,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
return (
|
|
|
|
<Panel>
|
|
|
|
<SelectedAnvil list={anvils} />
|
|
|
|
<AnvilList list={sortAnvils(anvils)} />
|
|
|
|
</Panel>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Anvils;
|