|
@@ -1,20 +1,20 @@
|
|
|
import { RootState } from "@/store";
|
|
|
import { getLogListAPI } from "@/store/action/A8log";
|
|
|
-import { Input, DatePicker, Table } from "antd";
|
|
|
-import React, { useEffect, useMemo, useRef, useState } from "react";
|
|
|
+import { Input, DatePicker } from "antd";
|
|
|
+import React, { useCallback, useEffect, useRef, useState } from "react";
|
|
|
import { useDispatch, useSelector } from "react-redux";
|
|
|
|
|
|
import styles from "./index.module.scss";
|
|
|
+import MyTable from "@/components/MyTable";
|
|
|
+import { A8tableC } from "@/utils/tableData";
|
|
|
|
|
|
const { RangePicker } = DatePicker;
|
|
|
|
|
|
function D2Log() {
|
|
|
const dispatch = useDispatch();
|
|
|
|
|
|
- const pageNumRef = useRef(1);
|
|
|
- const pagePageRef = useRef(10);
|
|
|
// 筛选和分页
|
|
|
- const [tableSelect, setTableSelect] = useState({
|
|
|
+ const [fromData, setFromData] = useState({
|
|
|
searchKey: "",
|
|
|
pageSize: 10,
|
|
|
pageNum: 1,
|
|
@@ -24,69 +24,35 @@ function D2Log() {
|
|
|
|
|
|
// 账号的输入
|
|
|
const nameTime = useRef(-1);
|
|
|
- const nameChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
|
- clearTimeout(nameTime.current);
|
|
|
- nameTime.current = window.setTimeout(() => {
|
|
|
- setTableSelect({ ...tableSelect, searchKey: e.target.value, pageNum: 1 });
|
|
|
- }, 500);
|
|
|
- };
|
|
|
+ const nameChange = useCallback(
|
|
|
+ (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
|
+ clearTimeout(nameTime.current);
|
|
|
+ nameTime.current = window.setTimeout(() => {
|
|
|
+ setFromData({ ...fromData, searchKey: e.target.value, pageNum: 1 });
|
|
|
+ }, 500);
|
|
|
+ },
|
|
|
+ [fromData]
|
|
|
+ );
|
|
|
// 时间选择器改变
|
|
|
- const timeChange = (date: any, dateString: any) => {
|
|
|
- let startTime = "";
|
|
|
- let endTime = "";
|
|
|
- if (dateString[0] && dateString[1]) {
|
|
|
- startTime = dateString[0] + " 00:00:00";
|
|
|
- endTime = dateString[1] + " 23:59:59";
|
|
|
- }
|
|
|
- setTableSelect({ ...tableSelect, startTime, endTime, pageNum: 1 });
|
|
|
- };
|
|
|
+ const timeChange = useCallback(
|
|
|
+ (date: any, dateString: any) => {
|
|
|
+ let startTime = "";
|
|
|
+ let endTime = "";
|
|
|
+ if (dateString[0] && dateString[1]) {
|
|
|
+ startTime = dateString[0] + " 00:00:00";
|
|
|
+ endTime = dateString[1] + " 23:59:59";
|
|
|
+ }
|
|
|
+ setFromData({ ...fromData, startTime, endTime, pageNum: 1 });
|
|
|
+ },
|
|
|
+ [fromData]
|
|
|
+ );
|
|
|
|
|
|
useEffect(() => {
|
|
|
- pageNumRef.current = tableSelect.pageNum;
|
|
|
- pagePageRef.current = tableSelect.pageSize;
|
|
|
- dispatch(getLogListAPI(tableSelect));
|
|
|
- }, [dispatch, tableSelect]);
|
|
|
+ dispatch(getLogListAPI(fromData));
|
|
|
+ }, [dispatch, fromData]);
|
|
|
|
|
|
// ---------关于表格
|
|
|
-
|
|
|
- // 页码变化
|
|
|
- const paginationChange = (pageNum: number, pageSize: number) => {
|
|
|
- pageNumRef.current = pageNum;
|
|
|
- pagePageRef.current = pageSize;
|
|
|
- setTableSelect({ ...tableSelect, pageNum, pageSize });
|
|
|
- };
|
|
|
-
|
|
|
- const results = useSelector((state: RootState) => state.A8log.tableInfo);
|
|
|
-
|
|
|
- const columns = useMemo(() => {
|
|
|
- return [
|
|
|
- {
|
|
|
- title: "序号",
|
|
|
- render: (text: any, record: any, index: any) =>
|
|
|
- index + 1 + (pageNumRef.current - 1) * pagePageRef.current,
|
|
|
- },
|
|
|
- {
|
|
|
- title: "操作者",
|
|
|
- dataIndex: "userName",
|
|
|
- },
|
|
|
- {
|
|
|
- title: "操作日期",
|
|
|
- dataIndex: "createTime",
|
|
|
- },
|
|
|
- {
|
|
|
- title: "IP记录",
|
|
|
- dataIndex: "ip",
|
|
|
- },
|
|
|
- {
|
|
|
- title: "操作模块",
|
|
|
- dataIndex: "type",
|
|
|
- },
|
|
|
- {
|
|
|
- title: "操作事件",
|
|
|
- dataIndex: "description",
|
|
|
- },
|
|
|
- ];
|
|
|
- }, []);
|
|
|
+ const tableInfo = useSelector((state: RootState) => state.A8log.tableInfo);
|
|
|
|
|
|
return (
|
|
|
<div className={styles.D2Log}>
|
|
@@ -112,20 +78,16 @@ function D2Log() {
|
|
|
|
|
|
{/* 表格主体 */}
|
|
|
<div className="tableMain">
|
|
|
- <Table
|
|
|
- scroll={{ y: 630 }}
|
|
|
- dataSource={results.list}
|
|
|
- columns={columns}
|
|
|
- rowKey="id"
|
|
|
- pagination={{
|
|
|
- showQuickJumper: true,
|
|
|
- position: ["bottomCenter"],
|
|
|
- showSizeChanger: true,
|
|
|
- current: tableSelect.pageNum,
|
|
|
- pageSize: tableSelect.pageSize,
|
|
|
- total: results.total,
|
|
|
- onChange: paginationChange,
|
|
|
- }}
|
|
|
+ <MyTable
|
|
|
+ yHeight={630}
|
|
|
+ list={tableInfo.list}
|
|
|
+ columnsTemp={A8tableC}
|
|
|
+ pageNum={fromData.pageNum}
|
|
|
+ pageSize={fromData.pageSize}
|
|
|
+ total={tableInfo.total}
|
|
|
+ onChange={(pageNum, pageSize) =>
|
|
|
+ setFromData({ ...fromData, pageNum, pageSize })
|
|
|
+ }
|
|
|
/>
|
|
|
</div>
|
|
|
</div>
|