feat: enhance log data

This commit is contained in:
GyDi
2022-02-23 02:00:45 +08:00
parent 12ac7bb338
commit dd15455031
6 changed files with 72 additions and 39 deletions

View File

@@ -1,38 +1,12 @@
import dayjs from "dayjs";
import { useEffect, useState } from "react";
import { useRecoilState } from "recoil";
import { Button, Paper } from "@mui/material";
import { Virtuoso } from "react-virtuoso";
import { ApiType } from "../services/types";
import { getInfomation } from "../services/api";
import { atomLogData } from "../services/states";
import BasePage from "../components/base/base-page";
import LogItem from "../components/log/log-item";
let logCache: ApiType.LogItem[] = [];
const LogPage = () => {
const [logData, setLogData] = useState(logCache);
useEffect(() => {
let ws: WebSocket | null = null;
getInfomation().then((result) => {
const { server = "", secret = "" } = result;
ws = new WebSocket(`ws://${server}/logs?token=${secret}`);
ws.addEventListener("message", (event) => {
const data = JSON.parse(event.data) as ApiType.LogItem;
const time = dayjs().format("MM-DD HH:mm:ss");
setLogData((l) => (logCache = [...l, { ...data, time }]));
});
});
return () => ws?.close();
}, []);
const onClear = () => {
setLogData([]);
logCache = [];
};
const [logData, setLogData] = useRecoilState(atomLogData);
return (
<BasePage
@@ -43,7 +17,7 @@ const LogPage = () => {
size="small"
sx={{ mt: 1 }}
variant="contained"
onClick={onClear}
onClick={() => setLogData([])}
>
Clear
</Button>