diff --git a/src/api/user/index.ts b/src/api/user/index.ts index 00ef845..f3a20f5 100644 --- a/src/api/user/index.ts +++ b/src/api/user/index.ts @@ -156,7 +156,10 @@ export const getUserInfoApi = (userId: string): any => { export const updateUserInfo = (data: any): any => { return web.request({ url: "/auth/auth/user/update", - method: "get", + method: "post", + headers: { + "Content-Type": "application/json;charset=UTF-8", + }, data: data, }); }; @@ -195,3 +198,29 @@ export const logout = (userId: any): any => { }, }); }; +/** + * 检查用户名是否已存在 + * @param userName + */ +export const checkUserName = (userName: any): any => { + return web.request({ + url: "/auth/auth/user/checkUserName", + method: "post", + params: { + userName: userName, + }, + }); +}; +/** + * 获取最近分享 + * @param userId + */ +export const getRecentShare = (userId: any): any => { + return web.request({ + url: "/share/share/detail/getRecentShare", + method: "get", + params: { + userId: userId, + }, + }); +}; diff --git a/src/components/Main/File/components/FileUpload.tsx b/src/components/Main/File/components/FileUpload.tsx index 3f58a20..8b283b0 100644 --- a/src/components/Main/File/components/FileUpload.tsx +++ b/src/components/Main/File/components/FileUpload.tsx @@ -29,10 +29,7 @@ const FileUpload = (props: any) => { const uploadFile = async (options: any) => { const { onSuccess, onError, file }: { onSuccess: any; onError: any; file: any } = options; - if ( - store.getUploadFilePath() === null || - (store.getUploadFileBucket() === null && store.getUploadFileStorage() === null) - ) { + if (store.getUploadFileBucket() === null || store.getUploadFileStorage() === null) { message.open({ content: "请选择存储桶和存储路径", type: "error", diff --git a/src/components/Main/Home/index.tsx b/src/components/Main/Home/index.tsx index 02de0d0..a6e180e 100644 --- a/src/components/Main/Home/index.tsx +++ b/src/components/Main/Home/index.tsx @@ -339,7 +339,7 @@ const MainHome: React.FC = observer(() => { color: "coral", fontWeight: "bolder", }}> - {storageCount} + {storageCount || 0} } /个 @@ -400,7 +400,7 @@ const MainHome: React.FC = observer(() => { color: "lightblue", fontWeight: "bolder", }}> - {bucketCount} + {bucketCount || 0} } /个 @@ -467,7 +467,7 @@ const MainHome: React.FC = observer(() => { color: "orange", marginLeft: 5, }}> - {uploadFile} + {uploadFile || 0} @@ -483,7 +483,7 @@ const MainHome: React.FC = observer(() => { color: "green", marginLeft: 5, }}> - {downloadFile} + {downloadFile || 0} @@ -531,7 +531,7 @@ const MainHome: React.FC = observer(() => { color: "orange", marginLeft: 5, }}> - {uploadFlow} + {uploadFlow || 0} @@ -547,7 +547,7 @@ const MainHome: React.FC = observer(() => { color: "green", marginLeft: 5, }}> - {downloadFlow} + {downloadFlow || 0} diff --git a/src/components/Main/Share/components/ShareAdd/ShareAdd.tsx b/src/components/Main/Share/components/ShareAdd/ShareAdd.tsx index 7e4f8d7..5d062d7 100644 --- a/src/components/Main/Share/components/ShareAdd/ShareAdd.tsx +++ b/src/components/Main/Share/components/ShareAdd/ShareAdd.tsx @@ -31,7 +31,7 @@ import { cyan, generate, green, presetPalettes, red } from "@ant-design/colors"; type Presets = Required["presets"][number]; -const ShareAdd: React.FunctionComponent = observer(() => { +const ShareAdd: React.FunctionComponent = () => { const navigate = useNavigate(); const divRef = useRef(null); const [form] = Form.useForm(); @@ -373,5 +373,5 @@ const ShareAdd: React.FunctionComponent = observer(() => { ); -}); +}; export default observer(ShareAdd); diff --git a/src/components/Main/Share/components/ShareDetail/ShareDetail.tsx b/src/components/Main/Share/components/ShareDetail/ShareDetail.tsx index 039fadc..9fa5760 100644 --- a/src/components/Main/Share/components/ShareDetail/ShareDetail.tsx +++ b/src/components/Main/Share/components/ShareDetail/ShareDetail.tsx @@ -8,6 +8,8 @@ import { HeartOutlined, InfoCircleOutlined, LeftOutlined, + LikeOutlined, + StarOutlined, TagsOutlined, WarningOutlined, } from "@ant-design/icons"; @@ -22,10 +24,10 @@ const { Paragraph } = Typography; import like from "@/assets/icons/like.svg"; import favorite from "@/assets/icons/favorite.svg"; import useStore from "@/utils/store/useStore.tsx"; -import { addLikeDetail, getShareDetail } from "@/api/share"; +import { addLikeDetail, deletedLikeDetail, getShareDetail } from "@/api/share"; import StorageIcon from "@/constant/stroage-icon.ts"; import { observer } from "mobx-react"; -import { addFavorites } from "@/api/user"; +import { addFavorites, deleteFavorites } from "@/api/user"; const ShareDetail: React.FunctionComponent = () => { const navigate = useNavigate(); const store = useStore("share"); @@ -44,18 +46,20 @@ const ShareDetail: React.FunctionComponent = () => { } async function addLike() { const data: any = { + circleId: store.getCircleId(), userId: userId, detailId: params.id, }; addLikeDetail(data).then(); } - // async function delLike() { - // const data: any = { - // userId: userId, - // detailId: params.id, - // }; - // deletedLikeDetail(data).then(); - // } + async function delLike() { + const data: any = { + circleId: store.getCircleId(), + userId: userId, + detailId: params.id, + }; + deletedLikeDetail(data).then(); + } async function setFavorites() { const data: any = { userId: userId, @@ -68,6 +72,7 @@ const ShareDetail: React.FunctionComponent = () => { type: "success", content: "收藏成功", }); + getDetail().then(); } else { message.open({ type: "error", @@ -76,6 +81,27 @@ const ShareDetail: React.FunctionComponent = () => { } }); } + async function cancelFavorites() { + const data: any = { + userId: userId, + detailId: params.id, + circleId: store.getCircleId(), + }; + deleteFavorites(data).then((res: any) => { + if (res && res.success) { + message.open({ + type: "success", + content: "取消成功", + }); + getDetail().then(); + } else { + message.open({ + type: "error", + content: "取消失败", + }); + } + }); + } useEffect(() => { getDetail().then(); @@ -109,7 +135,7 @@ const ShareDetail: React.FunctionComponent = () => { color: "gray", overflow: "hidden", }}> - {detail.nickname} + {detail.nickname || "unknown"} @@ -119,7 +145,7 @@ const ShareDetail: React.FunctionComponent = () => { fontSize: 12, color: "gray", }}> - {detail.likesCount} + {detail.likesCount || 0} @@ -129,7 +155,7 @@ const ShareDetail: React.FunctionComponent = () => { fontSize: 12, color: "gray", }}> - {detail.commentCount} + {detail.commentCount || 0} @@ -139,7 +165,7 @@ const ShareDetail: React.FunctionComponent = () => { fontSize: 12, color: "gray", }}> - {detail.views} + {detail.views || 0} @@ -218,7 +244,7 @@ const ShareDetail: React.FunctionComponent = () => { color: "#1677FF", fontSize: 16, }}> - 百度云 + {url.typeName} { Array.from(detail.tags).map((tag: any, index: number) => { return (
- + {tag.tagName}
@@ -290,21 +316,54 @@ const ShareDetail: React.FunctionComponent = () => { align={"center"} justify={"center"} style={{ height: 50 }}> - { - addLike().then(); - }} - size={"large"}> - {/*isFavor*/} - { - setFavorites().then(); - }} - size={"large"}> + {detail.isLike === true ? ( + <> + + { + delLike().then(); + }} + size={"large"}> + + + ) : ( + <> + + { + addLike().then(); + }}> + + + )} + + {detail.isFavor === true ? ( + <> + + { + cancelFavorites().then(); + }} + size={"large"}> + + + ) : ( + <> + + { + setFavorites().then(); + }} + className={styles.detail_link_btn} + /> + + + )} diff --git a/src/components/Main/Share/components/ShareDetail/components/Comment/index.tsx b/src/components/Main/Share/components/ShareDetail/components/Comment/index.tsx index 15a484b..7148786 100644 --- a/src/components/Main/Share/components/ShareDetail/components/Comment/index.tsx +++ b/src/components/Main/Share/components/ShareDetail/components/Comment/index.tsx @@ -44,33 +44,38 @@ const Comment = observer((props: any) => { const userStore = useStore("user"); const userId: any = userStore.getUserId(); async function listComments() { + setComment([]); listComment(params.id, userId).then((res: any) => { - console.log(res); if (res && res.success && res.data) { - setComment([]); setComment(res.data); setLoading(false); } }); } async function addLike(commentId: any) { + setComment([]); const data: any = { + detailId: params.id, userId: userId, commentId: commentId, }; addLikeComment(data).then(); + listComments().then(); } async function delLike(commentId: any) { + setComment([]); const data: any = { + detailId: params.id, userId: userId, commentId: commentId, }; deletedLikeComment(data).then(); + listComments().then(); } async function getCommentHot() { + setComment([]); listCommentHot(params.id, userId).then((res: any) => { if (res && res.success && res.data) { - setComment([]); setComment(res.data); setLoading(false); } @@ -85,7 +90,7 @@ const Comment = observer((props: any) => { } async function addComments(data: any) { addComment(data).then((res: any) => { - if (res && res.success && res.data) { + if (res && res.success) { message.open({ content: "评论成功", type: "success", @@ -108,7 +113,7 @@ const Comment = observer((props: any) => { } async function addReplies(data: any) { addReply(data).then((res: any) => { - if (res && res.success && res.data) { + if (res && res.success) { message.open({ content: "回复成功", type: "success", @@ -132,7 +137,7 @@ const Comment = observer((props: any) => { setIsReplyComment(isReplyComment === index ? null : index); }; useEffect(() => { - listComments().then(); + getCommentHot().then(); getAllCommentAndReply(params.id).then(); }, []); return ( @@ -264,99 +269,136 @@ const Comment = observer((props: any) => { - + - {item.createdTime} - - - {item.isLike === false ? ( - { - delLike( - item.id, - ).then(); - }} - className={ - styles.like_icon - } - /> - ) : ( - + {item.createdTime} + + + {item.isLike === + true ? ( + { + delLike( + item.id, + ).then(); + }} + style={{ + color: "red", + }} + /> + ) : ( + { + addLike( + item.id, + ).then(); + }} + /> + )} + + {item.likes} + + + + { - addLike( - item.id, - ).then(); - }} - /> - )} - - {item.likes} - - - - { - setReply([]); - if (item.id) { - replyComment( - item.id, - ).then(() => { - handleExpandReplyCommentClick( - index, + setReply([]); + if (item.id) { + replyComment( + item.id, + ).then( + () => { + handleExpandReplyCommentClick( + index, + ); + }, ); - }); + } + }} + className={ + styles.comment_icon } - }} - className={ - styles.comment_icon - } - /> - - {item.replyCount} - + /> + + {item.replyCount} + + + + + - + {item.browser || + "unknown"} + + + {item.browserVersion || + "unknown"} + @@ -573,62 +615,97 @@ const Comment = observer((props: any) => { vertical={ false } - style={{ - marginTop: 10, - width: "100%", - }}> - - { - replyItem.createdTime - } - + align={ + "center" + } + justify={ + "space-between" + }> - {replyItem.isLike === - false ? ( - { - delLike( - replyItem.id, - ).then(); - }} - className={ - styles.like_icon - } - /> - ) : ( - { - addLike( - replyItem.id, - ).then(); - }} - /> - )} + style={{ + marginTop: 10, + width: "100%", + }}> { - replyItem.likes + replyItem.createdTime } + + {replyItem.isLike === + false ? ( + { + addLike( + replyItem.id, + ).then(); + }} + className={ + styles.like_icon + } + /> + ) : ( + { + delLike( + replyItem.id, + ).then(); + }} + /> + )} + + { + replyItem.likes + } + + + + + { align={ "center" }> - + {replyItem.browser || + "unknown"} + + + {replyItem.browserVersion || + "unknown"} + diff --git a/src/components/Main/Share/components/ShareDetail/index.module.less b/src/components/Main/Share/components/ShareDetail/index.module.less index 194b3cf..ec37758 100644 --- a/src/components/Main/Share/components/ShareDetail/index.module.less +++ b/src/components/Main/Share/components/ShareDetail/index.module.less @@ -21,3 +21,10 @@ width: 50px; height: auto; } +.detail_link_btn{ + font-size: 30px; +} +.detail_link_btn:hover{ + font-size: 35px; + color: red; +} diff --git a/src/components/Main/User/MyFavorites/index.tsx b/src/components/Main/User/MyFavorites/index.tsx index ff0e7c7..0be2e91 100644 --- a/src/components/Main/User/MyFavorites/index.tsx +++ b/src/components/Main/User/MyFavorites/index.tsx @@ -1,7 +1,7 @@ /** @format */ import { ProCard } from "@ant-design/pro-components"; -import { Avatar, Button, Flex, Input, List, Skeleton, Tag } from "antd"; +import { Avatar, Button, Empty, Flex, Input, List, Skeleton, Tag } from "antd"; import { useEffect, useState } from "react"; import styles from "./index.module.less"; @@ -25,24 +25,7 @@ export default observer(() => { } }); } - // async function cancelFavorites(id: any) { - // const data: any = { - // id: id, - // }; - // deleteFavorites(data).then((res: any) => { - // if (res && res.success) { - // message.open({ - // type: "success", - // content: "取消成功", - // }); - // } else { - // message.open({ - // type: "error", - // content: "取消失败", - // }); - // } - // }); - // } + useEffect(() => { getMyShare().then(); }, []); @@ -75,110 +58,128 @@ export default observer(() => { - - -

分享列表

- - } - renderItem={(item: any) => ( - - } - title={ - - - {item.title} - - {item.tags && - Array.from(item.tags).map( - (tag: any, index: number) => { - return ( + {data.length === 0 ? ( + + ) : ( + <> + + +

分享列表

+ + } + renderItem={(item: any) => ( + + } + title={ + + + {item.title} + + {item.tags && + Array.from(item.tags).map( + (tag: any, index: number) => { + return ( + + + {tag.tagName} + + + ); + }, + )} + + } + description={ + <> + + {item.description} + - - {tag.tagName} - + align={"center"}> + + + {item.nickname} + - ); - }, - )} - - } - description={ - <> - - {item.description} - - - - - {item.nickname} - + + + + {item.likesCount} + + + + + + {item.commentCount} + + + + {" "} + + {item.views} + + + - - - - {item.likesCount} - - - - - - {item.commentCount} - - - - {" "} - - {item.views} - - - - - - } - /> - - )} - /> -
+ + } + /> +
+ )} + /> +
+ + )}
diff --git a/src/components/Main/User/MyShare/index.tsx b/src/components/Main/User/MyShare/index.tsx index 8e26939..c30c4f6 100644 --- a/src/components/Main/User/MyShare/index.tsx +++ b/src/components/Main/User/MyShare/index.tsx @@ -1,7 +1,7 @@ /** @format */ import { ProCard } from "@ant-design/pro-components"; -import { Avatar, Button, Flex, Input, List, Skeleton, Tag } from "antd"; +import { Avatar, Button, Empty, Flex, Input, List, Skeleton, Tag } from "antd"; import { useEffect, useState } from "react"; import styles from "./index.module.less"; @@ -58,110 +58,128 @@ export default observer(() => { - - -

分享列表

- - } - renderItem={(item: any) => ( - - } - title={ - - - {item.title} - - {item.tags && - Array.from(item.tags).map( - (tag: any, index: number) => { - return ( + {data.length === 0 ? ( + + ) : ( + <> + + +

分享列表

+ + } + renderItem={(item: any) => ( + + } + title={ + + + {item.title} + + {item.tags && + Array.from(item.tags).map( + (tag: any, index: number) => { + return ( + + + {tag.tagName} + + + ); + }, + )} + + } + description={ + <> + + {item.description} + - - {tag.tagName} - + align={"center"}> + + + {item.nickname} + - ); - }, - )} - - } - description={ - <> - - {item.description} - - - - - {item.nickname} - + + + + {item.likesCount} + + + + + + {item.commentCount} + + + + {" "} + + {item.views} + + + - - - - {item.likesCount} - - - - - - {item.commentCount} - - - - {" "} - - {item.views} - - - - - - } - /> - - )} - /> -
+ + } + /> +
+ )} + /> +
+ + )}
diff --git a/src/components/Main/User/UserInfo/index.tsx b/src/components/Main/User/UserInfo/index.tsx index d7579cb..81e1d98 100644 --- a/src/components/Main/User/UserInfo/index.tsx +++ b/src/components/Main/User/UserInfo/index.tsx @@ -1,46 +1,37 @@ /** @format */ import { FunctionComponent, useEffect, useState } from "react"; import { Avatar, Card, Empty, Flex, List, Skeleton } from "antd"; -import { - BankOutlined, - BulbOutlined, - EnvironmentOutlined, -} from "@ant-design/icons"; +import { BankOutlined, BulbOutlined, EnvironmentOutlined } from "@ant-design/icons"; import styles from "./index.module.less"; import { ProCard } from "@ant-design/pro-components"; import Meta from "antd/es/card/Meta"; import { Link, useNavigate } from "react-router-dom"; import { getAllStorage } from "@/api/oss"; import StorageIcon from "@/constant/stroage-icon.ts"; -import { getUserInfoApi } from "@/api/user"; +import { getRecentShare, getUserInfoApi } from "@/api/user"; import useStore from "@/utils/store/useStore.tsx"; import { observer } from "mobx-react"; const UserInfo: FunctionComponent = observer(() => { const navigate = useNavigate(); const [loading, setLoading] = useState(true); + const [loadingStorage, setLoadingStorage] = useState(true); const [userStorage, setUserStorage] = useState([]); + const [recentShare, setRecentShare] = useState([]); const [userInfo, setUserInfo] = useState({} as any); const store = useStore("user"); const userId: any = store.getUserId(); - const data = [ - { - title: "Ant Design Title 1", - }, - { - title: "Ant Design Title 2", - }, - { - title: "Ant Design Title 3", - }, - { - title: "Ant Design Title 4", - }, - ]; async function getUserStorage() { const res: any = await getAllStorage(userId); if (res && res.success && res.data) { setUserStorage(res.data); + setLoadingStorage(false); + } + } + async function getUserRecentShare() { + const res: any = await getRecentShare(userId); + if (res && res.success && res.data) { + setRecentShare(res.data); setLoading(false); } } @@ -53,6 +44,7 @@ const UserInfo: FunctionComponent = observer(() => { useEffect(() => { getUserInfo().then(); getUserStorage().then(); + getUserRecentShare().then(); }, []); return ( <> @@ -79,81 +71,92 @@ const UserInfo: FunctionComponent = observer(() => {
查看更多}> - - {userStorage.map((item: any, index: number) => { - return ( - <> - { - navigate(`/main/setting/${item.ossType}`); - }} - style={{ width: 350, marginTop: 16, marginLeft: 10 }} - hoverable={true}> - } - title={item.name} - description={ - <> - 配置:{item.configCount} - - 存储桶: {item.bucketCount} - - - }> - - - ); - })} - + {userStorage && userStorage.length === 0 ? ( + + ) : ( + <> + + {userStorage.map((item: any, index: number) => { + return ( +
+ { + navigate(`/main/setting/${item.ossType}`); + }} + style={{ + width: 350, + marginTop: 16, + marginLeft: 10, + }} + hoverable={true}> + + } + title={item.name} + description={ + <> + + {" "} + 配置:{item.configCount} + + + 存储桶: {item.bucketCount} + + + }> + +
+ ); + })} +
+ + )}
- - - - - } - title="Card title" - description="This is the description" - /> - - - + {/**/} + {/* */} + {/* */} + {/* */} + {/* }*/} + {/* title="Card title"*/} + {/* description="This is the description"*/} + {/* />*/} + {/* */} + {/* */} + {/**/}
- 查看更多}> - - ( - - - } - title={{item.title}} - description="Ant Design, a design language for background applications, is refined by Ant UED Team" - /> - - )} - /> - + + {recentShare && recentShare.length === 0 ? ( + + ) : ( + + ( + + } + title={item.title} + description={item.date} + /> + + )} + /> + + )} diff --git a/src/components/Main/User/UserSetting/index.tsx b/src/components/Main/User/UserSetting/index.tsx index a752e1b..3876c71 100644 --- a/src/components/Main/User/UserSetting/index.tsx +++ b/src/components/Main/User/UserSetting/index.tsx @@ -33,6 +33,7 @@ const UserSetting: FunctionComponent = observer(() => { const userId: any = store.getUserId(); async function getUserInfo() { getUserInfoApi(userId).then((res: any) => { + console.log(res); if (res && res.success && res.data) { setUserInfo(res.data); setLoading(false); @@ -40,8 +41,8 @@ const UserSetting: FunctionComponent = observer(() => { }); } type FieldType = { - nickname?: string; - location?: string; + nickName?: string; + // location?: string; introduce?: string; gender?: string; company?: string; @@ -64,7 +65,7 @@ const UserSetting: FunctionComponent = observer(() => { } const onFinish: FormProps["onFinish"] = (values) => { const data: any = { - userId: userId, + id: userId, ...values, }; updateUserInfo(data).then((res: any) => { @@ -92,24 +93,22 @@ const UserSetting: FunctionComponent = observer(() => { getUserInfo().then(); }, []); const prefixSelector = ( - - - + ); - const ProFormText = (props: any) => { - return ( - - city} - width="md" - name="location" - disabled={disable}> - - ); - }; + // const ProFormText = (props: any) => { + // return ( + // + // city} + // width="md" + // name="location" + // disabled={disable}> + // + // ); + // }; useEffect(() => {}, []); const TabItems = [ { @@ -142,7 +141,7 @@ const UserSetting: FunctionComponent = observer(() => { {/**/} label="昵称" - name="nickname" + name="nickName" rules={[ { type: "string", @@ -167,12 +166,12 @@ const UserSetting: FunctionComponent = observer(() => { 隐私 - - label="地区" - name="location" - rules={[{ required: true, message: "请输入地区!" }]}> - - + {/**/} + {/* label="地区"*/} + {/* name="location"*/} + {/* rules={[{ required: true, message: "请输入地区!" }]}>*/} + {/* */} + {/**/} label="公司" name="company"> @@ -240,7 +239,7 @@ const UserSetting: FunctionComponent = observer(() => { type="text" onClick={async () => { const data: any = { - userId: userId, + id: userId, password: password, }; await updateUser(data); @@ -264,7 +263,7 @@ const UserSetting: FunctionComponent = observer(() => { type="text" onClick={async () => { const data: any = { - userId: userId, + id: userId, phone: phone, }; await updateUser(data); @@ -288,7 +287,7 @@ const UserSetting: FunctionComponent = observer(() => { type="text" onClick={async () => { const data: any = { - userId: userId, + id: userId, email: email, }; await updateUser(data); @@ -323,14 +322,14 @@ const UserSetting: FunctionComponent = observer(() => { 用户名: - {userInfo.userName} + {userInfo.userName} 账号ID: - {userInfo.id} + {userInfo.id} diff --git a/src/utils/axios/web.ts b/src/utils/axios/web.ts index 31eb0d1..722f78a 100644 --- a/src/utils/axios/web.ts +++ b/src/utils/axios/web.ts @@ -4,7 +4,7 @@ import Request from "./request"; const web: Request = new Request({ baseURL: import.meta.env.VITE_APP_BASE_API, - timeout: 10000, + // timeout: 10000, }); export default web; diff --git a/src/views/Main/index.tsx b/src/views/Main/index.tsx index 6dfcfba..fa0d92c 100644 --- a/src/views/Main/index.tsx +++ b/src/views/Main/index.tsx @@ -16,6 +16,8 @@ import { logout } from "@/api/user"; import { observer } from "mobx-react"; import useStore from "@/utils/store/useStore.tsx"; import { getUserMenuPermission } from "@/api/user"; +import { clearStorage, getStorageFromKey, removeStorageFromKey } from "@/utils/localStorage/config.ts"; +import localforage from "localforage"; const Layout = () => { const location = useLocation(); @@ -75,7 +77,14 @@ const Layout = () => { label: "退出登录", onClick: () => { logout(store.getUserId()); - navigate("/login"); + clearStorage(); + store.setToken(""); + store.setUserId(""); + store.setAvatar(""); + store.setNickName(""); + setTimeout(() => { + navigate("/login"); + }, 1000); }, }, ], diff --git a/src/views/User/Forget/index.tsx b/src/views/User/Forget/index.tsx index 619366e..e0ce714 100644 --- a/src/views/User/Forget/index.tsx +++ b/src/views/User/Forget/index.tsx @@ -1,375 +1,373 @@ -/** @format */ - -import { LockOutlined, MobileOutlined, SafetyOutlined, WechatOutlined } from "@ant-design/icons"; -import { CaptFieldRef, ProFormCaptcha, ProFormText } from "@ant-design/pro-components"; -import { Alert, Button, ConfigProvider, Form, Image, message, Space, Spin, Tabs } from "antd"; -import { useEffect, useRef, useState } from "react"; -import { TinyColor } from "@ctrl/tinycolor"; -import logo from "@/assets/images/logo.png"; -import styles from "./index.module.less"; -import { observer } from "mobx-react"; -import FooterComponent from "@/components/Footer"; -import { createClientId, findPassword, generateQRCode, getClientToken, getSms } from "@/api/user"; -import RotateCaptcha, { CaptchaInstance, type TicketInfoType } from "react-rotate-captcha"; -import { get, load } from "@/api/captcha"; -import { useNavigate } from "react-router-dom"; -import useStore from "@/utils/store/useStore.tsx"; -import { setStorage } from "@/utils/localStorage/config.ts"; -import { TimerManager } from "timer-manager-lib"; - -type LoginType = "phone"; - -export default observer(() => { - const [form] = Form.useForm(); - const captchaRef = useRef(); - const smsCaptcha = useRef(null); - const findPasswordCaptcha = useRef(null); - const [loginType, setLoginType] = useState("phone"); - const colors = ["#fc6076", "#ff9a44", "#ef9d43", "#e75516"]; - const [QRCode, setQRCode] = useState(""); - const navigate = useNavigate(); - const store = useStore("user"); - const timerManager = new TimerManager(); - const [loading, setLoading] = useState(true); - - const getHoverColors = (colors: string[]) => - colors.map((color) => new TinyColor(color).lighten(5).toString()); - const getActiveColors = (colors: string[]) => - colors.map((color) => new TinyColor(color).darken(5).toString()); - - async function smsVerify(token: string, deg: number): Promise { - const phone = form.getFieldValue("phone"); - const data: any = { - token: token, - deg: deg, - phone: phone, - }; - const res: any = await getSms(data); - if (res && res.code === 0) { - message.open({ - content: res.data, - type: "success", - duration: 5, - }); - } else { - message.open({ - content: res.data, - type: "warning", - duration: 5, - }); - } - return res; - } - - async function findPasswordVerify(token: string, deg: number): Promise { - const mobile = form.getFieldValue("phone"); - const captcha = form.getFieldValue("activeCode"); - const password = form.getFieldValue("password"); - const confirmPassword = form.getFieldValue("confirmPassword"); - - const data: API.findPasswordRequest = { - token: token, - deg: deg, - phone: mobile, - activeCode: captcha, - password: password, - confirmPassword: confirmPassword, - }; - const res: any = await findPassword(data); - if (res && res.success && res.code === 0) { - message.open({ - content: res.data, - type: "success", - duration: 5, - }); - } else if (res.code === 0 && !res.success) { - message.open({ - content: res.data, - type: "error", - duration: 5, - }); - } - return res; - } - - async function openSmsCaptcha() { - smsCaptcha.current!.open(); - } - - async function fopenFindPasswordCaptcha() { - findPasswordCaptcha.current!.open(); - } - - const items = [ - { - key: "phone", - label: ( - - - 重置密码 - - ), - }, - ]; - - async function wechatLogin() { - createClientId().then((res: any) => { - generateQRCode(res.data).then((response: any) => { - if (response.success) { - setQRCode(response.data.qrCodeUrl); - setLoading(false); - timerManager.add(() => { - getClientToken(res.data).then((result: any) => { - if (result.success) { - timerManager.clear(); - store.setToken(result.data.tokenValue); - store.setUserId(result.data.loginId); - setStorage("token", result.data.tokenValue, 24 * 60 * 30); - setStorage("userId", result.data.loginId, 24 * 60 * 30); - message - .open({ - content: "登录成功!", - type: "success", - }) - .then(); - if (store.getToken() !== null || store.getUserId() !== null) { - setTimeout(() => { - navigate("/main"); - }, 2000); - } - } - }); - }, 3000); - } else { - message - .open({ - content: response.data, - type: "error", - }) - .then(); - } - }); - }); - } - - useEffect(() => { - wechatLogin().then(); - }, []); - - return ( -
- - -
- - - - - 微信扫码登录 - - - - 微信扫码关注公众号)} - description={ -
- - 微信扫码 - 关注公众号 - -
- 登录更快更安全 -
- } - // type="success" - showIcon={true} - className={styles.alert} - icon={} - /> -
-
-
- - - logo - 五味子云存储 - -
随时随地分享你的美好瞬间
-
- - - setLoginType(activeKey as LoginType) - }> - - <> - , - autoComplete: "off", - }} - name="phone" - placeholder="请输入手机号" - rules={[ - { - required: true, - message: "请输入手机号!", - }, - { - pattern: /^1\d{10}$/, - message: "手机号格式错误!", - }, - ]} - /> - - , - }} - captchaProps={{ - size: "large", - }} - placeholder={"请输入验证码"} - captchaTextRender={(timing: boolean, count: number) => { - if (timing) { - return `${count} ${"获取验证码"}`; - // return `${"获取验证码"}`; - } - return "获取验证码"; - }} - name="activeCode" - phoneName={"phone"} - countDown={60} - rules={[ - { - required: true, - message: "请输入验证码!", - }, - ]} - fieldRef={captchaRef} - onGetCaptcha={async () => { - await openSmsCaptcha(); - }} - /> - - , - }} - placeholder="请输入新密码" - rules={[ - { - required: true, - message: "请输入新密码!", - }, - { - pattern: - /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z\\W]{6,18}$/, - message: - "密码长度需在6~18位字符,且必须包含字母和数字!", - }, - ]} - /> - - , - }} - placeholder="请再次确认密码" - rules={[ - { - required: true, - message: "请再次确认密码!", - }, - ({ getFieldValue }) => ({ - validator(_, value) { - if (!value || getFieldValue("password") === value) { - return Promise.resolve(); - } - return Promise.reject( - new Error("两次输入的密码不一致!"), - ); - }, - }), - ]} - /> - - - - - - - 登录 - -
-
-
- -
- ); -}); +/** @format */ + +import { LockOutlined, MobileOutlined, SafetyOutlined, WechatOutlined } from "@ant-design/icons"; +import { CaptFieldRef, ProFormCaptcha, ProFormText } from "@ant-design/pro-components"; +import { Alert, Button, ConfigProvider, Form, Image, message, Space, Spin, Tabs } from "antd"; +import { useEffect, useRef, useState } from "react"; +import { TinyColor } from "@ctrl/tinycolor"; +import logo from "@/assets/images/logo.png"; +import styles from "./index.module.less"; +import { observer } from "mobx-react"; +import FooterComponent from "@/components/Footer"; +import { createClientId, findPassword, generateQRCode, getClientToken, getSms } from "@/api/user"; +import RotateCaptcha, { CaptchaInstance, type TicketInfoType } from "react-rotate-captcha"; +import { get, load } from "@/api/captcha"; +import { useNavigate } from "react-router-dom"; +import useStore from "@/utils/store/useStore.tsx"; +import { setStorage } from "@/utils/localStorage/config.ts"; +import { TimerManager } from "timer-manager-lib"; + +type LoginType = "phone"; + +export default observer(() => { + const [form] = Form.useForm(); + const captchaRef = useRef(); + const smsCaptcha = useRef(null); + const findPasswordCaptcha = useRef(null); + const [loginType, setLoginType] = useState("phone"); + const colors = ["#fc6076", "#ff9a44", "#ef9d43", "#e75516"]; + const [QRCode, setQRCode] = useState(""); + const navigate = useNavigate(); + const store = useStore("user"); + const timerManager = new TimerManager(); + const [loading, setLoading] = useState(true); + + const getHoverColors = (colors: string[]) => + colors.map((color) => new TinyColor(color).lighten(5).toString()); + const getActiveColors = (colors: string[]) => + colors.map((color) => new TinyColor(color).darken(5).toString()); + + async function smsVerify(token: string, deg: number): Promise { + const phone = form.getFieldValue("phone"); + const data: any = { + token: token, + deg: deg, + phone: phone, + }; + const res: any = await getSms(data); + if (res && res.code === 0) { + message.open({ + content: res.data, + type: "success", + duration: 5, + }); + } else { + message.open({ + content: res.data, + type: "warning", + duration: 5, + }); + } + return res; + } + + async function findPasswordVerify(token: string, deg: number): Promise { + const mobile = form.getFieldValue("phone"); + const captcha = form.getFieldValue("activeCode"); + const password = form.getFieldValue("password"); + const confirmPassword = form.getFieldValue("confirmPassword"); + + const data: API.findPasswordRequest = { + token: token, + deg: deg, + phone: mobile, + activeCode: captcha, + password: password, + confirmPassword: confirmPassword, + }; + const res: any = await findPassword(data); + if (res && res.success && res.code === 0) { + message.open({ + content: res.data, + type: "success", + duration: 5, + }); + } else if (res.code === 0 && !res.success) { + message.open({ + content: res.data, + type: "error", + duration: 5, + }); + } + return res; + } + + async function openSmsCaptcha() { + smsCaptcha.current!.open(); + } + + async function fopenFindPasswordCaptcha() { + findPasswordCaptcha.current!.open(); + } + + const items = [ + { + key: "phone", + label: ( + + + 重置密码 + + ), + }, + ]; + + async function wechatLogin() { + createClientId().then((res: any) => { + generateQRCode(res.data).then((response: any) => { + if (res && response.success && res.data) { + setQRCode(response.data.qrCodeUrl); + setLoading(false); + timerManager.add(() => { + getClientToken(res.data).then((result: any) => { + if (result.success) { + timerManager.clear(); + store.setToken(result.data.tokenValue); + store.setUserId(result.data.loginId); + setStorage("token", result.data.tokenValue, 24 * 60 * 30); + setStorage("userId", result.data.loginId, 24 * 60 * 30); + message + .open({ + content: "登录成功!", + type: "success", + }) + .then(); + if (store.getToken() !== null || store.getUserId() !== null) { + setTimeout(() => { + navigate("/main"); + }, 2000); + } + } + }); + }, 3000); + } else { + message + .open({ + content: response.data, + type: "error", + }) + .then(); + } + }); + }); + } + + useEffect(() => { + wechatLogin().then(); + }, []); + + return ( +
+ + +
+ + + + + 微信扫码登录 + + + + 微信扫码关注公众号)} + description={ +
+ + 微信扫码 + 关注公众号 + +
+ 登录更快更安全 +
+ } + // type="success" + showIcon={true} + className={styles.alert} + icon={} + /> +
+
+
+ + + logo + 五味子云存储 + +
随时随地分享你的美好瞬间
+
+ + + setLoginType(activeKey as LoginType) + }> + + <> + , + autoComplete: "off", + }} + name="phone" + placeholder="请输入手机号" + rules={[ + { + required: true, + message: "请输入手机号!", + }, + { + pattern: /^1\d{10}$/, + message: "手机号格式错误!", + }, + ]} + /> + + , + }} + captchaProps={{ + size: "large", + }} + placeholder={"请输入验证码"} + captchaTextRender={(timing: boolean, count: number) => { + if (timing) { + return `${count} ${"获取验证码"}`; + // return `${"获取验证码"}`; + } + return "获取验证码"; + }} + name="activeCode" + phoneName={"phone"} + countDown={60} + rules={[ + { + required: true, + message: "请输入验证码!", + }, + ]} + fieldRef={captchaRef} + onGetCaptcha={async () => { + await openSmsCaptcha(); + }} + /> + + , + }} + placeholder="请输入新密码" + rules={[ + { + required: true, + message: "请输入新密码!", + }, + { + pattern: + /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z\\W]{6,18}$/, + message: + "密码长度需在6~18位字符,且必须包含字母和数字!", + }, + ]} + /> + + , + }} + placeholder="请再次确认密码" + rules={[ + { + required: true, + message: "请再次确认密码!", + }, + ({ getFieldValue }) => ({ + validator(_, value) { + if (!value || getFieldValue("password") === value) { + return Promise.resolve(); + } + return Promise.reject( + new Error("两次输入的密码不一致!"), + ); + }, + }), + ]} + /> + + + + + + + 登录 + +
+
+
+ +
+ ); +}); diff --git a/src/views/User/Login/index.tsx b/src/views/User/Login/index.tsx index 46c7219..0f74fc9 100644 --- a/src/views/User/Login/index.tsx +++ b/src/views/User/Login/index.tsx @@ -120,6 +120,7 @@ export default observer(() => { store.setAvatar(res.data.user.avatar); store.setNickName(res.data.user.nickName); setStorage("token", res.data.token, 24 * 60 * 30); + setStorage("userId", res.data.user.id, 24 * 60 * 30); if (store.getToken() !== null || store.getUserId() !== null) { setTimeout(() => { navigate("/main/home"); @@ -154,6 +155,7 @@ export default observer(() => { store.setToken(res.data.token); store.setUserId(res.data.user.id); setStorage("token", res.data.token, 24 * 60 * 30); + setStorage("userId", res.data.user.id, 24 * 60 * 30); if (store.getToken() !== null || store.getUserId() !== null) { setTimeout(() => { navigate("/main"); @@ -217,7 +219,7 @@ export default observer(() => { async function wechatLogin() { createClientId().then((res: any) => { generateQRCode(res.data).then((response: any) => { - if (response.success) { + if (res && response.success && res.data) { setQRCode(response.data.qrCodeUrl); setLoading(false); timerManager.add(() => { @@ -289,7 +291,6 @@ export default observer(() => { className={styles.mp_code_img} // src={generateMpRegCodeData.data?.qrCodeUrl} src={QRCode} - fallback="" /> { - const [form] = Form.useForm(); - const registerCaptcha = useRef(null); - const smsCaptcha = useRef(null); - const captchaRef = useRef(); - const [QRCode, setQRCode] = useState(""); - const navigate = useNavigate(); - const store = useStore("user"); - const colors = ["#6253E1", "#04BEFE"]; - const timerManager = new TimerManager(); - const [loading, setLoading] = useState(true); - - const getHoverColors = (colors: string[]) => - colors.map((color) => new TinyColor(color).lighten(5).toString()); - const getActiveColors = (colors: string[]) => - colors.map((color) => new TinyColor(color).darken(5).toString()); - - const items = [ - { - key: "phone", - label: ( - - - 手机号注册 - - ), - }, - ]; - const [loginType, setLoginType] = useState("phone"); - - async function smsVerify(token: string, deg: number): Promise { - const phone = form.getFieldValue("phone"); - const data: any = { - token: token, - deg: deg, - phone: phone, - }; - const res: any = await getSms(data); - if (res && res.code === 0) { - message.open({ - content: res.data, - type: "success", - duration: 5, - }); - } else { - message.open({ - content: res.data, - type: "warning", - duration: 5, - }); - } - return res; - } - - async function openRegisterCaptcha() { - registerCaptcha.current!.open(); - } - - async function openSmsCaptcha() { - smsCaptcha.current!.open(); - } - - async function registerVerify(token: string, deg: number): Promise { - const userName = form.getFieldValue("username"); - const password = form.getFieldValue("password"); - const phone = form.getFieldValue("phone"); - const activeCode = form.getFieldValue("activeCode"); - const data: any = { - token: token, - deg: deg, - userName: userName, - password: password, - phone: phone, - activeCode: activeCode, - }; - const res: any = await register(data); - if (res && res.success && res.code === 0) { - message - .open({ - content: res.data, - type: "success", - duration: 5, - }) - .then(() => { - navigate("/login"); - }); - } else if (res.code === 0 && !res.success) { - message.open({ - content: res.data, - type: "error", - duration: 5, - }); - } - return res; - } - - async function wechatLogin() { - createClientId().then((res: any) => { - generateQRCode(res.data).then((response: any) => { - if (response.success) { - setQRCode(response.data.qrCodeUrl); - setLoading(false); - timerManager.add(() => { - getClientToken(res.data).then((result: any) => { - if (result.success) { - timerManager.clear(); - store.setToken(result.data.tokenValue); - store.setUserId(result.data.loginId); - setStorage("token", result.data.tokenValue, 24 * 60 * 30); - setStorage("userId", result.data.loginId, 24 * 60 * 30); - message - .open({ - content: "登录成功!", - type: "success", - }) - .then(); - if (store.getToken() !== null || store.getUserId() !== null) { - setTimeout(() => { - navigate("/main"); - }, 2000); - } - } - }); - }, 3000); - } else { - message - .open({ - content: response.data, - type: "error", - }) - .then(); - } - }); - }); - } - - useEffect(() => { - wechatLogin().then(); - }, []); - - return ( -
- - -
- - - - - 微信扫码登录 - - - - 微信扫码关注公众号)} - description={ -
- - 微信扫码 - 关注公众号 - -
- 登录更快更安全 -
- } - // type="success" - showIcon={true} - className={styles.alert} - icon={} - /> -
-
-
- - - logo - 五味子云存储 - -
随时随地分享你的美好瞬间
-
- - - setLoginType(activeKey as LoginType) - }> - - <> - , - autoComplete: "off", - }} - name="username" - placeholder="请输入用户名" - rules={[ - { - required: true, - message: "请输入用户名!", - }, - { - pattern: /^[a-zA-Z0-9_-]{3,16}$/, - message: - "用户名只能是3到16位(字母,数字,下划线,减号)", - }, - ]} - /> - - , - autoComplete: "off", - }} - name="phone" - placeholder="请输入手机号" - rules={[ - { - required: true, - message: "请输入手机号!", - }, - { - pattern: /^1\d{10}$/, - message: "手机号格式错误!", - }, - ]} - /> - - , - }} - captchaProps={{ - size: "large", - }} - placeholder={"请输入验证码"} - captchaTextRender={(timing: boolean, count: number) => { - if (timing) { - return `${count} ${"获取验证码"}`; - // return `${"获取验证码"}`; - } - return "获取验证码"; - }} - name="activeCode" - phoneName={"phone"} - countDown={60} - rules={[ - { - required: true, - message: "请输入验证码!", - }, - ]} - fieldRef={captchaRef} - onGetCaptcha={async () => { - await openSmsCaptcha(); - }} - /> - - , - }} - placeholder="请输入密码" - rules={[ - { - required: true, - message: "请输入密码!", - }, - { - pattern: - /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z\\W]{6,18}$/, - message: - "密码长度需在6~18位字符,且必须包含字母和数字!", - }, - ]} - /> - - , - }} - placeholder="请再次确认密码" - rules={[ - { - required: true, - message: "请再次确认密码!", - }, - ({ getFieldValue }) => ({ - validator(_, value) { - if (!value || getFieldValue("password") === value) { - return Promise.resolve(); - } - return Promise.reject( - new Error("两次输入的密码不一致!"), - ); - }, - }), - ]} - /> - - - - - - - 登录 - -
-
-
- -
- ); -}); +/** @format */ + +import { + LockOutlined, + MobileOutlined, + SafetyOutlined, + UserOutlined, + WechatOutlined, +} from "@ant-design/icons"; +import { CaptFieldRef, ProFormCaptcha, ProFormText } from "@ant-design/pro-components"; +import { Alert, Button, ConfigProvider, Form, Image, message, Space, Spin, Tabs } from "antd"; +import { useEffect, useRef, useState } from "react"; +import logo from "@/assets/images/logo.png"; +// import background from '@/assets/images/background.png' +import styles from "./index.module.less"; +import { observer } from "mobx-react"; +import FooterComponent from "@/components/Footer"; +import { createClientId, generateQRCode, getClientToken, getSms, register } from "@/api/user"; +import { TinyColor } from "@ctrl/tinycolor"; +import { get, load } from "@/api/captcha"; +import RotateCaptcha, { CaptchaInstance, type TicketInfoType } from "react-rotate-captcha"; +import { useNavigate } from "react-router-dom"; +import { setStorage } from "@/utils/localStorage/config.ts"; +import useStore from "@/utils/store/useStore.tsx"; +import { TimerManager } from "timer-manager-lib"; +// import useStore from '@/utils/store/useStore.tsx' +type LoginType = "phone"; + +export default observer(() => { + const [form] = Form.useForm(); + const registerCaptcha = useRef(null); + const smsCaptcha = useRef(null); + const captchaRef = useRef(); + const [QRCode, setQRCode] = useState(""); + const navigate = useNavigate(); + const store = useStore("user"); + const colors = ["#6253E1", "#04BEFE"]; + const timerManager = new TimerManager(); + const [loading, setLoading] = useState(true); + + const getHoverColors = (colors: string[]) => + colors.map((color) => new TinyColor(color).lighten(5).toString()); + const getActiveColors = (colors: string[]) => + colors.map((color) => new TinyColor(color).darken(5).toString()); + + const items = [ + { + key: "phone", + label: ( + + + 手机号注册 + + ), + }, + ]; + const [loginType, setLoginType] = useState("phone"); + + async function smsVerify(token: string, deg: number): Promise { + const phone = form.getFieldValue("phone"); + const data: any = { + token: token, + deg: deg, + phone: phone, + }; + const res: any = await getSms(data); + if (res && res.code === 0) { + message.open({ + content: res.data, + type: "success", + duration: 5, + }); + } else { + message.open({ + content: res.data, + type: "warning", + duration: 5, + }); + } + return res; + } + + async function openRegisterCaptcha() { + registerCaptcha.current!.open(); + } + + async function openSmsCaptcha() { + smsCaptcha.current!.open(); + } + + async function registerVerify(token: string, deg: number): Promise { + const userName = form.getFieldValue("username"); + const password = form.getFieldValue("password"); + const phone = form.getFieldValue("phone"); + const activeCode = form.getFieldValue("activeCode"); + const data: any = { + token: token, + deg: deg, + userName: userName, + password: password, + phone: phone, + activeCode: activeCode, + }; + const res: any = await register(data); + if (res && res.success && res.code === 0) { + message + .open({ + content: res.data, + type: "success", + duration: 5, + }) + .then(() => { + navigate("/login"); + }); + } else if (res.code === 0 && !res.success) { + message.open({ + content: res.data, + type: "error", + duration: 5, + }); + } + return res; + } + + async function wechatLogin() { + createClientId().then((res: any) => { + generateQRCode(res.data).then((response: any) => { + if (res && response.success && res.data) { + setQRCode(response.data.qrCodeUrl); + setLoading(false); + timerManager.add(() => { + getClientToken(res.data).then((result: any) => { + if (result.success) { + timerManager.clear(); + store.setToken(result.data.tokenValue); + store.setUserId(result.data.loginId); + setStorage("token", result.data.tokenValue, 24 * 60 * 30); + setStorage("userId", result.data.loginId, 24 * 60 * 30); + message + .open({ + content: "登录成功!", + type: "success", + }) + .then(); + if (store.getToken() !== null || store.getUserId() !== null) { + setTimeout(() => { + navigate("/main"); + }, 2000); + } + } + }); + }, 3000); + } else { + message + .open({ + content: response.data, + type: "error", + }) + .then(); + } + }); + }); + } + + useEffect(() => { + wechatLogin().then(); + }, []); + + return ( +
+ + +
+ + + + + 微信扫码登录 + + + + 微信扫码关注公众号)} + description={ +
+ + 微信扫码 + 关注公众号 + +
+ 登录更快更安全 +
+ } + // type="success" + showIcon={true} + className={styles.alert} + icon={} + /> +
+
+
+ + + logo + 五味子云存储 + +
随时随地分享你的美好瞬间
+
+ + + setLoginType(activeKey as LoginType) + }> + + <> + , + autoComplete: "off", + }} + name="username" + placeholder="请输入用户名" + rules={[ + { + required: true, + message: "请输入用户名!", + }, + { + pattern: /^[a-zA-Z0-9_-]{3,16}$/, + message: + "用户名只能是3到16位(字母,数字,下划线,减号)", + }, + ]} + /> + + , + autoComplete: "off", + }} + name="phone" + placeholder="请输入手机号" + rules={[ + { + required: true, + message: "请输入手机号!", + }, + { + pattern: /^1\d{10}$/, + message: "手机号格式错误!", + }, + ]} + /> + + , + }} + captchaProps={{ + size: "large", + }} + placeholder={"请输入验证码"} + captchaTextRender={(timing: boolean, count: number) => { + if (timing) { + return `${count} ${"获取验证码"}`; + // return `${"获取验证码"}`; + } + return "获取验证码"; + }} + name="activeCode" + phoneName={"phone"} + countDown={60} + rules={[ + { + required: true, + message: "请输入验证码!", + }, + ]} + fieldRef={captchaRef} + onGetCaptcha={async () => { + await openSmsCaptcha(); + }} + /> + + , + }} + placeholder="请输入密码" + rules={[ + { + required: true, + message: "请输入密码!", + }, + { + pattern: + /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z\\W]{6,18}$/, + message: + "密码长度需在6~18位字符,且必须包含字母和数字!", + }, + ]} + /> + + , + }} + placeholder="请再次确认密码" + rules={[ + { + required: true, + message: "请再次确认密码!", + }, + ({ getFieldValue }) => ({ + validator(_, value) { + if (!value || getFieldValue("password") === value) { + return Promise.resolve(); + } + return Promise.reject( + new Error("两次输入的密码不一致!"), + ); + }, + }), + ]} + /> + + + + + + + 登录 + +
+
+
+ +
+ ); +});