Signup.js 10.8 KB
Newer Older
한규민's avatar
한규민 committed
1
import styles from "./signup.module.scss";
한규민's avatar
한규민 committed
2
import { useState } from "react";
한규민's avatar
한규민 committed
3
import authApi from "../../apis/auth.api.js";
한규민's avatar
한규민 committed
4
import { Redirect } from "react-router-dom";
한규민's avatar
한규민 committed
5
import catchErrors from "../../utils/catchErrors.js";
한규민's avatar
한규민 committed
6
7

const Signup = () => {
한규민's avatar
한규민 committed
8
    //회원정보
한규민's avatar
한규민 committed
9
    const [user, setUser] = useState({
한규민's avatar
한규민 committed
10
        userId: "",
11
        userName:"",
한규민's avatar
한규민 committed
12
        userEmail: "",
한규민's avatar
한규민 committed
13
14
15
16
17
        userNickName: "",
        userBirthday: "",
        userMbnum: "",
        userPassword: "",
        userRePassword: ""
18
    })
19
    const [startTime, setStartTime] = useState("");
한규민's avatar
한규민 committed
20
    const [number, setNumber] = useState(null);
한규민's avatar
한규민 committed
21
22
    const [loading, setLoading] = useState(false);
    const [success, setSuccess] = useState(false);
한규민's avatar
한규민 committed
23
    //각 타입별 error 유무 state
한규민's avatar
한규민 committed
24
    const [mbError,setMbError] = useState(false);
한규민's avatar
한규민 committed
25
    const [error, setError] = useState("");
한규민's avatar
한규민 committed
26
    const [errorMsg, setErrorMsg] = useState({
한규민's avatar
한규민 committed
27
        errorId: false,
28
        errorName: false,
한규민's avatar
한규민 committed
29
        errorEmail: false,
한규민's avatar
한규민 committed
30
        errorNickName: false,
한규민's avatar
한규민 committed
31
32
33
34
        errorBirthday: false,
        errorMbnum: false,
        errorPassword: false,
    })
한규민's avatar
한규민 committed
35
    const [confirmMb, setConfirmMb] = useState(false);
한규민's avatar
한규민 committed
36
37

    //입력할때마다 state에 저장
38
    const handleUserOnChange = (e) => {
한규민's avatar
한규민 committed
39
40
        setUser({
            ...user,
41
42
            [e.target.name]: e.target.value
        })
한규민's avatar
한규민 committed
43
        if (e.target.name === "userBirthday" || e.target.name === "userMbum") {
한규민's avatar
한규민 committed
44
45
46
47
48
            setUser({
                ...user,
                [e.target.name]: String(e.target.value)
            })
        }
한규민's avatar
한규민 committed
49
    }
한규민's avatar
한규민 committed
50
    //인증번호 보내기
한규민's avatar
한규민 committed
51
    const handleOnClickMbnum = async (e) => {
한규민's avatar
한규민 committed
52
        e.preventDefault();
한규민's avatar
한규민 committed
53
        try {
54
            setStartTime("");
한규민's avatar
한규민 committed
55
56
57
58
59
60
            setError("");
            setLoading(true)
            const phone = user.userMbnum;
            const message = await authApi.confirmMbnum(phone);
            if(message.isSuccess){
            setMbError("보냄");
61
            setStartTime(message.startTime);
한규민's avatar
한규민 committed
62
            }
한규민's avatar
한규민 committed
63
        } catch (error) {
한규민's avatar
한규민 committed
64
65
66
67
68
            console.log('error'+ error)
        }finally {
            setLoading(false);
        }
    }
한규민's avatar
한규민 committed
69
    //인증번호 입력
한규민's avatar
한규민 committed
70
71
72
    const handleOnChangeMb = (e) => {
        setNumber(String(e.target.value));
    }
한규민's avatar
한규민 committed
73
    //인증번호 검증
한규민's avatar
한규민 committed
74
75
76
77
    const handleOnClickMbConfirm = async (e) => {
        e.preventDefault();
        try {
            setError("");
78
79
            setLoading(true);
            const confirmNum = {userMbnum : user.userMbnum, number : number, startTime : startTime};
한규민's avatar
한규민 committed
80
81
82
83
84
85
86
87
88
89
            const message = await authApi.confirmNum(confirmNum);
            setMbError(message);
            if(message === "성공"){
                setConfirmMb(true);
                console.log("인증완료");
            }
        } catch (error) {
            catchErrors(error, setError);
        }finally {
            setLoading(false);
한규민's avatar
한규민 committed
90
        }
한규민's avatar
한규민 committed
91
    }
한규민's avatar
한규민 committed
92
    //비밀번호일치 여부만 클라이언트에서 확인
한규민's avatar
한규민 committed
93
94
95
96
97
    const validationPw = () => {
        if(user.userPassword !== user.userRePassword){
            return false;
        }else{return true;}
    }
한규민's avatar
한규민 committed
98
    //서버로 전송
한규민's avatar
한규민 committed
99
100
101
    const handleOnSummit = async (e) => {
        e.preventDefault();
        try {
한규민's avatar
한규민 committed
102
            setError("");
한규민's avatar
한규민 committed
103
            //처리가 될때까지 버튼(가입하기)이 안눌리게 지정
한규민's avatar
한규민 committed
104
            setLoading(true);
한규민's avatar
한규민 committed
105
            let validPw = validationPw();
한규민's avatar
한규민 committed
106
107
108
109
110
111
112
113
114
115
116
117
118
            if(confirmMb){
                if(validPw){
                    const userData = user;
                    //서버로 전송
                    const error = await authApi.signup(userData);
                    if(error === "성공"){
                        setSuccess(true);
                    }else{
                        setErrorMsg(error);
                        alert("형식에 맞게 다시 작성해주세요");
                    }
                }else{
                    throw new Error("비밀번호가 일치하지 않습니다.");
한규민's avatar
한규민 committed
119
120
                }
            }else{
한규민's avatar
한규민 committed
121
                throw new Error("핸드폰 번호를 인증해주세요.");
한규민's avatar
한규민 committed
122
            }
한규민's avatar
한규민 committed
123
124
125
126
127
        } catch (error) {
            //에러전송
            catchErrors(error, setError);
        } finally {
            setLoading(false);
한규민's avatar
한규민 committed
128
        }
한규민's avatar
signup    
한규민 committed
129
    }
한규민's avatar
한규민 committed
130

한규민's avatar
한규민 committed
131
    if(success){
한규민's avatar
한규민 committed
132
133
        return <Redirect to="/login" />;
    }
한규민's avatar
한규민 committed
134

한규민's avatar
한규민 committed
135
    return (
한규민's avatar
한규민 committed
136
        // 데이터 입력과 유효성 검사 후 보이는 경고창
한규민's avatar
한규민 committed
137
        <form className={`d-flex col-md-6 col-12 justify-content-center`} onSubmit={handleOnSummit}>
한규민's avatar
한규민 committed
138
            <div className="d-flex flex-column">
한규민's avatar
signup    
한규민 committed
139
140
141
142
                <span className={styles.title}>회원가입</span>
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>아이디</label>
한규민's avatar
한규민 committed
143
                        <input className={`${styles.input} ${styles.inputSize}`} type="text" name="userId" placeholder="5~10자리 사이" onChange={handleUserOnChange} maxLength="10"/>
한규민's avatar
한규민 committed
144
                    </div>
한규민's avatar
한규민 committed
145
                    {errorMsg.errorId && <p className={styles.errorMsg}>5~10자리 사이로 입력해주세요.</p>}
146
                </div>
147
148
149
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>이름</label>
한규민's avatar
한규민 committed
150
                        <input className={`${styles.input} ${styles.inputSize}`} type="text" name="userName" placeholder="이름을 입력해주세요" onChange={handleUserOnChange}  maxLength="20"  />
151
                    </div>
한규민's avatar
한규민 committed
152
                    {errorMsg.errorName && <p className={styles.errorMsg}>이름을 입력해주세요</p>}
153
                </div>
한규민's avatar
한규민 committed
154
155
156
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>이메일</label>
한규민's avatar
한규민 committed
157
                        <input className={`${styles.input} ${styles.inputSize}`} type="email" name="userEmail" placeholder="이메일을 입력해주세요" onChange={handleUserOnChange} maxLength="20"  />
한규민's avatar
한규민 committed
158
                    </div>
한규민's avatar
한규민 committed
159
                    {errorMsg.errorEmail && <p className={styles.errorMsg}>이메일을 입력해주세요</p>}
한규민's avatar
한규민 committed
160
                </div>
한규민's avatar
한규민 committed
161
162
163
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>별명</label>
한규민's avatar
한규민 committed
164
                        <input className={`${styles.input} ${styles.inputSize}`} type="text" name="userNickName" placeholder="10자리 이내" onChange={handleUserOnChange} maxLength="20"  />
한규민's avatar
한규민 committed
165
                    </div>
한규민's avatar
한규민 committed
166
                    {errorMsg.errorNickName && <p className={styles.errorMsg}>10 이내로 입력해주세요.</p>}
167
                </div>
한규민's avatar
한규민 committed
168
169
170
171

                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>생년월일</label>
한규민's avatar
한규민 committed
172
                        <input className={`${styles.input} ${styles.inputSize} ${styles.input.placeholder}`} type="number" name="userBirthday" placeholder="6자리(예시: 991225)" onChange={handleUserOnChange} min="0" max="999999"  />
한규민's avatar
한규민 committed
173
                    </div>
한규민's avatar
한규민 committed
174
                    {errorMsg.errorBirthday && <p className={styles.errorMsg}>숫자 6자리를 입력해주세요.</p>}
175
                </div>
한규민's avatar
한규민 committed
176
177
178
179

                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>휴대폰 번호</label>
한규민's avatar
한규민 committed
180
                        <div className="d-flex col-md-auto">
한규민's avatar
한규민 committed
181
                            <input className={`${styles.input} ${styles.input2}`} type="number" name="userMbnum" placeholder="-없이 11자리 입력" onChange={handleUserOnChange} min="0" max="99999999999"  />
한규민's avatar
한규민 committed
182
                            <button type="button" disabled={loading} className={`rounded-2 mt-2 ${styles.butterYellowAndBtn} ${styles.btnHover}`} data-bs-toggle="collapse" data-bs-target="#collapseExample" aria-expanded="false" aria-controls="collapseExample" onClick={handleOnClickMbnum}>인증번호받기</button>
한규민's avatar
한규민 committed
183
                        </div>
한규민's avatar
한규민 committed
184
                    </div>
한규민's avatar
한규민 committed
185
                    {errorMsg.errorMbnum && <p className={styles.errorMsg}>-없이 숫자 11자리를 입력해주세요.</p>}
한규민's avatar
한규민 committed
186

한규민's avatar
한규민 committed
187
                    <div className="collapse" id="collapseExample">
한규민's avatar
한규민 committed
188
189
190
191
                        {/* <div className="d-flex col-md-auto justify-content-end"> */}
                        <div className="d-flex justify-content-between mt-3">
                            <label className={`${styles.confirm}`}>인증하기</label>
                            <div>
한규민's avatar
한규민 committed
192
                                <input className={`${styles.input} ${styles.input2}`} type="number" placeholder="인증번호를 입력" onChange={handleOnChangeMb} />
한규민's avatar
한규민 committed
193
194
195
196
                                <button type="button" className={`rounded-2 py-2 ${styles.butterYellowAndBtn} ${styles.btnHover}`} onClick={handleOnClickMbConfirm}>확인</button>
                                <button type="button" className={`rounded-2 py-2 ${styles.butterYellowAndBtn} ${styles.btnHover}`} onClick={handleOnClickMbnum}>재전송</button>
                            </div>
                        </div>
한규민's avatar
한규민 committed
197
198
199
200
                        {(mbError === "재전송") && <p className={styles.errorMsg}>유효시간이 만료되었습니다. 재전송해주세요.</p>}
                        {(mbError === "보냄") && <p className={styles.errorMsg}>5분이내에 입력해주세요.</p>}
                        {(mbError === "성공") && <p className={styles.errorMsg}>인증되었습니다.</p>}
                        {(mbError === "실패") && <p className={styles.errorMsg}>인증번호를 다시 입력해주세요.</p>}
한규민's avatar
한규민 committed
201
                    </div>
202
                </div>
한규민's avatar
한규민 committed
203

한규민's avatar
한규민 committed
204
205
206
                <div className="d-flex flex-column">
                    <div className={`${styles.inputContent}`}>
                        <label className={styles.signupLabel}>비밀번호</label>
한규민's avatar
한규민 committed
207
                        <input className={`${styles.input} ${styles.inputSize}`} type="password" name="userPassword" placeholder="8~11자리 사이" onChange={handleUserOnChange} maxLength="20"  />
한규민's avatar
한규민 committed
208
                    </div>
한규민's avatar
한규민 committed
209
                    {errorMsg.errorPassword && <p className={styles.errorMsg}>8~11자리 사이로 입력해주세요.</p>}
210
                </div>
한규민's avatar
한규민 committed
211

한규민's avatar
한규민 committed
212
213
                <div className={`d-flex ${styles.inputContent}`}>
                    <label className={styles.signupLabel}>비밀번호 확인</label>
한규민's avatar
한규민 committed
214
                    <input className={`${styles.input} ${styles.inputSize}`} type="password" name="userRePassword" placeholder="8~11자리 사이" onChange={handleUserOnChange} maxLength="20"  />
한규민's avatar
한규민 committed
215
216
                </div>

한규민's avatar
한규민 committed
217
                <button className={`rounded my-3 py-2 fs-5 ${styles.butterYellowAndBtn} ${styles.btnHover}`} type="submit" disabled={loading}>가입하기</button>
218
            </div>
한규민's avatar
한규민 committed
219
        </form>
한규민's avatar
한규민 committed
220
221
222
223
    )
}

export default Signup