feat: 评论接口对接
This commit is contained in:
@@ -1,22 +1,48 @@
|
||||
/** @format */
|
||||
import { FunctionComponent, useState } from "react";
|
||||
import { FunctionComponent, useEffect, useState } from "react";
|
||||
import { ProCard } from "@ant-design/pro-components";
|
||||
import styles from "./index.module.less";
|
||||
import { Avatar, Button, Card, Drawer, Flex, FloatButton, Form, Image, Input, Space } from "antd";
|
||||
import {
|
||||
Avatar,
|
||||
Button,
|
||||
Card,
|
||||
Drawer,
|
||||
Flex,
|
||||
FloatButton,
|
||||
Form,
|
||||
Image,
|
||||
Input,
|
||||
message,
|
||||
Skeleton,
|
||||
Tooltip,
|
||||
} from "antd";
|
||||
|
||||
import { useNavigate } from "react-router-dom";
|
||||
import TextArea from "antd/es/input/TextArea";
|
||||
import { EyeOutlined, PlusOutlined, UnorderedListOutlined } from "@ant-design/icons";
|
||||
import pic from "@/assets/images/background.png";
|
||||
|
||||
import Meta from "antd/es/card/Meta";
|
||||
import { addShareCircle, getShareCircleList } from "@/api/share";
|
||||
const MainShare: FunctionComponent = () => {
|
||||
const navigate = useNavigate();
|
||||
const [open, setOpen] = useState(false);
|
||||
|
||||
const [loading, setLoading] = useState(true);
|
||||
const [circleList, setCircleList] = useState<any[]>([]);
|
||||
const [form] = Form.useForm();
|
||||
const onClose = () => {
|
||||
setOpen(false);
|
||||
};
|
||||
async function getShareCircles() {
|
||||
getShareCircleList().then((res: any) => {
|
||||
if (res && res.success && res.data) {
|
||||
setCircleList(res.data);
|
||||
setLoading(false);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
useEffect(() => {
|
||||
getShareCircles().then();
|
||||
}, []);
|
||||
return (
|
||||
<>
|
||||
<div className={styles.share_main}>
|
||||
@@ -30,77 +56,108 @@ const MainShare: FunctionComponent = () => {
|
||||
</div>
|
||||
</ProCard>
|
||||
<ProCard title={<h3>文件分享圈</h3>} bordered={false} boxShadow={false}>
|
||||
<Flex vertical={false} align={"center"}>
|
||||
<Card
|
||||
hoverable
|
||||
style={{
|
||||
width: "250px",
|
||||
boxShadow: " 0 0 10px rgba(0, 0, 0, 0.1)",
|
||||
borderRadius: 20,
|
||||
// backgroundColor: "rgba(79,68,68,0.11)",
|
||||
}}
|
||||
onClick={() => {
|
||||
navigate("/main/share/list/1");
|
||||
}}
|
||||
cover={
|
||||
<Image
|
||||
alt="example"
|
||||
src={pic as any}
|
||||
style={{
|
||||
height: 180,
|
||||
borderTopLeftRadius: 20,
|
||||
borderTopRightRadius: 20,
|
||||
}}
|
||||
preview={false}
|
||||
width={"100%"}
|
||||
fallback=""
|
||||
/>
|
||||
}>
|
||||
<Meta title="工具软件分享" description="分享一些常用的办公软件" />
|
||||
{/*<Avatar*/}
|
||||
{/* src={pic2 as any}*/}
|
||||
{/* shape={"circle"}*/}
|
||||
{/* style={{*/}
|
||||
{/* position: "absolute",*/}
|
||||
{/* top: 160,*/}
|
||||
{/* left: 10,*/}
|
||||
{/* width: 60,*/}
|
||||
{/* height: 60,*/}
|
||||
{/* zIndex: 9999,*/}
|
||||
{/* }}></Avatar>*/}
|
||||
<Flex
|
||||
vertical={false}
|
||||
style={{ marginTop: 10 }}
|
||||
align={"center"}
|
||||
justify={"space-between"}>
|
||||
<Flex vertical={false} align={"center"}>
|
||||
<Avatar src={pic as any} size={"small"} />{" "}
|
||||
<span style={{ fontSize: 12, color: "gray", marginLeft: 5 }}>
|
||||
landaiqing
|
||||
</span>
|
||||
</Flex>
|
||||
<Flex
|
||||
vertical={false}
|
||||
align={"center"}
|
||||
style={{ width: 100 }}
|
||||
justify={"space-between"}>
|
||||
<Flex vertical={false} align={"center"}>
|
||||
<EyeOutlined style={{ color: "gray" }} />{" "}
|
||||
<span
|
||||
style={{ fontSize: 12, color: "gray", marginLeft: 5 }}>
|
||||
1024
|
||||
</span>
|
||||
</Flex>
|
||||
<Flex vertical={false} align={"center"}>
|
||||
<UnorderedListOutlined style={{ color: "gray" }} />{" "}
|
||||
<span
|
||||
style={{ fontSize: 12, color: "gray", marginLeft: 5 }}>
|
||||
999
|
||||
</span>
|
||||
</Flex>
|
||||
</Flex>
|
||||
</Flex>
|
||||
</Card>
|
||||
<Flex vertical={false} align={"center"} wrap={true} justify={"flex-start"}>
|
||||
<Skeleton active={true} loading={loading} paragraph={{ rows: 10 }}>
|
||||
{circleList &&
|
||||
circleList.map((item: any, index: number) => {
|
||||
return (
|
||||
<div key={index}>
|
||||
<Card
|
||||
hoverable
|
||||
style={{
|
||||
width: "250px",
|
||||
boxShadow: " 0 0 10px rgba(0, 0, 0, 0.1)",
|
||||
borderRadius: 20,
|
||||
marginLeft: 30,
|
||||
marginTop: 20,
|
||||
// backgroundColor: "rgba(79,68,68,0.11)",
|
||||
}}
|
||||
onClick={() => {
|
||||
navigate("/main/share/list/" + item.id);
|
||||
}}
|
||||
cover={
|
||||
<Image
|
||||
alt="example"
|
||||
src={item.icon}
|
||||
style={{
|
||||
height: 180,
|
||||
borderTopLeftRadius: 20,
|
||||
borderTopRightRadius: 20,
|
||||
backgroundSize: "cover",
|
||||
}}
|
||||
preview={false}
|
||||
width={"100%"}
|
||||
height={"100%"}
|
||||
fallback=""
|
||||
/>
|
||||
}>
|
||||
<Meta
|
||||
title={item.name}
|
||||
description={
|
||||
<>
|
||||
<Tooltip title={item.description}>
|
||||
<span>{item.description}</span>
|
||||
</Tooltip>
|
||||
</>
|
||||
}
|
||||
/>
|
||||
<Flex
|
||||
vertical={false}
|
||||
style={{ marginTop: 10 }}
|
||||
align={"center"}
|
||||
justify={"space-between"}>
|
||||
<Flex vertical={false} align={"center"}>
|
||||
<Avatar
|
||||
src={item.avatar as any}
|
||||
size={"small"}
|
||||
/>{" "}
|
||||
<span
|
||||
style={{
|
||||
fontSize: 12,
|
||||
color: "gray",
|
||||
marginLeft: 5,
|
||||
}}>
|
||||
{item.nickName}
|
||||
</span>
|
||||
</Flex>
|
||||
<Flex
|
||||
vertical={false}
|
||||
align={"center"}
|
||||
style={{ width: 100 }}
|
||||
justify={"space-between"}>
|
||||
<Flex vertical={false} align={"center"}>
|
||||
<EyeOutlined
|
||||
style={{ color: "gray" }}
|
||||
/>{" "}
|
||||
<span
|
||||
style={{
|
||||
fontSize: 12,
|
||||
color: "gray",
|
||||
marginLeft: 5,
|
||||
}}>
|
||||
{item.views}
|
||||
</span>
|
||||
</Flex>
|
||||
<Flex vertical={false} align={"center"}>
|
||||
<UnorderedListOutlined
|
||||
style={{ color: "gray" }}
|
||||
/>{" "}
|
||||
<span
|
||||
style={{
|
||||
fontSize: 12,
|
||||
color: "gray",
|
||||
marginLeft: 5,
|
||||
}}>
|
||||
{item.count}
|
||||
</span>
|
||||
</Flex>
|
||||
</Flex>
|
||||
</Flex>
|
||||
</Card>
|
||||
</div>
|
||||
);
|
||||
})}
|
||||
</Skeleton>
|
||||
</Flex>
|
||||
</ProCard>
|
||||
</div>
|
||||
@@ -114,15 +171,44 @@ const MainShare: FunctionComponent = () => {
|
||||
paddingBottom: 80,
|
||||
},
|
||||
}}
|
||||
extra={
|
||||
<Space>
|
||||
<Button onClick={onClose}>取消</Button>
|
||||
<Button onClick={onClose} type="primary">
|
||||
提交
|
||||
</Button>
|
||||
</Space>
|
||||
}>
|
||||
<Form layout="vertical">
|
||||
// extra={
|
||||
// <Space>
|
||||
// <Button onClick={onClose}>取消</Button>
|
||||
// <Button onClick={onClose} type="primary">
|
||||
// 提交
|
||||
// </Button>
|
||||
// </Space>
|
||||
// }
|
||||
>
|
||||
<Form
|
||||
layout="vertical"
|
||||
form={form}
|
||||
onFinish={(values: any) => {
|
||||
const formData = {
|
||||
userId: 17,
|
||||
...values,
|
||||
};
|
||||
addShareCircle(formData).then((res: any) => {
|
||||
if (res && res.success && res.data) {
|
||||
message
|
||||
.open({
|
||||
content: "创建成功",
|
||||
type: "success",
|
||||
})
|
||||
.then();
|
||||
setOpen(false);
|
||||
getShareCircles().then();
|
||||
form.resetFields();
|
||||
} else {
|
||||
message
|
||||
.open({
|
||||
content: res.data,
|
||||
type: "error",
|
||||
})
|
||||
.then();
|
||||
}
|
||||
});
|
||||
}}>
|
||||
<Form.Item
|
||||
name="name"
|
||||
label="名称"
|
||||
@@ -143,6 +229,16 @@ const MainShare: FunctionComponent = () => {
|
||||
rules={[{ required: true, message: "请输入描述!" }]}>
|
||||
<TextArea rows={4} maxLength={50} showCount placeholder="请输入描述!" />
|
||||
</Form.Item>
|
||||
<Form.Item
|
||||
style={{
|
||||
display: "flex",
|
||||
flexDirection: "row",
|
||||
justifyContent: "flex-end",
|
||||
}}>
|
||||
<Button type="primary" htmlType="submit">
|
||||
提交
|
||||
</Button>
|
||||
</Form.Item>
|
||||
</Form>
|
||||
</Drawer>
|
||||
<FloatButton
|
||||
|
Reference in New Issue
Block a user