|
@@ -1,9 +1,147 @@
|
|
|
-import React from "react";
|
|
|
+import React, { useCallback, useEffect, useMemo, useState } from "react";
|
|
|
import styles from "./index.module.scss";
|
|
|
+import { Button, DatePicker, Popconfirm, Table } from "antd";
|
|
|
+import { useDispatch, useSelector } from "react-redux";
|
|
|
+import { RootState } from "@/store";
|
|
|
+import { C1_APIdel, C1_APIgetList } from "@/store/action/C1Message";
|
|
|
+import { C1TableType } from "@/types/api/C1Message";
|
|
|
+import { MessageFu } from "@/utils/message";
|
|
|
+
|
|
|
+const { RangePicker } = DatePicker;
|
|
|
+
|
|
|
function C1Message() {
|
|
|
+ const dispatch = useDispatch();
|
|
|
+
|
|
|
+ const [fromData, setFromData] = useState({
|
|
|
+ pageNum: 1,
|
|
|
+ pageSize: 10,
|
|
|
+ startTime: "",
|
|
|
+ endTime: "",
|
|
|
+ });
|
|
|
+
|
|
|
+ useEffect(() => {
|
|
|
+ dispatch(C1_APIgetList(fromData));
|
|
|
+ }, [dispatch, fromData]);
|
|
|
+
|
|
|
+ // 时间选择器改变
|
|
|
+ const timeChange = (_: 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 });
|
|
|
+ };
|
|
|
+
|
|
|
+ // 点击重置
|
|
|
+ const [inputKey, setInputKey] = useState(1);
|
|
|
+ const resetSelectFu = useCallback(() => {
|
|
|
+ // 把2个输入框和时间选择器清空
|
|
|
+ setInputKey(Date.now());
|
|
|
+ setFromData({
|
|
|
+ pageNum: 1,
|
|
|
+ pageSize: 10,
|
|
|
+ startTime: "",
|
|
|
+ endTime: "",
|
|
|
+ });
|
|
|
+ }, []);
|
|
|
+
|
|
|
+ // 点击删除
|
|
|
+ const delTableFu = useCallback(
|
|
|
+ async (id: number) => {
|
|
|
+ const res = await C1_APIdel(id);
|
|
|
+ if (res.code === 0) {
|
|
|
+ MessageFu.success("删除成功!");
|
|
|
+ dispatch(C1_APIgetList(fromData));
|
|
|
+ }
|
|
|
+ },
|
|
|
+ [dispatch, fromData]
|
|
|
+ );
|
|
|
+
|
|
|
+ const { tableInfo } = useSelector((state: RootState) => state.C1Message);
|
|
|
+
|
|
|
+ const columns = useMemo(() => {
|
|
|
+ return [
|
|
|
+ {
|
|
|
+ title: "留言时间",
|
|
|
+ dataIndex: "createTime",
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: "用户名",
|
|
|
+ dataIndex: "nickName",
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: "留言内容",
|
|
|
+ render: (item: C1TableType) =>
|
|
|
+ item.content.length >= 50 ? (
|
|
|
+ <span style={{ cursor: "pointer" }} title={item.content}>
|
|
|
+ {item.content.substring(0, 50) + "..."}
|
|
|
+ </span>
|
|
|
+ ) : (
|
|
|
+ item.content
|
|
|
+ ),
|
|
|
+ },
|
|
|
+
|
|
|
+ {
|
|
|
+ title: "操作",
|
|
|
+ render: (item: C1TableType) => (
|
|
|
+ <Popconfirm
|
|
|
+ title="删除后无法恢复,是否删除?"
|
|
|
+ okText="删除"
|
|
|
+ cancelText="取消"
|
|
|
+ onConfirm={() => delTableFu(item.id!)}
|
|
|
+ >
|
|
|
+ <Button size="small" type="text" danger>
|
|
|
+ 删除
|
|
|
+ </Button>
|
|
|
+ </Popconfirm>
|
|
|
+ ),
|
|
|
+ },
|
|
|
+ ];
|
|
|
+ }, [delTableFu]);
|
|
|
+
|
|
|
+ // 页码变化
|
|
|
+ const paginationChange = useCallback(
|
|
|
+ () => (pageNum: number, pageSize: number) => {
|
|
|
+ setFromData({ ...fromData, pageNum, pageSize });
|
|
|
+ },
|
|
|
+ [fromData]
|
|
|
+ );
|
|
|
+
|
|
|
return (
|
|
|
<div className={styles.C1Message}>
|
|
|
<div className="pageTitle">留言</div>
|
|
|
+ {/* 顶部搜索 */}
|
|
|
+ <div className="top">
|
|
|
+ <span>留言日期:</span>
|
|
|
+ <RangePicker
|
|
|
+ style={{ width: 300 }}
|
|
|
+ key={inputKey}
|
|
|
+ onChange={timeChange}
|
|
|
+ />
|
|
|
+   
|
|
|
+ <Button onClick={resetSelectFu}>重置</Button>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ {/* 表格主体 */}
|
|
|
+ <div className="tableBox">
|
|
|
+ <Table
|
|
|
+ scroll={{ y: 586 }}
|
|
|
+ dataSource={tableInfo.list}
|
|
|
+ columns={columns}
|
|
|
+ rowKey="id"
|
|
|
+ pagination={{
|
|
|
+ showQuickJumper: true,
|
|
|
+ position: ["bottomCenter"],
|
|
|
+ showSizeChanger: true,
|
|
|
+ current: fromData.pageNum,
|
|
|
+ pageSize: fromData.pageSize,
|
|
|
+ total: tableInfo.total,
|
|
|
+ onChange: paginationChange(),
|
|
|
+ }}
|
|
|
+ />
|
|
|
+ </div>
|
|
|
</div>
|
|
|
);
|
|
|
}
|