diff --git a/apis/auth.ts b/apis/auth.ts index ee9285f..6ea332d 100644 --- a/apis/auth.ts +++ b/apis/auth.ts @@ -79,3 +79,18 @@ export const getCenterList = async () => { throw error; } }; + +interface IdCheckResponseBody { + timestamp: string; + status: number; + error: string; + code: string; + message: string; +} + +async function postIdCheck(loginId: string): Promise { + const { data } = await client.post(`/users/loginId`, { loginId }); + return data; +} + +export { postIdCheck }; diff --git a/apis/hooks/auth.ts b/apis/hooks/auth.ts index a88caf8..21908f5 100644 --- a/apis/hooks/auth.ts +++ b/apis/hooks/auth.ts @@ -1,6 +1,7 @@ import { useQuery, useMutation } from "@tanstack/react-query"; -import { SignUp, getCenterList, userProps } from "../auth"; +import { SignUp, getCenterList, postIdCheck, userProps } from "../auth"; import { useRouter } from "next/router"; +import { InputError } from "@/pages/mypage/password"; function useGetCenterList() { const { data } = useQuery({ @@ -28,4 +29,20 @@ function useSignUp(userData: userProps) { return { mutate }; } -export { useGetCenterList, useSignUp }; +function usePostIdCheck( + loginId: string, + setIdError: React.Dispatch>, +) { + const { mutate } = useMutation({ + mutationKey: ["postIdCheck", loginId], + mutationFn: () => postIdCheck(loginId), + onSuccess: () => setIdError({ status: false, text: "" }), + onError: () => { + setIdError({ status: true, text: "이미 사용 중인 아이디입니다." }); + }, + }); + + return { mutate }; +} + +export { useGetCenterList, useSignUp, usePostIdCheck }; diff --git a/components/auth/AuthInput.tsx b/components/auth/AuthInput.tsx index 95cbe99..112401c 100644 --- a/components/auth/AuthInput.tsx +++ b/components/auth/AuthInput.tsx @@ -10,6 +10,7 @@ export interface TextInputProps { name: string; onChange: (e: ChangeEvent) => void; maxLength?: number; + isSuccess?: boolean; } const AuthInput = forwardRef( @@ -24,20 +25,23 @@ const AuthInput = forwardRef( name, onChange, maxLength = 10, + isSuccess = false, }, ref, ) => { + const borderStyle = () => { + if (isSuccess) return "border-green-600"; + else if (isError) return "border-red-500"; + return "border-solid"; + }; + return (
-
+
( />
{isError && ( -
{errorText}
+
{errorText}
)}
); diff --git a/pages/signup.tsx b/pages/signup.tsx index 72f16d1..6ec49c3 100644 --- a/pages/signup.tsx +++ b/pages/signup.tsx @@ -1,5 +1,5 @@ import { centerProps, userProps } from "@/apis/auth"; -import { useGetCenterList, useSignUp } from "@/apis/hooks/auth"; +import { useGetCenterList, usePostIdCheck, useSignUp } from "@/apis/hooks/auth"; import Button from "@/components/Button"; import HeadFunction from "@/components/HeadFunction"; import AuthInput from "@/components/auth/AuthInput"; @@ -12,6 +12,7 @@ import CheckIcon from "@/public/svgs/Check.svg"; import FlexBox from "@/components/Flexbox"; import { usePostNicknameCheck } from "@/apis/hooks/mypage"; import { InputError } from "./mypage/password"; +import NicknameInput from "@/components/mypage/NicknameInput"; const SignUp: NextPage = () => { //input용 @@ -49,6 +50,8 @@ const SignUp: NextPage = () => { const { mutate: signUpMutate } = useSignUp(userInfo); //중복 확인 + //닉네임 중복 + const [tempName, setTempName] = useState(""); const [nameError, setNameError] = useState({ status: false, text: "", @@ -58,7 +61,6 @@ const SignUp: NextPage = () => { if (checkNicknameValidity()) nameCheckMutate(); }; - const [tempName, setTempName] = useState(""); const checkNicknameValidity = () => { setTempName(userInfo.nickname); if (userInfo.nickname.length > 8) { @@ -86,100 +88,167 @@ const SignUp: NextPage = () => { setNameError, ); + //아이디 중복 + const [tempId, setTempId] = useState(""); + const [idError, setIdError] = useState({ + status: false, + text: "", + }); + + const checkIdValidity = () => { + setTempId(userInfo.loginId); + if (userInfo.loginId.length > 16) { + setIdError({ + status: true, + text: "아이디 최대 길이는 16자입니다.", + }); + return false; + } + + const regex = /^[a-zA-Z0-9\s]*$/; + if (!regex.test(userInfo.loginId)) { + setIdError({ + status: true, + text: "아이디는 영어, 숫자로만 구성할 수 있습니다.", + }); + return false; + } + + return true; + }; + + const { mutate: idCheckMutate } = usePostIdCheck( + userInfo.loginId, + setIdError, + ); + + const onClickIdBtn = () => { + if (checkIdValidity()) idCheckMutate(); + }; + return ( -
+
-
- +
+
+ + + + + + +
+ +
+ - - {/* */} - - - - - +
- - +
+ + + + + + +
+ +
+ - {/* */} - - - - - +
- - {data && ( - - )} +
+ + {data && ( + + )} +