feat: 文件分享update
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
|
|
||||||
.settings_container{
|
.settings_container{
|
||||||
height: 75vh;
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
}
|
}
|
||||||
.settings_header{
|
.settings_header{
|
||||||
display: flex;
|
display: flex;
|
||||||
|
@@ -55,7 +55,7 @@ export default () => {
|
|||||||
</Select>
|
</Select>
|
||||||
</div>
|
</div>
|
||||||
</ProCard>
|
</ProCard>
|
||||||
<ProCard style={{ marginTop: 20, height: "60vh" }} bordered boxShadow>
|
<ProCard style={{ marginTop: 20, height: "100%" }} bordered boxShadow>
|
||||||
{location.pathname === "/main/setting" || location.pathname === "/main/setting/" ? (
|
{location.pathname === "/main/setting" || location.pathname === "/main/setting/" ? (
|
||||||
<>
|
<>
|
||||||
<Empty description={"请选择存储商"} />
|
<Empty description={"请选择存储商"} />
|
||||||
|
225
src/components/Main/Share/components/ShareAdd/ShareAdd.tsx
Normal file
225
src/components/Main/Share/components/ShareAdd/ShareAdd.tsx
Normal file
@@ -0,0 +1,225 @@
|
|||||||
|
/** @format */
|
||||||
|
import React, { useEffect, useRef } from "react";
|
||||||
|
import { AiEditor } from "aieditor";
|
||||||
|
import "aieditor/dist/style.css";
|
||||||
|
import { useNavigate } from "react-router-dom";
|
||||||
|
import "aieditor/dist/style.css";
|
||||||
|
import styles from "./index.module.less";
|
||||||
|
import { ProCard } from "@ant-design/pro-components";
|
||||||
|
import { Button, Card, Form, FormListFieldData, FormProps, Input, Select } from "antd";
|
||||||
|
import { CloseOutlined, LeftOutlined, MinusCircleOutlined, PlusOutlined } from "@ant-design/icons";
|
||||||
|
import selectOptions from "@/components/Main/Settings/settings.ts";
|
||||||
|
|
||||||
|
const ShareAdd: React.FunctionComponent = () => {
|
||||||
|
const navigate = useNavigate();
|
||||||
|
const divRef = useRef(null);
|
||||||
|
const fromRef: any = useRef();
|
||||||
|
const [isDisabled, setIsDisabled] = React.useState(false);
|
||||||
|
|
||||||
|
const onFinish: FormProps["onFinish"] = (values) => {
|
||||||
|
console.log("Success:", values);
|
||||||
|
};
|
||||||
|
useEffect(() => {
|
||||||
|
if (divRef.current) {
|
||||||
|
const aiEditor = new AiEditor({
|
||||||
|
element: divRef.current,
|
||||||
|
placeholder: "点击输入描述...",
|
||||||
|
contentRetention: true,
|
||||||
|
textSelectionBubbleMenu: {
|
||||||
|
enable: true,
|
||||||
|
items: ["ai", "Bold", "Italic", "Underline", "Strike", "code", "comment"],
|
||||||
|
},
|
||||||
|
onChange: async (value) => {
|
||||||
|
fromRef.current.setFieldsValue({
|
||||||
|
content: value.getHtml(),
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
||||||
|
return () => {
|
||||||
|
aiEditor.destroy();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}, []);
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<div className={styles.share_add_main}>
|
||||||
|
<ProCard bordered={true}>
|
||||||
|
<Button
|
||||||
|
shape="circle"
|
||||||
|
icon={<LeftOutlined />}
|
||||||
|
onClick={() => {
|
||||||
|
navigate("/main/share/list/1");
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</ProCard>
|
||||||
|
<div className={styles.share_add_content}>
|
||||||
|
<Form onFinish={onFinish} autoComplete="off" ref={fromRef}>
|
||||||
|
<Form.Item
|
||||||
|
label={"标题"}
|
||||||
|
name="title"
|
||||||
|
id={"title"}
|
||||||
|
rules={[{ required: true, message: "请输入标题" }]}>
|
||||||
|
<Input name="title" maxLength={50} showCount></Input>
|
||||||
|
</Form.Item>
|
||||||
|
<Form.Item
|
||||||
|
label={"图标"}
|
||||||
|
id={"icon"}
|
||||||
|
name="icon"
|
||||||
|
rules={[{ required: true, message: "请输入图标" }]}>
|
||||||
|
<Input name="icon"></Input>
|
||||||
|
</Form.Item>
|
||||||
|
<Form.Item
|
||||||
|
label={"摘要"}
|
||||||
|
id={"description"}
|
||||||
|
name="description"
|
||||||
|
rules={[{ required: true, message: "请输入摘要" }]}>
|
||||||
|
<Input name="description" maxLength={100} showCount></Input>
|
||||||
|
</Form.Item>
|
||||||
|
<Form.Item label={"介绍"} name={"content"} id={"content"}>
|
||||||
|
<div
|
||||||
|
ref={divRef}
|
||||||
|
style={{ height: "300px", maxWidth: "100%", minWidth: "100%" }}
|
||||||
|
/>
|
||||||
|
</Form.Item>
|
||||||
|
<Form.List
|
||||||
|
name="tags"
|
||||||
|
rules={[
|
||||||
|
{
|
||||||
|
validator: async (_, tags) => {
|
||||||
|
if (!tags) {
|
||||||
|
return Promise.reject(new Error("请至少填写一个标签"));
|
||||||
|
}
|
||||||
|
if (tags.length >= 3) {
|
||||||
|
setIsDisabled(true);
|
||||||
|
return Promise.reject(
|
||||||
|
new Error("最多只能添加五个标签"),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]}>
|
||||||
|
{(fields: FormListFieldData[], { add, remove }, { errors }) => (
|
||||||
|
<>
|
||||||
|
{fields.map((field: FormListFieldData, index: number) => (
|
||||||
|
<Form.Item
|
||||||
|
label={"标签" + (index + 1)}
|
||||||
|
key={index}
|
||||||
|
id={"tags"}>
|
||||||
|
<Form.Item
|
||||||
|
validateTrigger={["onChange", "onBlur"]}
|
||||||
|
name={[field.name, "tag"]}
|
||||||
|
noStyle>
|
||||||
|
<Input
|
||||||
|
placeholder="请输入标签"
|
||||||
|
maxLength={10}
|
||||||
|
showCount
|
||||||
|
style={{ width: "20%" }}
|
||||||
|
/>
|
||||||
|
</Form.Item>
|
||||||
|
{fields.length > 0 ? (
|
||||||
|
<MinusCircleOutlined
|
||||||
|
className="dynamic-delete-button"
|
||||||
|
onClick={() => {
|
||||||
|
setIsDisabled(false);
|
||||||
|
remove(field.name);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
) : null}
|
||||||
|
</Form.Item>
|
||||||
|
))}
|
||||||
|
<Form.Item>
|
||||||
|
<Button
|
||||||
|
type="dashed"
|
||||||
|
disabled={isDisabled}
|
||||||
|
onClick={() => add()}
|
||||||
|
style={{ width: "100%" }}
|
||||||
|
icon={<PlusOutlined />}>
|
||||||
|
添加标签
|
||||||
|
</Button>
|
||||||
|
<Form.ErrorList errors={errors} />
|
||||||
|
</Form.Item>
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
</Form.List>
|
||||||
|
|
||||||
|
<Form.List name="urls">
|
||||||
|
{(fields: FormListFieldData[], { add, remove }) => (
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
rowGap: 16,
|
||||||
|
flexDirection: "column",
|
||||||
|
}}>
|
||||||
|
{fields.map((field: FormListFieldData, index: number) => (
|
||||||
|
<Card
|
||||||
|
size="small"
|
||||||
|
title={`链接 ${index + 1}`}
|
||||||
|
key={index}
|
||||||
|
extra={
|
||||||
|
<CloseOutlined
|
||||||
|
onClick={() => {
|
||||||
|
remove(field.name);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
}>
|
||||||
|
<Form.Item name={[field.name, "type"]} label="分享类型">
|
||||||
|
<Select
|
||||||
|
size="middle"
|
||||||
|
style={{ width: "20%" }}
|
||||||
|
showSearch={true}
|
||||||
|
allowClear={true}
|
||||||
|
notFoundContent={"未找到哦"}
|
||||||
|
placeholder={"请选择分享类型"}>
|
||||||
|
{selectOptions.map(
|
||||||
|
(storage: any, index: any) => {
|
||||||
|
return (
|
||||||
|
<Select.Option
|
||||||
|
value={storage.value}
|
||||||
|
key={index}>
|
||||||
|
{storage.name}
|
||||||
|
</Select.Option>
|
||||||
|
);
|
||||||
|
},
|
||||||
|
)}
|
||||||
|
</Select>
|
||||||
|
</Form.Item>
|
||||||
|
<Form.Item
|
||||||
|
name={[field.name, "description"]}
|
||||||
|
label="资源描述">
|
||||||
|
<Input name={"description"} />
|
||||||
|
</Form.Item>
|
||||||
|
<Form.Item name={[field.name, "url"]} label="资源链接">
|
||||||
|
<Input name={"url"} />
|
||||||
|
</Form.Item>
|
||||||
|
<Form.Item
|
||||||
|
name={[field.name, "password"]}
|
||||||
|
label={"提取密码"}>
|
||||||
|
<Input name={"password"} />
|
||||||
|
</Form.Item>
|
||||||
|
</Card>
|
||||||
|
))}
|
||||||
|
|
||||||
|
<Button type="dashed" onClick={() => add()} block>
|
||||||
|
+ 添加分享链接
|
||||||
|
</Button>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</Form.List>
|
||||||
|
<Form.Item
|
||||||
|
style={{
|
||||||
|
display: "flex",
|
||||||
|
flexDirection: "row",
|
||||||
|
justifyContent: "flex-end",
|
||||||
|
marginTop: "2%",
|
||||||
|
}}>
|
||||||
|
<Button type="primary" htmlType="submit">
|
||||||
|
保存
|
||||||
|
</Button>
|
||||||
|
</Form.Item>
|
||||||
|
</Form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
export default ShareAdd;
|
@@ -0,0 +1,7 @@
|
|||||||
|
.share_add_main{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
.share_add_content{
|
||||||
|
margin-top: 2%;
|
||||||
|
}
|
||||||
|
}
|
@@ -1,31 +1,26 @@
|
|||||||
/** @format */
|
/** @format */
|
||||||
import React, { useEffect, useRef } from "react";
|
import React from "react";
|
||||||
import { Button } from "antd";
|
import { Avatar, Button, Card, Divider, Flex, Tooltip } from "antd";
|
||||||
import { LeftOutlined } from "@ant-design/icons";
|
import {
|
||||||
|
ExportOutlined,
|
||||||
|
InfoCircleOutlined,
|
||||||
|
LeftOutlined,
|
||||||
|
WarningOutlined,
|
||||||
|
} from "@ant-design/icons";
|
||||||
import { useNavigate } from "react-router-dom";
|
import { useNavigate } from "react-router-dom";
|
||||||
import {AiEditor} from "aieditor";
|
import "aieditor/dist/style.css";
|
||||||
import "aieditor/dist/style.css"
|
import { ProCard } from "@ant-design/pro-components";
|
||||||
|
import styles from "./index.module.less";
|
||||||
|
import logo from "@/assets/icons/baiduyun.svg";
|
||||||
|
import { Typography } from "antd";
|
||||||
|
|
||||||
|
const { Paragraph } = Typography;
|
||||||
const ShareDetail: React.FunctionComponent = () => {
|
const ShareDetail: React.FunctionComponent = () => {
|
||||||
const navigate = useNavigate();
|
const navigate = useNavigate();
|
||||||
//定义 ref
|
|
||||||
const divRef = useRef(null);
|
|
||||||
//初始化 AiEditor
|
|
||||||
useEffect(() => {
|
|
||||||
if (divRef.current) {
|
|
||||||
const aiEditor = new AiEditor({
|
|
||||||
editable:false,
|
|
||||||
element: divRef.current,
|
|
||||||
placeholder: "点击输入内容...",
|
|
||||||
content: 'AiEditor 是一个面向 AI 的开源富文本编辑器。 ',
|
|
||||||
})
|
|
||||||
return ()=>{
|
|
||||||
aiEditor.destroy();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, [])
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
<div>
|
||||||
|
<ProCard bordered={true}>
|
||||||
<Button
|
<Button
|
||||||
shape="circle"
|
shape="circle"
|
||||||
icon={<LeftOutlined />}
|
icon={<LeftOutlined />}
|
||||||
@@ -33,11 +28,103 @@ const ShareDetail: React.FunctionComponent = () => {
|
|||||||
navigate("/main/share/list/1");
|
navigate("/main/share/list/1");
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
<div>
|
</ProCard>
|
||||||
<div ref={divRef} style={{ height: 550}}>
|
<div className={styles.share_detail_container}>
|
||||||
|
<ProCard bordered={true}>
|
||||||
|
<div style={{ height: 500 }}>
|
||||||
|
资源描述
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<Card style={{ borderRadius: "10px", borderColor: "#1677FF" }}>
|
||||||
|
<Flex vertical={false} align={"center"} justify={"space-between"}>
|
||||||
|
<span
|
||||||
|
style={{
|
||||||
|
fontSize: 18,
|
||||||
|
color: "#1677FF",
|
||||||
|
fontWeight: "bolder",
|
||||||
|
}}>
|
||||||
|
资源下载
|
||||||
|
</span>
|
||||||
|
<Button icon={<WarningOutlined />} type={"primary"}>
|
||||||
|
投诉
|
||||||
|
</Button>
|
||||||
|
</Flex>
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
align={"center"}
|
||||||
|
style={{ marginTop: 10 }}
|
||||||
|
justify={"space-between"}>
|
||||||
|
<span style={{ fontSize: 16 }}>Windows DefenderRemover</span>
|
||||||
|
</Flex>
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
align={"center"}
|
||||||
|
style={{ marginTop: 10 }}
|
||||||
|
justify={"space-between"}>
|
||||||
|
<span
|
||||||
|
style={{
|
||||||
|
fontSize: 18,
|
||||||
|
color: "#1677FF",
|
||||||
|
fontWeight: "bolder",
|
||||||
|
}}>
|
||||||
|
下载地址
|
||||||
|
</span>
|
||||||
|
</Flex>
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
align={"center"}
|
||||||
|
style={{ marginTop: 10 }}
|
||||||
|
justify={"space-between"}>
|
||||||
|
<Card hoverable={true} style={{ width: 280, height: 140 }}>
|
||||||
|
<Flex vertical={true}>
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
justify={"space-between"}
|
||||||
|
align={"center"}>
|
||||||
<div>
|
<div>
|
||||||
555
|
<Avatar src={logo}></Avatar>
|
||||||
|
<span
|
||||||
|
style={{
|
||||||
|
marginLeft: 10,
|
||||||
|
color: "#1677FF",
|
||||||
|
fontSize: 16,
|
||||||
|
}}>
|
||||||
|
百度云
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<ExportOutlined className={styles.link_btn} />
|
||||||
|
</Flex>
|
||||||
|
<Divider></Divider>
|
||||||
|
<Flex vertical={false}>
|
||||||
|
<Tooltip
|
||||||
|
title="DefenderRemove111111111"
|
||||||
|
placement={"bottom"}>
|
||||||
|
<span style={{ width: 150, overflowX: "hidden" }}>
|
||||||
|
DefenderRemove111111111
|
||||||
|
</span>
|
||||||
|
</Tooltip>
|
||||||
|
<span
|
||||||
|
style={{
|
||||||
|
width: 130,
|
||||||
|
marginLeft: 10,
|
||||||
|
display: "flex",
|
||||||
|
flexDirection: "row",
|
||||||
|
}}>
|
||||||
|
<span style={{ color: "#1677FF" }}>密码:</span>{" "}
|
||||||
|
<Paragraph copyable>12345</Paragraph>
|
||||||
|
</span>
|
||||||
|
</Flex>
|
||||||
|
</Flex>
|
||||||
|
</Card>
|
||||||
|
</Flex>
|
||||||
|
<Flex vertical={false} style={{ marginTop: 10 }}>
|
||||||
|
<span style={{ color: "grey" }}>
|
||||||
|
<InfoCircleOutlined />
|
||||||
|
本站所有资源均来源于网络,仅供学习使用,请下载后24小时内删除
|
||||||
|
</span>
|
||||||
|
</Flex>
|
||||||
|
</Card>
|
||||||
|
</ProCard>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</>
|
</>
|
||||||
|
@@ -0,0 +1,10 @@
|
|||||||
|
.share_detail_container{
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
.link_btn{
|
||||||
|
font-size: 20px;
|
||||||
|
color: grey;
|
||||||
|
}
|
||||||
|
.link_btn:hover{
|
||||||
|
color: #1890ff;
|
||||||
|
}
|
@@ -1,13 +1,14 @@
|
|||||||
/** @format */
|
/** @format */
|
||||||
|
|
||||||
import { ProCard } from "@ant-design/pro-components";
|
import { ProCard } from "@ant-design/pro-components";
|
||||||
import { Avatar, Button, Divider, List, Skeleton } from "antd";
|
import { Avatar, Button, Divider, Flex, List, Skeleton, Tag } from "antd";
|
||||||
import { useEffect, useState } from "react";
|
import { useEffect, useState } from "react";
|
||||||
import styles from "./index.module.less";
|
import styles from "./index.module.less";
|
||||||
import Search from "antd/es/input/Search";
|
import Search from "antd/es/input/Search";
|
||||||
import InfiniteScroll from "react-infinite-scroll-component";
|
import InfiniteScroll from "react-infinite-scroll-component";
|
||||||
import { useNavigate } from "react-router-dom";
|
import { useNavigate } from "react-router-dom";
|
||||||
import { LeftOutlined } from "@ant-design/icons";
|
import { CommentOutlined, EyeOutlined, HeartOutlined, LeftOutlined } from "@ant-design/icons";
|
||||||
|
import logo from "@/assets/icons/aliyun.svg";
|
||||||
interface DataType {
|
interface DataType {
|
||||||
gender: string;
|
gender: string;
|
||||||
name: {
|
name: {
|
||||||
@@ -23,11 +24,11 @@ interface DataType {
|
|||||||
};
|
};
|
||||||
nat: string;
|
nat: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default () => {
|
export default () => {
|
||||||
const navigate = useNavigate();
|
const navigate = useNavigate();
|
||||||
const [loading, setLoading] = useState(false);
|
const [loading, setLoading] = useState(false);
|
||||||
const [data, setData] = useState<DataType[]>([]);
|
const [data, setData] = useState<DataType[]>([]);
|
||||||
|
|
||||||
const loadMoreData = () => {
|
const loadMoreData = () => {
|
||||||
if (loading) {
|
if (loading) {
|
||||||
return;
|
return;
|
||||||
@@ -63,7 +64,12 @@ export default () => {
|
|||||||
<Search placeholder="搜索" style={{ width: 500, marginLeft: 20 }} />
|
<Search placeholder="搜索" style={{ width: 500, marginLeft: 20 }} />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<Button>分享</Button>
|
<Button
|
||||||
|
onClick={() => {
|
||||||
|
navigate("/main/share/add");
|
||||||
|
}}>
|
||||||
|
分享
|
||||||
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</ProCard>
|
</ProCard>
|
||||||
<ProCard bordered={true} boxShadow={true} style={{ marginTop: 20 }}>
|
<ProCard bordered={true} boxShadow={true} style={{ marginTop: 20 }}>
|
||||||
@@ -81,16 +87,62 @@ export default () => {
|
|||||||
<List.Item.Meta
|
<List.Item.Meta
|
||||||
avatar={<Avatar src={item.picture.large} />}
|
avatar={<Avatar src={item.picture.large} />}
|
||||||
title={
|
title={
|
||||||
|
<>
|
||||||
<a
|
<a
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
navigate("/main/share/detail/1");
|
navigate("/main/share/detail/1");
|
||||||
}}>
|
}}>
|
||||||
{item.name.last}
|
{item.name.last}
|
||||||
</a>
|
</a>
|
||||||
|
<Tag
|
||||||
|
bordered={false}
|
||||||
|
color="processing"
|
||||||
|
style={{ marginLeft: 10 }}>
|
||||||
|
IDM
|
||||||
|
</Tag>
|
||||||
|
</>
|
||||||
|
}
|
||||||
|
description={
|
||||||
|
<>
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
justify={"space-between"}
|
||||||
|
align={"center"}>
|
||||||
|
{item.email}
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
align={"center"}
|
||||||
|
justify={"space-between"}
|
||||||
|
style={{ width: "250px" }}>
|
||||||
|
<Avatar src={logo} size={"small"} />
|
||||||
|
<span
|
||||||
|
style={{
|
||||||
|
fontSize: 12,
|
||||||
|
color: "gray",
|
||||||
|
}}>
|
||||||
|
landaiqing
|
||||||
|
</span>
|
||||||
|
<HeartOutlined />
|
||||||
|
<span
|
||||||
|
style={{ fontSize: 12, color: "gray" }}>
|
||||||
|
1024
|
||||||
|
</span>
|
||||||
|
<CommentOutlined />
|
||||||
|
<span
|
||||||
|
style={{ fontSize: 12, color: "gray" }}>
|
||||||
|
1024
|
||||||
|
</span>
|
||||||
|
<EyeOutlined style={{ color: "gray" }} />{" "}
|
||||||
|
<span
|
||||||
|
style={{ fontSize: 12, color: "gray" }}>
|
||||||
|
1024
|
||||||
|
</span>
|
||||||
|
</Flex>
|
||||||
|
</Flex>
|
||||||
|
</>
|
||||||
}
|
}
|
||||||
description={item.email}
|
|
||||||
/>
|
/>
|
||||||
<div>Content</div>
|
{/*<div>Content</div>*/}
|
||||||
</List.Item>
|
</List.Item>
|
||||||
)}
|
)}
|
||||||
/>
|
/>
|
||||||
|
@@ -1,28 +1,39 @@
|
|||||||
/** @format */
|
/** @format */
|
||||||
import { FunctionComponent } from "react";
|
import { FunctionComponent, useState } from "react";
|
||||||
import { ProCard } from "@ant-design/pro-components";
|
import { ProCard } from "@ant-design/pro-components";
|
||||||
import styles from "./index.module.less";
|
import styles from "./index.module.less";
|
||||||
import { Button, Card, Image } from "antd";
|
import { Avatar, Button, Card, Drawer, Flex, Form, Image, Input, Space } from "antd";
|
||||||
|
|
||||||
import Search from "antd/es/input/Search";
|
import Search from "antd/es/input/Search";
|
||||||
import Meta from "antd/es/card/Meta";
|
import Meta from "antd/es/card/Meta";
|
||||||
import { useNavigate } from "react-router-dom";
|
import { useNavigate } from "react-router-dom";
|
||||||
import background from "@/assets/images/background.png";
|
import background from "@/assets/images/background.png";
|
||||||
|
import TextArea from "antd/es/input/TextArea";
|
||||||
|
import { EyeOutlined, UnorderedListOutlined } from "@ant-design/icons";
|
||||||
const MainShare: FunctionComponent = () => {
|
const MainShare: FunctionComponent = () => {
|
||||||
const navigate = useNavigate();
|
const navigate = useNavigate();
|
||||||
|
const [open, setOpen] = useState(false);
|
||||||
|
const showDrawer = () => {
|
||||||
|
setOpen(true);
|
||||||
|
};
|
||||||
|
|
||||||
|
const onClose = () => {
|
||||||
|
setOpen(false);
|
||||||
|
};
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<div className={styles.share_main}>
|
<div className={styles.share_main}>
|
||||||
<ProCard bordered={true} boxShadow={false}>
|
<ProCard bordered={true} boxShadow={true}>
|
||||||
<div className={styles.share_header}>
|
<div className={styles.share_header}>
|
||||||
<Search placeholder="搜索圈子" style={{ width: 500 }} />
|
<Search placeholder="搜索圈子" style={{ width: 500 }} />
|
||||||
<Button>创建圈子</Button>
|
<Button onClick={showDrawer}>创建圈子</Button>
|
||||||
</div>
|
</div>
|
||||||
</ProCard>
|
</ProCard>
|
||||||
<ProCard bordered={true} boxShadow={false} style={{ marginTop: 20 }}>
|
<ProCard bordered={true} boxShadow={true} style={{ marginTop: 20 }}>
|
||||||
|
<Flex vertical={false} align={"center"}>
|
||||||
<Card
|
<Card
|
||||||
hoverable
|
hoverable
|
||||||
style={{ width: 240 }}
|
style={{ width: "250px" }}
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
navigate("/main/share/list/1");
|
navigate("/main/share/list/1");
|
||||||
}}
|
}}
|
||||||
@@ -36,10 +47,108 @@ const MainShare: FunctionComponent = () => {
|
|||||||
fallback=""
|
fallback=""
|
||||||
/>
|
/>
|
||||||
}>
|
}>
|
||||||
<Meta title="Europe Street beat" description="www.instagram.com" />
|
<Meta title="工具软件分享" description="分享一些常用的办公软件" />
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
style={{ marginTop: 10 }}
|
||||||
|
align={"center"}
|
||||||
|
justify={"space-between"}>
|
||||||
|
<Avatar src={background} size={"small"} />{" "}
|
||||||
|
<span style={{ fontSize: 12, color: "gray" }}>landaiqing</span>
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
align={"center"}
|
||||||
|
style={{ width: 100 }}
|
||||||
|
justify={"space-between"}>
|
||||||
|
<EyeOutlined style={{ color: "gray" }} />{" "}
|
||||||
|
<span style={{ fontSize: 12, color: "gray" }}>1024</span>
|
||||||
|
<UnorderedListOutlined style={{ color: "gray" }} />{" "}
|
||||||
|
<span style={{ fontSize: 12, color: "gray" }}>999</span>
|
||||||
|
</Flex>
|
||||||
|
</Flex>
|
||||||
</Card>
|
</Card>
|
||||||
|
|
||||||
|
<Card
|
||||||
|
hoverable
|
||||||
|
style={{ width: "250px", marginLeft: 20 }}
|
||||||
|
onClick={() => {
|
||||||
|
navigate("/main/share/list/1");
|
||||||
|
}}
|
||||||
|
cover={
|
||||||
|
<Image
|
||||||
|
alt="example"
|
||||||
|
src={background}
|
||||||
|
style={{ height: 200 }}
|
||||||
|
preview={false}
|
||||||
|
width={"100%"}
|
||||||
|
fallback=""
|
||||||
|
/>
|
||||||
|
}>
|
||||||
|
<Meta title="工具软件分享" description="分享一些常用的办公软件" />
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
style={{ marginTop: 10 }}
|
||||||
|
align={"center"}
|
||||||
|
justify={"space-between"}>
|
||||||
|
<Avatar src={background} size={"small"} />{" "}
|
||||||
|
<span style={{ fontSize: 12, color: "gray" }}>landaiqing</span>
|
||||||
|
<Flex
|
||||||
|
vertical={false}
|
||||||
|
align={"center"}
|
||||||
|
style={{ width: 100 }}
|
||||||
|
justify={"space-between"}>
|
||||||
|
<EyeOutlined style={{ color: "gray" }} />{" "}
|
||||||
|
<span style={{ fontSize: 12, color: "gray" }}>1024</span>
|
||||||
|
<UnorderedListOutlined style={{ color: "gray" }} />{" "}
|
||||||
|
<span style={{ fontSize: 12, color: "gray" }}>999</span>
|
||||||
|
</Flex>
|
||||||
|
</Flex>
|
||||||
|
</Card>
|
||||||
|
</Flex>
|
||||||
</ProCard>
|
</ProCard>
|
||||||
</div>
|
</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.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>
|
||||||
|
</Drawer>
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@@ -7,6 +7,7 @@ import {
|
|||||||
Button,
|
Button,
|
||||||
Descriptions,
|
Descriptions,
|
||||||
DescriptionsProps,
|
DescriptionsProps,
|
||||||
|
Flex,
|
||||||
Form,
|
Form,
|
||||||
FormProps,
|
FormProps,
|
||||||
Input,
|
Input,
|
||||||
@@ -206,13 +207,16 @@ const UserSetting: FunctionComponent = () => {
|
|||||||
<Skeleton loading={loading} active>
|
<Skeleton loading={loading} active>
|
||||||
<Space direction={"vertical"} style={{ width: "100%" }}>
|
<Space direction={"vertical"} style={{ width: "100%" }}>
|
||||||
<ProCard hoverable bordered>
|
<ProCard hoverable bordered>
|
||||||
登录密码:
|
<Flex vertical={false} align={"center"} justify={"space-between"}>
|
||||||
|
<span style={{ width: 80 }}>登录密码:</span>
|
||||||
|
<Input variant="borderless" value={"******************"} />
|
||||||
|
</Flex>
|
||||||
</ProCard>
|
</ProCard>
|
||||||
<ProCard hoverable bordered>
|
<ProCard hoverable bordered>
|
||||||
安全手机:
|
安全手机:1333333333333333
|
||||||
</ProCard>
|
</ProCard>
|
||||||
<ProCard hoverable bordered>
|
<ProCard hoverable bordered>
|
||||||
安全邮箱:
|
安全邮箱:landaiqing@126.com
|
||||||
</ProCard>
|
</ProCard>
|
||||||
</Space>
|
</Space>
|
||||||
</Skeleton>
|
</Skeleton>
|
||||||
|
11
src/router/modules/main/share/modules/shareAdd.tsx
Normal file
11
src/router/modules/main/share/modules/shareAdd.tsx
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
/** @format */
|
||||||
|
|
||||||
|
import { lazy } from "react";
|
||||||
|
|
||||||
|
const ShareAdd = lazy(
|
||||||
|
() =>
|
||||||
|
new Promise((resolve: any) => {
|
||||||
|
resolve(import("@/components/Main/Share/components/ShareAdd/ShareAdd.tsx"));
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
export default ShareAdd;
|
@@ -46,6 +46,7 @@ import qiniuBucket from "@/router/modules/main/bucket/createBuckets/qiniu.ts";
|
|||||||
import ucloudBucket from "@/router/modules/main/bucket/createBuckets/ucloud.ts";
|
import ucloudBucket from "@/router/modules/main/bucket/createBuckets/ucloud.ts";
|
||||||
import upBucket from "@/router/modules/main/bucket/createBuckets/up.ts";
|
import upBucket from "@/router/modules/main/bucket/createBuckets/up.ts";
|
||||||
import wangyiBucket from "@/router/modules/main/bucket/createBuckets/wangyi.ts";
|
import wangyiBucket from "@/router/modules/main/bucket/createBuckets/wangyi.ts";
|
||||||
|
import ShareAdd from "@/router/modules/main/share/modules/shareAdd.tsx";
|
||||||
|
|
||||||
const routes: RouteObject[] = [
|
const routes: RouteObject[] = [
|
||||||
{
|
{
|
||||||
@@ -163,6 +164,10 @@ const routes: RouteObject[] = [
|
|||||||
path: "/main/share/detail/:id",
|
path: "/main/share/detail/:id",
|
||||||
Component: ShareDetail,
|
Component: ShareDetail,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: "/main/share/add",
|
||||||
|
Component: ShareAdd,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: "/main/setting",
|
path: "/main/setting",
|
||||||
Component: MainSetting,
|
Component: MainSetting,
|
||||||
|
@@ -32,14 +32,14 @@ export default function AuthRoute(props: { children: React.ReactNode }) {
|
|||||||
return <Navigate to="/404" />;
|
return <Navigate to="/404" />;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if (!isLogin) {
|
if (!isLogin) {
|
||||||
// message
|
message
|
||||||
// .open({
|
.open({
|
||||||
// content: "请先登录!",
|
content: "请先登录!",
|
||||||
// type: "warning",
|
type: "warning",
|
||||||
// })
|
})
|
||||||
// .then();
|
.then();
|
||||||
// return <Navigate to="/login" />;
|
return <Navigate to="/login" />;
|
||||||
// }
|
}
|
||||||
return props.children;
|
return props.children;
|
||||||
}
|
}
|
||||||
|
@@ -6,19 +6,24 @@ import {
|
|||||||
LogoutOutlined,
|
LogoutOutlined,
|
||||||
QuestionCircleFilled,
|
QuestionCircleFilled,
|
||||||
} from "@ant-design/icons";
|
} from "@ant-design/icons";
|
||||||
import { DefaultFooter, PageContainer, ProCard, ProLayout } from "@ant-design/pro-components";
|
import {
|
||||||
import settings from "./settings.tsx";
|
DefaultFooter,
|
||||||
|
PageContainer,
|
||||||
|
ProCard,
|
||||||
|
ProLayout,
|
||||||
|
} from "@ant-design/pro-components";
|
||||||
import { Link, Outlet, useLocation } from "react-router-dom";
|
import { Link, Outlet, useLocation } from "react-router-dom";
|
||||||
import logo from "@/assets/images/logo.png";
|
import logo from "@/assets/images/logo.png";
|
||||||
import { Suspense } from "react";
|
import { Suspense } from "react";
|
||||||
import { Dropdown } from "antd";
|
import { Dropdown } from "antd";
|
||||||
|
import settings from "@/views/Main/settings.tsx";
|
||||||
// import { getUserMenuPermission } from "@/api/user";
|
// import { getUserMenuPermission } from "@/api/user";
|
||||||
|
|
||||||
export default function Layout() {
|
export default function Layout() {
|
||||||
const location = useLocation();
|
const location = useLocation();
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
id="test-pro-layout"
|
id="pro-layout"
|
||||||
style={{
|
style={{
|
||||||
height: "100vh",
|
height: "100vh",
|
||||||
}}>
|
}}>
|
||||||
|
Reference in New Issue
Block a user