Login.js 4.61 KB
Newer Older
한규민's avatar
한규민 committed
1
import { useState } from "react";
한규민's avatar
login    
한규민 committed
2
3
import styles from "./login.module.scss";

한규민's avatar
한규민 committed
4
const Login = () => {
5
6
    //useState를 이용해서 각 state 생성 및 초기값 저장
    const [state, setState] = useState(true); // 이 줄은 css에 해당하는 state
한규민's avatar
한규민 committed
7
    //state변수 지정 하지만 이 변수는 react에 의해 없어지지 않음, 그리고 그 다음 변수는 state변수를 갱신해주는 함수
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
    const [loginText, setLoginText] = useState({
        id:'',
        password:''
    });

    const [guestText, setGusetText] = useState({
        guestName:'',
        gusetBirthday:'',
        gusetMbnum:'',
        guestPassword:''
    })

    //input태그에 걸려있는 onchange에서 실행할 함수설정
    const handleLoginOnChange = (e) =>{
        // ... 전개 연산자
        // 현재 state에 방금 변화한 값을 다시 저장함
        setLoginText({ ...loginText,
25
            [e.target.name]:e.target.value
26
27
28
29
30
31
32
33
        })
    };

    const handleGuestOnChange = (e) =>{
        setGusetText({ ...guestText,
            [e.target.name]:e.target.value
        })
    }
한규민's avatar
한규민 committed
34
35

    return (
한규민's avatar
한규민 committed
36
        <div className={`d-flex flex-column col-md-5 col-10`}>
한규민's avatar
한규민 committed
37
            {/* nav-tabs */}
한규민's avatar
한규민 committed
38
            {/* {console.log(loginText)} */}
한규민's avatar
한규민 committed
39
            <ul className="nav nav-fill nav-tabs w-100" id="loginTab" role="tablist">
한규민's avatar
login    
한규민 committed
40
                <li className="nav-item fs-6" role="presentation">
41
                    <button className={`nav-link active px-2 ${styles.fontSize}`} style={{ color: state ? "black" : "#FEDC00", backgroundColor: state ? "#FEDC00" : "black"}} 
한규민's avatar
login    
한규민 committed
42
43
                    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
44
45
                </li>
                <li className="nav-item" role="presentation">
한규민's avatar
login    
한규민 committed
46
47
                    <button className={`nav-link px-2 ${styles.fontSize}`}
                    id="guest-tab" data-bs-toggle="tab" data-bs-target="#guest" type="button" role="tab" aria-controls="guest" aria-selected="false" 
48
                    onClick={() => setState(false)} style={{ color: state ? "#FEDC00" : "black", backgroundColor: state ? "black" : "#FEDC00" }}>비회원 예매 확인</button>
한규민's avatar
한규민 committed
49
50
                </li>
            </ul>
한규민's avatar
한규민 committed
51

한규민's avatar
한규민 committed
52
            <div className="tab-content w-100" id="myTabContent">
한규민's avatar
한규민 committed
53
54
                {/* 로그인 */}
                <div className="tab-pane fade show active" id="login" role="tabpanel" aria-labelledby="login-tab">
한규민's avatar
한규민 committed
55
                    <div className="d-flex flex-column ">
56
57
                        <input className={styles.input} type="text" name="id" placeholder="ID" onChange={handleLoginOnChange}/>
                        <input className={styles.input} type="text" name="password" placeholder="Password" onChange={handleLoginOnChange} minlength="8" required />
한규민's avatar
한규민 committed
58
                    <input className={`rounded-2 mt-2 ${styles.butterYellowAndBtn} ${styles.btnHover}`} type="submit" value="Login" />
한규민's avatar
한규민 committed
59
                        <span><a href="./signup" className={styles.intoSignupPage}>회원이 아니십니까?</a></span>
한규민's avatar
한규민 committed
60
61
62
63
64
                    </div>
                </div>

                {/* 비회원예매 학인 */}
                <div className="tab-pane fade" id="guest" role="tabpanel" aria-labelledby="guest-tab">
한규민's avatar
한규민 committed
65
                    <div className="d-flex flex-column">
66
67
68
69
                        <input className={styles.input} type="text" name="guestName" id="guestName" placeholder="이름" onChange={handleGuestOnChange} minlength="8" required />
                        <input className={styles.input} type="number" name="gusetBirthday" id="gusetBirthday" placeholder="생년월일" onChange={handleGuestOnChange} minlength="8" required />
                        <input className={styles.input} type="number" name="gusetMbnum" id="gusetMbnum" placeholder="휴대폰 번호" onChange={handleGuestOnChange} minlength="8" required />
                        <input className={styles.input} type="text" name="guestPassword" id="password" placeholder="비밀번호" onChange={handleGuestOnChange} minlength="8" required />
한규민's avatar
한규민 committed
70
71

                        <p className={`text-white ${styles.fontSizeTwo}`}>
한규민's avatar
한규민 committed
72
73
                             비회원 정보  입력  예매 내역 확인/취소  티켓 발권이 어려울  있으니 다시 한번 확인해 주시기 바랍니다.
                        </p>
한규민's avatar
한규민 committed
74
                            <input className={`rounded-2 mt-2 ${styles.butterYellowAndBtn} ${styles.btnHover}`} type="submit" value="비회원 예매 확인" />
한규민's avatar
한규민 committed
75
76
                    </div>
                </div>
한규민's avatar
login    
한규민 committed
77
78
79
80
81
82
            </div>
        </div>
    )
}

export default Login