import { useEffect, useState } from "react"; import { Button, Row, Col, Popconfirm, Image, Empty, message, Pagination, } from "antd"; import { resource } from "../../../api"; import styles from "./index.module.less"; import { CloseOutlined } from "@ant-design/icons"; import { UploadImageSub } from "../../../compenents/upload-image-button/upload-image-sub"; import { TreeCategory } from "../../../compenents"; interface ImageItem { id: number; category_id: number; name: string; extension: string; size: number; disk: string; file_id: string; path: string; url: string; created_at: string; } export const ResourceImagesPage = () => { const [imageList, setImageList] = useState([]); const [refresh, setRefresh] = useState(false); const [page, setPage] = useState(1); const [size, setSize] = useState(12); const [total, setTotal] = useState(0); const [category_ids, setCategoryIds] = useState([]); // 删除图片 const removeCategory = (id: number) => { if (id === 0) { return; } resource.destroyResource(id).then(() => { message.success("删除成功"); resetImageList(); }); }; // 获取图片列表 const getImageList = () => { let categoryIds = category_ids.join(","); resource .resourceList(page, size, "", "", "", "IMAGE", categoryIds) .then((res: any) => { setTotal(res.data.result.total); setImageList(res.data.result.data); }) .catch((err: any) => { console.log("错误,", err); }); }; // 重置列表 const resetImageList = () => { setPage(1); setImageList([]); setRefresh(!refresh); }; // 加载图片列表 useEffect(() => { getImageList(); }, [category_ids, refresh, page, size]); return ( <>
setCategoryIds(keys)} />
{ resetImageList(); }} > {imageList.length === 0 && ( )} {imageList.map((item) => (
removeCategory(item.id)} okText="确定" cancelText="取消" >
))} {imageList.length > 0 && ( { setPage(currentPage); setSize(currentSize); }} defaultCurrent={page} total={total} /> )}
); };