anvil/striker-ui/pages/index.tsx

70 lines
1.8 KiB
TypeScript

import { Grid } from '@material-ui/core';
import { makeStyles } from '@material-ui/core/styles';
import Anvils from '../components/Anvils';
import Nodes from '../components/Nodes';
import CPU from '../components/CPU';
import SharedStorage from '../components/SharedStorage';
import ReplicatedStorage from '../components/ReplicatedStorage';
import Memory from '../components/Memory';
import PeriodicFetch from '../lib/fetchers/periodicFetch';
const useStyles = makeStyles(() => ({
grid: {
height: '100vh',
},
}));
const Home = (): JSX.Element => {
const classes = useStyles();
const { data } = PeriodicFetch<AnvilList>(
process.env.NEXT_PUBLIC_API_URL || 'http://localhost:8080',
'/anvils/get_anvils',
);
return (
<Grid container alignItems="center" justify="space-around">
<Grid item xs={3}>
<Grid
container
justify="flex-start"
direction="column"
className={classes.grid}
>
<Anvils list={data} />
<Nodes anvil={data?.anvils[0]} />
</Grid>
</Grid>
<Grid item xs={5}>
<Grid
container
justify="flex-start"
direction="column"
className={classes.grid}
>
<ReplicatedStorage />
</Grid>
</Grid>
<Grid item xs={3}>
<Grid
container
justify="flex-start"
direction="column"
className={classes.grid}
>
{data?.anvils?.length ? (
<>
<SharedStorage anvil={data.anvils[0]} />
<CPU uuid={data.anvils[0].anvil_uuid} />
<Memory uuid={data.anvils[0].anvil_uuid} />
</>
) : null}
</Grid>
</Grid>
</Grid>
);
};
export default Home;