2023-01-16 08:11:44 +01:00
|
|
|
import React, { useState, useEffect, ReactElement } from 'react';
|
2023-01-10 05:57:29 +01:00
|
|
|
import { LogTable } from '../../components/admin/LogTable';
|
2020-10-30 02:01:38 +01:00
|
|
|
|
2022-04-20 04:57:27 +02:00
|
|
|
import { LOGS_ALL, fetchData } from '../../utils/apis';
|
2020-10-30 02:01:38 +01:00
|
|
|
|
2023-01-16 08:11:44 +01:00
|
|
|
import { AdminLayout } from '../../components/layouts/AdminLayout';
|
|
|
|
|
2020-10-30 02:01:38 +01:00
|
|
|
const FETCH_INTERVAL = 5 * 1000; // 5 sec
|
|
|
|
|
|
|
|
export default function Logs() {
|
|
|
|
const [logs, setLogs] = useState([]);
|
|
|
|
|
|
|
|
const getInfo = async () => {
|
|
|
|
try {
|
|
|
|
const result = await fetchData(LOGS_ALL);
|
|
|
|
setLogs(result);
|
|
|
|
} catch (error) {
|
2021-02-07 04:38:58 +01:00
|
|
|
console.log('==== error', error);
|
2020-10-30 02:01:38 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
let getStatusIntervalId = null;
|
|
|
|
|
|
|
|
setInterval(getInfo, FETCH_INTERVAL);
|
|
|
|
getInfo();
|
|
|
|
|
|
|
|
getStatusIntervalId = setInterval(getInfo, FETCH_INTERVAL);
|
|
|
|
// returned function will be called on component unmount
|
|
|
|
return () => {
|
|
|
|
clearInterval(getStatusIntervalId);
|
|
|
|
};
|
|
|
|
}, []);
|
|
|
|
|
2021-02-07 04:38:58 +01:00
|
|
|
return <LogTable logs={logs} pageSize={20} />;
|
2020-10-30 02:01:38 +01:00
|
|
|
}
|
2023-01-16 08:11:44 +01:00
|
|
|
|
|
|
|
Logs.getLayout = function getLayout(page: ReactElement) {
|
|
|
|
return <AdminLayout page={page} />;
|
|
|
|
};
|