258 lines
10 KiB
TypeScript
258 lines
10 KiB
TypeScript
/** @format */
|
|
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,
|
|
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 Meta from "antd/es/card/Meta";
|
|
import { addShareCircle, getShareCircleList } from "@/api/share";
|
|
import useStore from "@/utils/store/useStore.tsx";
|
|
import { observer } from "mobx-react";
|
|
const MainShare: FunctionComponent = observer(() => {
|
|
const store = useStore("user");
|
|
const userId: any = store.getUserId();
|
|
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}>
|
|
<ProCard bordered={false} boxShadow={false}>
|
|
<div className={styles.share_header}>
|
|
<Input
|
|
size={"large"}
|
|
placeholder="搜索圈子"
|
|
style={{ width: 500, borderRadius: 20 }}
|
|
/>
|
|
</div>
|
|
</ProCard>
|
|
<ProCard title={<h3>文件分享圈</h3>} bordered={false} boxShadow={false}>
|
|
<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>
|
|
<Drawer
|
|
title="创建圈子"
|
|
width={"40%"}
|
|
onClose={onClose}
|
|
open={open}
|
|
styles={{
|
|
body: {
|
|
paddingBottom: 80,
|
|
},
|
|
}}
|
|
// extra={
|
|
// <Space>
|
|
// <Button onClick={onClose}>取消</Button>
|
|
// <Button onClick={onClose} type="primary">
|
|
// 提交
|
|
// </Button>
|
|
// </Space>
|
|
// }
|
|
>
|
|
<Form
|
|
layout="vertical"
|
|
form={form}
|
|
onFinish={(values: any) => {
|
|
const formData: any = {
|
|
userId: userId,
|
|
...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="名称"
|
|
rules={[{ required: true, message: "请输入圈子名称!" }]}>
|
|
<Input maxLength={30} showCount placeholder="请输入圈子名称!" />
|
|
</Form.Item>
|
|
|
|
<Form.Item
|
|
name="icon"
|
|
label="图标"
|
|
rules={[{ required: true, message: "请输入图标!" }]}>
|
|
<Input placeholder="请输入图标!" />
|
|
</Form.Item>
|
|
|
|
<Form.Item
|
|
name="description"
|
|
label="描述"
|
|
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
|
|
type={"primary"}
|
|
style={{ right: "5%", width: 50, height: 50 }}
|
|
icon={<PlusOutlined />}
|
|
onClick={() => setOpen(true)}
|
|
/>
|
|
</>
|
|
);
|
|
});
|
|
export default MainShare;
|