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

const Signup = () => {
한규민's avatar
한규민 committed
8
    //회원정보
한규민's avatar
한규민 committed
9
    const [user, setUser] = useState({
한규민's avatar
한규민 committed
10
        userId: "",
Kim, Subin's avatar
Kim, Subin committed
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);
Kim, Subin's avatar
Kim, Subin committed
23
    const [mbError, setMbError] = useState(false);
한규민's avatar
한규민 committed
24
    const [error, setError] = useState("");
한규민's avatar
한규민 committed
25
    const [errorMsg, setErrorMsg] = useState({
한규민's avatar
한규민 committed
26
        errorId: false,
27
        errorName: false,
한규민's avatar
한규민 committed
28
        errorEmail: false,
한규민's avatar
한규민 committed
29
        errorNickName: false,
한규민's avatar
한규민 committed
30
31
32
33
        errorBirthday: false,
        errorMbnum: false,
        errorPassword: false,
    })
한규민's avatar
한규민 committed
34
    const [confirmMb, setConfirmMb] = useState(false);
한규민's avatar
한규민 committed
35

36
    const handleUserOnChange = (e) => {
한규민's avatar
한규민 committed
37
38
        setUser({
            ...user,
39
40
            [e.target.name]: e.target.value
        })
한규민's avatar
한규민 committed
41
        if (e.target.name === "userBirthday" || e.target.name === "userMbum") {
한규민's avatar
한규민 committed
42
43
44
45
46
            setUser({
                ...user,
                [e.target.name]: String(e.target.value)
            })
        }
한규민's avatar
한규민 committed
47
    }
한규민's avatar
한규민 committed
48
    const handleOnClickMbnum = async (e) => {
한규민's avatar
한규민 committed
49
        e.preventDefault();
한규민's avatar
한규민 committed
50
        try {
51
            setStartTime("");
한규민's avatar
한규민 committed
52
53
54
55
            setError("");
            setLoading(true)
            const phone = user.userMbnum;
            const message = await authApi.confirmMbnum(phone);
Kim, Subin's avatar
Kim, Subin committed
56
57
58
            if (message.isSuccess) {
                setMbError("보냄");
                setStartTime(message.startTime);
한규민's avatar
한규민 committed
59
            }
한규민's avatar
한규민 committed
60
        } catch (error) {
Kim, Subin's avatar
Kim, Subin committed
61
            catchErrors(error, setError);
한규민's avatar
한규민 committed
62
        } finally {
한규민's avatar
한규민 committed
63
64
65
            setLoading(false);
        }
    }
한규민's avatar
한규민 committed
66

한규민's avatar
한규민 committed
67
68
69
    const handleOnChangeMb = (e) => {
        setNumber(String(e.target.value));
    }
한규민's avatar
한규민 committed
70

한규민's avatar
한규민 committed
71
72
73
74
    const handleOnClickMbConfirm = async (e) => {
        e.preventDefault();
        try {
            setError("");
75
            setLoading(true);
Kim, Subin's avatar
Kim, Subin committed
76
            const confirmNum = { userMbnum: user.userMbnum, number: number, startTime: startTime };
한규민's avatar
한규민 committed
77
78
            const message = await authApi.confirmNum(confirmNum);
            setMbError(message);
Kim, Subin's avatar
Kim, Subin committed
79
            if (message === "성공") {
한규민's avatar
한규민 committed
80
81
82
83
                setConfirmMb(true);
            }
        } catch (error) {
            catchErrors(error, setError);
한규민's avatar
한규민 committed
84
        } finally {
한규민's avatar
한규민 committed
85
            setLoading(false);
한규민's avatar
한규민 committed
86
        }
한규민's avatar
한규민 committed
87
    }
한규민's avatar
한규민 committed
88

한규민's avatar
한규민 committed
89
    const validationPw = () => {
Kim, Subin's avatar
Kim, Subin committed
90
91
        if (user.userPassword !== user.userRePassword) return false;
        else return true;
한규민's avatar
한규민 committed
92
    }
한규민's avatar
한규민 committed
93

한규민's avatar
한규민 committed
94
95
96
    const handleOnSummit = async (e) => {
        e.preventDefault();
        try {
한규민's avatar
한규민 committed
97
98
            setError("");
            setLoading(true);
한규민's avatar
한규민 committed
99
            let validPw = validationPw();
Kim, Subin's avatar
Kim, Subin committed
100
101
            if (confirmMb) {
                if (validPw) {
한규민's avatar
한규민 committed
102
103
                    const userData = user;
                    const error = await authApi.signup(userData);
Kim, Subin's avatar
Kim, Subin committed
104
105
                    if (error === "성공") setSuccess(true);
                    else {
한규민's avatar
한규민 committed
106
107
108
                        setErrorMsg(error);
                        alert("형식에 맞게 다시 작성해주세요");
                    }
Kim, Subin's avatar
Kim, Subin committed
109
110
                } else throw new Error("비밀번호가 일치하지 않습니다.");
            } else throw new Error("핸드폰 번호를 인증해주세요.");
한규민's avatar
한규민 committed
111
112
113
114
        } catch (error) {
            catchErrors(error, setError);
        } finally {
            setLoading(false);
한규민's avatar
한규민 committed
115
        }
한규민's avatar
signup    
한규민 committed
116
    }
한규민's avatar
한규민 committed
117

한규민's avatar
한규민 committed
118
119
120
    if (success) {
        return <Redirect to="/login" />;
    }
한규민's avatar
한규민 committed
121

한규민's avatar
한규민 committed
122
    return (
한규민's avatar
한규민 committed
123
        <form className={`d-flex col-md-6 col-12 justify-content-center`} onSubmit={handleOnSummit}>
한규민's avatar
한규민 committed
124
            <div className="d-flex flex-column">
한규민's avatar
signup    
한규민 committed
125
126
127
128
                <span className={styles.title}>회원가입</span>
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>아이디</label>
Kim, Subin's avatar
Kim, Subin committed
129
                        <input className={`${styles.input} ${styles.inputSize}`} type="text" name="userId" placeholder="5~10자리 사이" onChange={handleUserOnChange} maxLength="10" />
한규민's avatar
한규민 committed
130
                    </div>
한규민's avatar
한규민 committed
131
                    {errorMsg.errorId && <p className={styles.errorMsg}>5~10자리 사이로 입력해주세요.</p>}
132
                </div>
133
134
135
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>이름</label>
Kim, Subin's avatar
Kim, Subin committed
136
                        <input className={`${styles.input} ${styles.inputSize}`} type="text" name="userName" placeholder="이름을 입력해주세요" onChange={handleUserOnChange} maxLength="20" />
137
                    </div>
한규민's avatar
한규민 committed
138
                    {errorMsg.errorName && <p className={styles.errorMsg}>이름을 입력해주세요</p>}
139
                </div>
한규민's avatar
한규민 committed
140
141
142
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>이메일</label>
Kim, Subin's avatar
Kim, Subin committed
143
                        <input className={`${styles.input} ${styles.inputSize}`} type="email" name="userEmail" placeholder="이메일을 입력해주세요" onChange={handleUserOnChange} maxLength="20" />
한규민's avatar
한규민 committed
144
                    </div>
한규민's avatar
한규민 committed
145
                    {errorMsg.errorEmail && <p className={styles.errorMsg}>이메일을 입력해주세요</p>}
한규민's avatar
한규민 committed
146
                </div>
한규민's avatar
한규민 committed
147
148
149
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>별명</label>
Kim, Subin's avatar
Kim, Subin committed
150
                        <input className={`${styles.input} ${styles.inputSize}`} type="text" name="userNickName" placeholder="10자리 이내" onChange={handleUserOnChange} maxLength="20" />
한규민's avatar
한규민 committed
151
                    </div>
한규민's avatar
한규민 committed
152
                    {errorMsg.errorNickName && <p className={styles.errorMsg}>10 이내로 입력해주세요.</p>}
153
                </div>
한규민's avatar
한규민 committed
154
155
156
                <div className="d-flex flex-column">
                    <div className={styles.inputContent}>
                        <label className={styles.signupLabel}>생년월일</label>
Kim, Subin's avatar
Kim, Subin committed
157
                        <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
158
                    </div>
한규민's avatar
한규민 committed
159
                    {errorMsg.errorBirthday && <p className={styles.errorMsg}>숫자 6자리를 입력해주세요.</p>}
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
                        <div className="d-flex col-md-auto">
Kim, Subin's avatar
Kim, Subin committed
165
                            <input className={`${styles.input} ${styles.input2}`} type="number" name="userMbnum" placeholder="-없이 11자리 입력" onChange={handleUserOnChange} min="0" max="99999999999" />
한규민's avatar
한규민 committed
166
                            <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
167
                        </div>
한규민's avatar
한규민 committed
168
                    </div>
한규민's avatar
한규민 committed
169
170
                    {errorMsg.errorMbnum && <p className={styles.errorMsg}>-없이 숫자 11자리를 입력해주세요.</p>}
                    <div className="collapse" id="collapseExample">
한규민's avatar
한규민 committed
171
172
173
                        <div className="d-flex justify-content-between mt-3">
                            <label className={`${styles.confirm}`}>인증하기</label>
                            <div>
한규민's avatar
한규민 committed
174
                                <input className={`${styles.input} ${styles.input2}`} type="number" placeholder="인증번호를 입력" onChange={handleOnChangeMb} />
한규민's avatar
한규민 committed
175
176
177
178
                                <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
179
180
181
182
                        {(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
183
                    </div>
184
                </div>
한규민's avatar
한규민 committed
185

한규민's avatar
한규민 committed
186
187
188
                <div className="d-flex flex-column">
                    <div className={`${styles.inputContent}`}>
                        <label className={styles.signupLabel}>비밀번호</label>
Kim, Subin's avatar
Kim, Subin committed
189
                        <input className={`${styles.input} ${styles.inputSize}`} type="password" name="userPassword" placeholder="8~11자리 사이" onChange={handleUserOnChange} maxLength="20" />
한규민's avatar
한규민 committed
190
                    </div>
한규민's avatar
한규민 committed
191
                    {errorMsg.errorPassword && <p className={styles.errorMsg}>8~11자리 사이로 입력해주세요.</p>}
192
                </div>
한규민's avatar
한규민 committed
193
194
                <div className={`d-flex ${styles.inputContent}`}>
                    <label className={styles.signupLabel}>비밀번호 확인</label>
Kim, Subin's avatar
Kim, Subin committed
195
                    <input className={`${styles.input} ${styles.inputSize}`} type="password" name="userRePassword" placeholder="8~11자리 사이" onChange={handleUserOnChange} maxLength="20" />
한규민's avatar
한규민 committed
196
                </div>
한규민's avatar
한규민 committed
197
                <button className={`rounded my-3 py-2 fs-5 ${styles.butterYellowAndBtn} ${styles.btnHover}`} type="submit" disabled={loading}>가입하기</button>
198
            </div>
한규민's avatar
한규민 committed
199
        </form>
한규민's avatar
한규민 committed
200
201
202
203
    )
}

export default Signup