34 lines
900 B
TypeScript
34 lines
900 B
TypeScript
import { useEffect } from 'react';
|
|
import { atom, useRecoilState } from 'recoil';
|
|
import { ServerStatus, makeEmptyServerStatus } from '../../interfaces/server-status.model';
|
|
import ServerStatusService from '../../services/status-service';
|
|
|
|
export const serverStatusState = atom({
|
|
key: 'serverStatusState',
|
|
default: makeEmptyServerStatus(),
|
|
});
|
|
|
|
export function ServerStatusStore() {
|
|
const [, setServerStatus] = useRecoilState<ServerStatus>(serverStatusState);
|
|
|
|
const updateServerStatus = async () => {
|
|
try {
|
|
const status = await ServerStatusService.getStatus();
|
|
setServerStatus(status);
|
|
return status;
|
|
} catch (error) {
|
|
console.error(`serverStatusState -> getStatus() ERROR: \n${error}`);
|
|
return null;
|
|
}
|
|
};
|
|
|
|
useEffect(() => {
|
|
setInterval(() => {
|
|
updateServerStatus();
|
|
}, 5000);
|
|
updateServerStatus();
|
|
}, []);
|
|
|
|
return null;
|
|
}
|