MyInfo.js 14 KB
Newer Older
한규민's avatar
한규민 committed
1
2
3
import styles from "./my-info.module.scss";
import { useState, useEffect } from "react";
import authApi from "../../apis/auth.api";
한규민's avatar
한규민 committed
4
import catchErrors from "../../utils/catchErrors.js";
한규민's avatar
한규민 committed
5
6

const MyInfo = () => {
한규민's avatar
한규민 committed
7
    const [userNickName, setUserNickName] = useState("사용자");
한규민's avatar
한규민 committed
8
9
    const [img, setImg] = useState("");
    const [profile, setProfile] = useState("");
한규민's avatar
한규민 committed
10

한규민's avatar
한규민 committed
11
    // 사용자 이름 가져오는 함수
한규민's avatar
한규민 committed
12
13
14
15
    const getMember = async () => {
        const member = await authApi.getMember();
        setUserNickName(member.nickname);
        setProfile(member.img);
한규민's avatar
한규민 committed
16
    }
한규민's avatar
한규민 committed
17
    const [page, setPage] = useState(true);
한규민's avatar
한규민 committed
18

한규민's avatar
한규민 committed
19
20
21
22
23
    //현재 비밀번호 state
    const [presentPw, setPresentPw] = useState("");
    const [loading, setLoading] = useState(false);

    //변경할 데이터 입력받는 state
한규민's avatar
한규민 committed
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
    const [userRe, setUserRe] = useState({
        userEmail: "",
        userNickName: "",
        userMbnum: "",
        userPassword: "",
        userRePassword: ""
    })

    //각 타입별 error 유무 state
    const [error, setError] = useState("");
    const [errorMsg, setErrorMsg] = useState({
        errorEmail: false,
        errorNickName: false,
        errorMbnum: false,
        errorPassword: false,
        errorRePassword: false
    })

한규민's avatar
한규민 committed
42
    useEffect(() => {
한규민's avatar
한규민 committed
43
        getMember();
한규민's avatar
한규민 committed
44
45
    }, [])

한규민's avatar
한규민 committed
46
47
48
    const handlePwOnChange = (e) => {
        setPresentPw(e.target.value)
    }
한규민's avatar
한규민 committed
49
50
51
52
53
54
55
56
57
58
59
60
61
62

    //입력할때마다 state에 저장
    const handleUserOnChange = (e) => {
        setUserRe({
            ...userRe,
            [e.target.name]: e.target.value
        })
        if (e.target.name === "userMbnum") {
            setUserRe({
                ...userRe,
                [e.target.name]: String(e.target.value)
            })
        }
    }
한규민's avatar
한규민 committed
63
64
65
66
67
68
    const enterKey = (e) => {
        if (e.key === "Enter") {

            handleOnSummitVerify(e);
        }
    }
한규민's avatar
한규민 committed
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86

    const handleOnChange = (e) => {
        setImg(e.target.files[0]);
    }

    const handleOnSummitForm = async (e) => {
        e.preventDefault();
        try {
            setError("")
            const formData = new FormData();
            formData.append("image", img);
            const image = await authApi.profile(formData);
            console.log(image.img);
            setProfile(image.img);
        } catch (error) {
            catchErrors(error, setError);
        }
    }
한규민's avatar
한규민 committed
87
88
89
90
91
92
93
94
    //기존 비밀번호 확인 
    const handleOnSummitVerify = async (e) => {
        e.preventDefault();
        try {
            setError(() => (""));
            setLoading(() => (true));
            const pw = presentPw;
            const confirmPw = await authApi.comparePw(pw);
한규민's avatar
한규민 committed
95
            console.log("confirmPw : "+ confirmPw);
한규민's avatar
한규민 committed
96
            if (confirmPw) {
한규민's avatar
한규민 committed
97
                setPage(false);
한규민's avatar
한규민 committed
98
99
100
101
102
103
104
105
106
            } else {
                alert("비밀번호가 일치하지 않습니다.");
            }
        } catch (error) {
            catchErrors(error, setError);
        } finally {
            setLoading(false);
        }
    }
한규민's avatar
한규민 committed
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124

    //비교하여 error메세지 반환
    const vaildationData = (text, compareValue, error) => {
        if (text !== compareValue) {
            setErrorMsg(errorMsg => ({ ...errorMsg, [error]: true }));
        } else {
            setErrorMsg(errorMsg => ({ ...errorMsg, [error]: false }));
        }
    }

    const vaildationIdPw = (text, minValue, error) => {
        if ((text < minValue)) {
            setErrorMsg(errorMsg => ({ ...errorMsg, [error]: true }));
        } else {
            setErrorMsg(errorMsg => ({ ...errorMsg, [error]: false }));
        }
    }
    //유효성 검사
한규민's avatar
한규민 committed
125
126
127
128
129
130
131
132
133
    const validation = () => {
        //별명 유효성 검사
        vaildationData((userRe.userNickName.length === 0), false, "errorNickName");
        // 휴대폰 유효성 검사
        vaildationData(userRe.userMbnum.length, 11, "errorMbnum");
        // 비밀번호 유효성 검사
        vaildationIdPw(userRe.userPassword.length, 8, "errorPassword");
        // 비밀번호 확인 유효성 검사
        vaildationData(userRe.userPassword, userRe.userRePassword, "errorRePassword");
한규민's avatar
한규민 committed
134

한규민's avatar
한규민 committed
135
136
137
138
139
        // 최종 유효성 검사
        if ((Object.values(errorMsg).some((element) => (element)) === false)) {
            return true
        } else {
            return false
한규민's avatar
한규민 committed
140
141
142
143
        }
    }


한규민's avatar
한규민 committed
144

한규민's avatar
한규민 committed
145
146
147
148
149
150
    const handleOnSummit = async (e) => {
        e.preventDefault();
        try {
            setError(() => (""));
            //처리가 될때까지 버튼(가입하기)이 안눌리게 지정
            setLoading(() => (true));
한규민's avatar
한규민 committed
151
            console.log("userRe : " + userRe.userEmail);
한규민's avatar
한규민 committed
152
            //유효성 검사
한규민's avatar
한규민 committed
153
154
155
            let valid = validation();
            console.log("valid :" + valid);
            if (valid) {
한규민's avatar
한규민 committed
156
157
158
159
160
161
                const userData = userRe;
                console.log(userData);
                //서버로 전송
                const process = await authApi.modifyUser(userData);
                console.log("process : " + process);
                alert("회원정보 수정 완료");
한규민's avatar
한규민 committed
162
163
                valid = false;
            } else { throw new Error("유효하지 않은 데이터입니다.") }
한규민's avatar
한규민 committed
164
165
166
167
        } catch (error) {
            //에러전송
            catchErrors(error, setError);
        } finally {
한규민's avatar
한규민 committed
168
            setLoading(() => (false));
한규민's avatar
한규민 committed
169
170
171
        }
    }

한규민's avatar
한규민 committed
172
173
174
175
    const handleOnClick = (e) => {
        e.preventDefault();
        setPage(true);
    }
한규민's avatar
한규민 committed
176
177

    return (
한규민's avatar
한규민 committed
178
179
180
181
182
183
184
185
186
187
188
189
190
        <>
            {/* 마이페이지 창 */}
            <div className="d-flex flex-column">
                <span className={styles.title}>마이페이지</span>
                <div className="d-flex justify-content-around">
                    <div className={`${styles.box} me-5`}>
                        <p className={`${styles.hoverTxt}`}>프로필 변경</p>
                        <img src={`/upload/${profile}`} className={`figure-img img-fluid rounded-circle ${styles.profile}`} role="button" data-bs-toggle="modal" data-bs-target="#staticBackdrop" />
                    </div>
                    <div className="d-flex flex-column py-4 justify-content-around">
                        <span className={`${styles.userName}`}>{`${userNickName}`} 반갑습니다!</span>
                        <button className={`rounded my-3 fs-5 ${styles.butterYellowAndBtn} ${styles.btnHover}`} data-bs-toggle="modal" href="#verifyPassword" >회원정보 수정</button>
                    </div>
한규민's avatar
한규민 committed
191
192
193
                </div>
            </div>

한규민's avatar
한규민 committed
194
195
196
197
198
199
            <div className="modal fade" id="staticBackdrop" data-bs-backdrop="static" data-bs-keyboard="false" tabindex="-1" aria-labelledby="staticBackdropLabel" aria-hidden="true">
                <div className="modal-dialog modal-dialog-centered">
                    <form className="modal-content" onSubmit={handleOnSummitForm}>
                        <div className="modal-header">
                            <h5 className="modal-title" id="staticBackdropLabel">프로필변경</h5>
                            <button type="button" className="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
한규민's avatar
한규민 committed
200
                        </div>
한규민's avatar
한규민 committed
201
202
203
204
205
206
207
208
209
                        <div className="modal-body">
                            <input type="file" onChange={handleOnChange} />
                        </div>
                        <div className="modal-footer">
                            <button type="button" className="btn btn-secondary" data-bs-dismiss="modal">닫기</button>
                            <button type="submit" className={`rounded  fs-5 ${styles.butterYellowAndBtn} ${styles.btnHover}`}>변경</button>
                        </div>
                    </form>
                </div>
한규민's avatar
한규민 committed
210
211
            </div>

한규민's avatar
한규민 committed
212
213
214
215
216
217
218
219
            {/* 기존 비밀번호 확인 모달창 */}
            <div className="modal fade" id="verifyPassword" data-bs-backdrop="static" data-bs-keyboard="false" aria-hidden="true" aria-labelledby="verifyPasswordLabel" tabindex="-1">
                <div className="modal-dialog modal-dialog-centered modal-dialog-centered">
                    {page ?
                        <><form className="modal-content" onSubmit={handleOnSummitVerify}>
                            <div className="modal-header">
                                <h5 className="modal-title" id="verifyPasswordLabel">기존 비밀번호 확인</h5>
                                <button type="button" className="btn-close" data-bs-dismiss="modal" aria-label="Close" onclick={handleOnClick}></button>
한규민's avatar
한규민 committed
220
                            </div>
한규민's avatar
한규민 committed
221
222
223
224
225
226
227
                            <div clasNames="modal-body">
                                <div className="d-flex flex-column">
                                    <div className="d-flex justify-content-around align-items-center my-4">
                                        <label className={styles.signupLabel}>현재 비밀번호</label>
                                        <input className={`${styles.input} ${styles.inputSize}`} type="password" name="userPassword" placeholder="8~11자리 사이" onChange={handlePwOnChange} onKeyPress={enterKey} maxLength="11" required />
                                    </div>
                                </div>
한규민's avatar
한규민 committed
228
                            </div>
한규민's avatar
한규민 committed
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
                            <div className="modal-footer">
                                <button type="submit" className={`rounded my-3 fs-5 ${styles.butterYellowAndBtn} ${styles.btnHover}`} disabled={loading}>확인</button>
                            </div>
                        </form></>
                        : <><form className={`modal-content d-flex col-md-6 col-12 justify-content-center d-flex flex-column`} onSubmit={handleOnSummit}>
                            <div className="modal-header">
                                <h5 className="modal-title" id="modifyLabel">회원정보 수정</h5>
                                <button type="button" className="btn-close" data-bs-dismiss="modal" aria-label="Close" onclick={handleOnClick}></button>
                            </div>
                            <div className={`modal-body`}>
                                <div className="d-flex flex-column">
                                    <div className={styles.inputContent}>
                                        <label className={styles.signupLabel}>이메일</label>
                                        <input className={`${styles.input} ${styles.inputSize}`} type="email" name="userEmail" placeholder="이메일을 입력해주세요" onChange={handleUserOnChange} maxlength="20" required />
                                    </div>
                                    {errorMsg.errorEmail && <p className={styles.passwordConfirmError}>이메일을 입력해주세요</p>}
                                </div>
                                <div className="d-flex flex-column">
                                    <div className={styles.inputContent}>
                                        <label className={styles.signupLabel}>별명</label>
                                        <input className={`${styles.input} ${styles.inputSize}`} type="text" name="userNickName" placeholder="10자리 이내" onChange={handleUserOnChange} maxLength="10" required />
                                    </div>
                                    {errorMsg.errorNickName && <p className={styles.passwordConfirmError}>10 이내로 입력해주세요.</p>}
                                </div>
한규민's avatar
한규민 committed
253

한규민's avatar
한규민 committed
254
255
256
257
258
259
260
261
                                <div className="d-flex flex-column">
                                    <div className={styles.inputContent}>
                                        <label className={styles.signupLabel}>휴대폰 번호</label>
                                        <div className="d-flex col-md-auto">
                                            <input className={`${styles.input} ${styles.inputSize}`} type="number" name="userMbnum" placeholder="-없이 11자리 입력" onChange={handleUserOnChange} min="" max="99999999999" required />
                                        </div>
                                    </div>
                                    {errorMsg.errorMbnum && <p className={styles.passwordConfirmError}>-없이 숫자 11자리를 입력해주세요.</p>}
한규민's avatar
한규민 committed
262
263
                                </div>

한규민's avatar
한규민 committed
264
265
266
267
268
269
                                <div className="d-flex flex-column">
                                    <div className={styles.inputContent}>
                                        <label className={styles.signupLabel}> 비밀번호</label>
                                        <input className={`${styles.input} ${styles.inputSize}`} type="password" name="userPassword" placeholder="8~11자리 사이" onChange={handleUserOnChange} maxLength="11" required />
                                    </div>
                                    {errorMsg.errorPassword && <p className={styles.passwordConfirmError}>8~11자리 사이로 입력해주세요.</p>}
한규민's avatar
한규민 committed
270

한규민's avatar
한규민 committed
271
                                </div>
한규민's avatar
한규민 committed
272

한규민's avatar
한규민 committed
273
274
275
276
277
278
                                <div className="d-flex flex-column">
                                    <div className={styles.inputContent}>
                                        <label className={styles.signupLabel}> 비밀번호 확인</label>
                                        <input className={`${styles.input} ${styles.inputSize}`} type="password" name="userRePassword" placeholder="8~11자리 사이" onChange={handleUserOnChange} maxLength="11" required />
                                    </div>
                                    {errorMsg.errorRePassword && <p className={styles.passwordConfirmError}>비밀번호가 일치하지 않습니다.</p>}
한규민's avatar
한규민 committed
279

한규민's avatar
한규민 committed
280
                                </div>
한규민's avatar
한규민 committed
281

한규민's avatar
한규민 committed
282
283
284
285
286
287
288
                            </div>
                            <div className="modal-footer">
                                <button type="button" className="btn btn-secondary rounded my-3 py-2 fs-5" data-bs-dismiss="modal" onClick={handleOnClick} disabled={loading}>닫기</button>
                                <button type="submit" className={`rounded my-3 py-2 fs-5 ${styles.butterYellowAndBtn} ${styles.btnHover}`} disabled={loading}>수정하기</button>
                            </div>
                        </form></>}
                </div>
한규민's avatar
한규민 committed
289
            </div>
한규민's avatar
한규민 committed
290
        </>
한규민's avatar
한규민 committed
291
292
293
294
    )
}

export default MyInfo