Login.js 6.32 KB
Newer Older
한규민's avatar
한규민 committed
1
import { useState } from "react";
한규민's avatar
login    
한규민 committed
2
import styles from "./login.module.scss";
한규민's avatar
한규민 committed
3
import { Redirect } from "react-router-dom";
한규민's avatar
한규민 committed
4
import catchErrors from "../../utils/catchErrors";
한규민's avatar
한규민 committed
5
import { useAuth } from "../../context/auth_context.js";
한규민's avatar
login    
한규민 committed
6

한규민's avatar
한규민 committed
7
const Login = () => {
한규민's avatar
한규민 committed
8
    const { login, guestLogin, loading } = useAuth();
9
10
    //useState를 이용해서 각 state 생성 및 초기값 저장
    const [state, setState] = useState(true); // 이 줄은 css에 해당하는 state
한규민's avatar
한규민 committed
11
    //state변수 지정 하지만 이 변수는 react에 의해 없어지지 않음, 그리고 그 다음 변수는 state변수를 갱신해주는 함수
한규민's avatar
한규민 committed
12
    const [user, setUser] = useState({
한규민's avatar
한규민 committed
13
14
        id: "",
        password: ""
15
    });
한규민's avatar
한규민 committed
16
    const [error, setError] = useState("");
한규민's avatar
한규민 committed
17
    const [success, setSuccess] = useState(false);
18

한규민's avatar
한규민 committed
19
    const [guest, setGuset] = useState({
한규민's avatar
한규민 committed
20
21
22
23
24
        guestName: "",
        guestEmail: "",
        guestBirthday: "",
        guestMbnum: "",
        guestPassword: ""
25
26
27
    })

    //input태그에 걸려있는 onchange에서 실행할 함수설정
한규민's avatar
push    
한규민 committed
28
    const handleLoginOnChange = (e) => {
29
30
        // ... 전개 연산자
        // 현재 state에 방금 변화한 값을 다시 저장함
한규민's avatar
한규민 committed
31
32
        setUser({
            ...user,
한규민's avatar
push    
한규민 committed
33
            [e.target.name]: e.target.value
34
35
36
        })
    };

한규민's avatar
push    
한규민 committed
37
38
39
40
    const handleGuestOnChange = (e) => {
        setGuset({
            ...guest,
            [e.target.name]: e.target.value
41
42
        })
    }
한규민's avatar
한규민 committed
43

한규민's avatar
context    
한규민 committed
44
    const requestServer = async (data) => {
한규민's avatar
한규민 committed
45
46
47
48
49
50
51
52
53
54
55
56
57
58
        try {
            if (data === user) {
                const success = await login(data);
                if (success) {
                    setSuccess("member");
                    alert('로그인이 완료되었습니다.')
                }
            } else {
                const success = await guestLogin(data);
                if (success) {
                    setSuccess("guest");
                    alert('로그인이 완료되었습니다.')
                }

한규민's avatar
한규민 committed
59
            }
한규민's avatar
한규민 committed
60
61
        } catch (error) {
            catchErrors(error, setError);
한규민's avatar
한규민 committed
62
        }
한규민's avatar
한규민 committed
63
64
    }

한규민's avatar
push    
한규민 committed
65
    const handleOnSummit = async (e) => {
한규민's avatar
한규민 committed
66
        e.preventDefault();
한규민's avatar
push    
한규민 committed
67
        try {
한규민's avatar
한규민 committed
68
            setError("");
한규민's avatar
push    
한규민 committed
69
            if (e.target.name === "login") {
한규민's avatar
한규민 committed
70
                requestServer(user);
한규민's avatar
push    
한규민 committed
71
72
73
74
75
            }
            else {
                requestServer(guest);
            }
        } catch (error) {
한규민's avatar
한규민 committed
76
77
78
79
            catchErrors(error, setError);
        }
    }

한규민's avatar
한규민 committed
80
    if (success === "member") {
한규민's avatar
한규민 committed
81
        return <Redirect to="/" />;
한규민's avatar
한규민 committed
82
83
    } else if (success === "guest"){
        return <Redirect to="/guest" />;
한규민's avatar
한규민 committed
84
    }
한규민's avatar
push    
한규민 committed
85

한규민's avatar
한규민 committed
86
    return (
한규민's avatar
한규민 committed
87
        <div className={`d-flex flex-column col-md-5 col-10`}>
한규민's avatar
한규민 committed
88
            <span className={styles.title}>로그인</span>
한규민's avatar
한규민 committed
89
            <ul className="nav nav-fill nav-tabs w-100" id="loginTab" role="tablist">
한규민's avatar
login    
한규민 committed
90
                <li className="nav-item fs-6" role="presentation">
한규민's avatar
push    
한규민 committed
91
92
93
                    <button className={`nav-link active px-2 ${styles.fontSize}`} style={{ color: state ? "black" : "#FEDC00", backgroundColor: state ? "#FEDC00" : "black" }}
                        id="login-tab" data-bs-toggle="tab" data-bs-target="#login" type="button" role="tab" aria-controls="login" aria-selected="true"
                        onClick={() => setState(true)}>로그인</button>
한규민's avatar
한규민 committed
94
95
                </li>
                <li className="nav-item" role="presentation">
한규민's avatar
login    
한규민 committed
96
                    <button className={`nav-link px-2 ${styles.fontSize}`}
한규민's avatar
push    
한규민 committed
97
98
                        id="guest-tab" data-bs-toggle="tab" data-bs-target="#guest" type="button" role="tab" aria-controls="guest" aria-selected="false"
                        onClick={() => setState(false)} style={{ color: state ? "#FEDC00" : "black", backgroundColor: state ? "black" : "#FEDC00" }}>비회원 예매 확인</button>
한규민's avatar
한규민 committed
99
100
101
                </li>
            </ul>
            <div className="tab-content w-100" id="myTabContent">
한규민's avatar
한규민 committed
102
103
                {/* 로그인 */}
                <div className="tab-pane fade show active" id="login" role="tabpanel" aria-labelledby="login-tab">
한규민's avatar
push    
한규민 committed
104
                    <form className="d-flex flex-column" name="login" onSubmit={handleOnSummit}>
한규민's avatar
한규민 committed
105
106
                        <input className={styles.input} type="text" name="id" placeholder="ID" onChange={handleLoginOnChange} maxLength="10"/>
                        <input className={styles.input} type="password" name="password" placeholder="Password" onChange={handleLoginOnChange} maxLength="11"/>
한규민's avatar
push    
한규민 committed
107
                        <input className={`rounded-2 mt-2 ${styles.butterYellowAndBtn} ${styles.btnHover}`} type="submit" value="Login" disabled={loading} />
한규민's avatar
한규민 committed
108
                        <span><a href="./signup" className={styles.intoSignupPage}>회원이 아니십니까?</a></span>
한규민's avatar
한규민 committed
109
                    </form>
한규민's avatar
한규민 committed
110
111
112
                </div>
                {/* 비회원예매 학인 */}
                <div className="tab-pane fade" id="guest" role="tabpanel" aria-labelledby="guest-tab">
한규민's avatar
context    
한규민 committed
113
                    <form className="d-flex flex-column" onSubmit={handleOnSummit}>
한규민's avatar
한규민 committed
114
115
116
117
118
                        <input className={styles.input} type="text" name="guestName" id="guestName" placeholder="이름" onChange={handleGuestOnChange} maxLength="10"/>
                        <input className={styles.input} type="email" name="guestEmail" id="guestEmail" placeholder="이메일" onChange={handleGuestOnChange} maxLength="20"/>
                        <input className={styles.input} type="number" name="guestBirthday" id="guestBirthday" placeholder="생년월일" onChange={handleGuestOnChange}  min="0" max="999999" />
                        <input className={styles.input} type="number" name="guestMbnum" id="guestMbnum" placeholder="휴대폰 번호" onChange={handleGuestOnChange}  min="0" max="99999999999" />
                        <input className={styles.input} type="password" name="guestPassword" id="guestPassword" placeholder="비밀번호" onChange={handleGuestOnChange} maxLength="20"/>
한규민's avatar
한규민 committed
119
                        <p className={`text-white ${styles.fontSizeTwo}`}>
한규민's avatar
한규민 committed
120
121
                             비회원 정보  입력  예매 내역 확인/취소  티켓 발권이 어려울  있으니 다시 한번 확인해 주시기 바랍니다.
                        </p>
한규민's avatar
push    
한규민 committed
122
                        <input className={`rounded-2 mt-2 ${styles.butterYellowAndBtn} ${styles.btnHover}`} type="submit" value="비회원 예매 확인" disabled={loading} />
한규민's avatar
한규민 committed
123
                    </form>
한규민's avatar
한규민 committed
124
                </div>
한규민's avatar
login    
한규민 committed
125
126
127
128
129
130
            </div>
        </div>
    )
}

export default Login