mirror of
https://github.com/clash-verge-rev/clash-verge-rev
synced 2025-05-08 02:55:46 +08:00
39 lines
973 B
TypeScript
39 lines
973 B
TypeScript
import { useRecoilState } from "recoil";
|
|
import { Button, Paper } from "@mui/material";
|
|
import { Virtuoso } from "react-virtuoso";
|
|
import { atomLogData } from "../services/states";
|
|
import BasePage from "../components/base/base-page";
|
|
import LogItem from "../components/log/log-item";
|
|
|
|
const LogPage = () => {
|
|
const [logData, setLogData] = useRecoilState(atomLogData);
|
|
|
|
return (
|
|
<BasePage
|
|
title="Logs"
|
|
contentStyle={{ height: "100%" }}
|
|
header={
|
|
<Button
|
|
size="small"
|
|
sx={{ mt: 1 }}
|
|
variant="contained"
|
|
onClick={() => setLogData([])}
|
|
>
|
|
Clear
|
|
</Button>
|
|
}
|
|
>
|
|
<Paper sx={{ boxShadow: 2, height: "100%" }}>
|
|
<Virtuoso
|
|
initialTopMostItemIndex={999}
|
|
data={logData}
|
|
itemContent={(index, item) => <LogItem value={item} />}
|
|
followOutput={"smooth"}
|
|
/>
|
|
</Paper>
|
|
</BasePage>
|
|
);
|
|
};
|
|
|
|
export default LogPage;
|