2022-11-26 01:13:17 +00:00
|
|
|
import { useContext, useMemo } from 'react';
|
|
|
|
|
2023-06-20 00:03:07 +00:00
|
|
|
import API_BASE_URL from '../lib/consts/API_BASE_URL';
|
|
|
|
|
2021-04-28 15:50:42 +00:00
|
|
|
import { AnvilContext } from './AnvilContext';
|
2022-11-26 01:13:17 +00:00
|
|
|
import FlexBox from './FlexBox';
|
|
|
|
import { Panel, PanelHeader } from './Panels';
|
|
|
|
import periodicFetch from '../lib/fetchers/periodicFetch';
|
2021-05-28 00:31:34 +00:00
|
|
|
import Spinner from './Spinner';
|
2022-11-26 01:13:17 +00:00
|
|
|
import { HeaderText, BodyText } from './Text';
|
2021-04-28 15:50:42 +00:00
|
|
|
|
|
|
|
const CPU = (): JSX.Element => {
|
|
|
|
const { uuid } = useContext(AnvilContext);
|
2021-03-17 16:39:00 +00:00
|
|
|
|
2022-11-26 01:13:17 +00:00
|
|
|
const { data: { allocated = 0, cores = 0, threads = 0 } = {}, isLoading } =
|
2023-06-20 00:03:07 +00:00
|
|
|
periodicFetch<AnvilCPU>(`${API_BASE_URL}/anvil/${uuid}/cpu`);
|
2021-03-17 16:39:00 +00:00
|
|
|
|
2022-11-26 01:13:17 +00:00
|
|
|
const contentAreaElement = useMemo(
|
|
|
|
() =>
|
|
|
|
isLoading ? (
|
|
|
|
<Spinner />
|
|
|
|
) : (
|
|
|
|
<FlexBox spacing={0}>
|
|
|
|
<BodyText text={`Total Cores: ${cores}`} />
|
|
|
|
<BodyText text={`Total Threads: ${threads}`} />
|
|
|
|
<BodyText text={`Allocated Cores: ${allocated}`} />
|
|
|
|
</FlexBox>
|
|
|
|
),
|
|
|
|
[allocated, cores, isLoading, threads],
|
|
|
|
);
|
2021-03-09 16:34:44 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<Panel>
|
2022-11-26 01:13:17 +00:00
|
|
|
<PanelHeader>
|
|
|
|
<HeaderText text="CPU" />
|
|
|
|
</PanelHeader>
|
|
|
|
{contentAreaElement}
|
2021-03-09 16:34:44 +00:00
|
|
|
</Panel>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default CPU;
|