forked from SOLUX-high5ive/FE
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request SOLUX-high5ive#26 from SOLUX-high5ive/yeonjin
LandingPage 업데이트
- Loading branch information
Showing
6 changed files
with
211 additions
and
54 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,61 +1,218 @@ | ||
import React, { useState } from 'react'; | ||
import styled from 'styled-components'; | ||
import { useNavigate } from 'react-router-dom'; | ||
import earth from '../images/Landingpage/Earth_etc.png'; | ||
import backpack from '../images/Landingpage/backpack.png'; | ||
import logo from '../images/Landingpage/logo.png'; | ||
import passport from '../images/Landingpage/passport.png'; | ||
import axios from 'axios'; | ||
import Cookies from 'js-cookie' | ||
import { useNavigate } from 'react-router-dom'; | ||
|
||
|
||
const Background = styled.div` | ||
background: linear-gradient(#253149, #323691); | ||
width: 100vw; | ||
height: 100%; | ||
display: flex; | ||
flex-direction: column; | ||
align-items: center; | ||
justify-content: center; | ||
`; | ||
|
||
const Logo = styled.img` | ||
margin-top: 250px; | ||
`; | ||
|
||
const Text = styled.div` | ||
color: white; | ||
font-size: 30px; | ||
margin-bottom: 20px; | ||
`; | ||
|
||
const LoginButton = styled.button` | ||
background-color: #6695F1; | ||
color: white; | ||
border-radius: 50px; | ||
border: none; | ||
padding: 10px 30px; | ||
margin: 15px 30px; | ||
font-size: 25px; | ||
&:hover { | ||
background-color: #5880cf; | ||
`; | ||
|
||
const SignUpButton = styled.button` | ||
color: white; | ||
text-decoration: underline; | ||
background:none; | ||
border:none; | ||
font-size: 20px; | ||
&:hover { | ||
text-decoration: underline; | ||
`; | ||
|
||
const EmailInput = styled.input` | ||
width: 300px; | ||
height: 50px; | ||
background-color: #8E8E8E; | ||
border: none; | ||
border-radius: 20px; | ||
margin: 10px; | ||
padding: 10px; | ||
opacity: 0.6; | ||
font-size: 20px; | ||
`; | ||
|
||
const PwInput = styled.input` | ||
width: 300px; | ||
height: 50px; | ||
background-color: #8E8E8E; | ||
border: none; | ||
border-radius: 20px; | ||
margin: 10px; | ||
padding: 10px; | ||
opacity: 0.6; | ||
font-size: 20px; | ||
`; | ||
|
||
const Earth = styled.img` | ||
`; | ||
|
||
const Passport = styled.img` | ||
position: absolute; | ||
top: 1; | ||
right:1; | ||
margin: -20% 50% 0 0; | ||
` | ||
|
||
const Backpack = styled.img` | ||
position: absolute; | ||
top: 1; | ||
right:0; | ||
margin: 30% 5% 0 0; | ||
` | ||
|
||
const Container = styled.div` | ||
display: flex; | ||
justify-content: center; | ||
align-items: center; | ||
`; | ||
|
||
const ImageContainer = styled.div` | ||
display: flex; | ||
flex-direction: column; | ||
justify-content: center; | ||
align-items: center; | ||
` | ||
|
||
const LogoContainer = styled.div` | ||
position: absolute; | ||
top: 0; | ||
right: 0; | ||
left: 0; | ||
margin: -50px 0 0 0; | ||
display: flex; | ||
flex-direction: column; | ||
justify-content: center; | ||
align-items: center; | ||
` | ||
|
||
const H4 = styled.div` | ||
color: white; | ||
font-size: 20px; | ||
`; | ||
|
||
const LoginContainer = styled.div` | ||
display: flex; | ||
flex-direction: column; | ||
justify-content: center; | ||
align-items: center; | ||
margin-bottom: 200px; | ||
` | ||
|
||
const LandingPage = () => { | ||
const [id, setEmail] = useState(''); | ||
const [password, setPassword] = useState(''); | ||
const navigate = useNavigate(); | ||
|
||
const handleEmailChange = (e) => { | ||
setEmail(e.target.value); | ||
}; | ||
|
||
const handlePasswordChange = (e) => { | ||
setPassword(e.target.value); | ||
}; | ||
|
||
const handleLogin = () => { | ||
// 로그인 로직 추가 | ||
console.log('로그인 시도:', id, password); | ||
axios.post('http://127.0.0.1:8000/sign/login', | ||
{ | ||
user_id: id, | ||
user_pw : password | ||
}, {headers:{'XSRF-Token':Cookies.get('csrftoken')}}) | ||
.then(res => { | ||
alert('로그인 성공!'); | ||
navigate('/home'); | ||
}) | ||
.catch(err => { | ||
console.error('login error', err); | ||
}) | ||
}; | ||
|
||
const handleSignUp = () => { | ||
// 회원가입 로직 추가 | ||
console.log('회원가입 및 성향테스트하기 클릭'); | ||
}; | ||
|
||
|
||
return ( | ||
<div className="startpage"> | ||
<img src="C:\사용자\박민주\startpage\landing.png" alt="플래닛 여행 사이트 랜딩 페이지" /> | ||
<div> | ||
<label>이메일:</label> | ||
<input type="email" value={id} onChange={handleEmailChange} placeholder="이메일" /> | ||
</div> | ||
<div> | ||
<label>비밀번호:</label> | ||
<input type="password" value={password} onChange={handlePasswordChange} placeholder="비밀번호" /> | ||
</div> | ||
<button onClick={handleLogin}>로그인</button> | ||
<p> | ||
계정이 없으신가요? <button onClick={handleSignUp}>회원가입 및 성향테스트하기</button> | ||
</p> | ||
</div> | ||
); | ||
const [email, setEmail] = useState(''); | ||
const [password, setPassword] = useState(''); | ||
const navigate = useNavigate(); | ||
|
||
const handleEmailChange = (e) => { | ||
setEmail(e.target.value); | ||
}; | ||
|
||
const handlePasswordChange = (e) => { | ||
setPassword(e.target.value); | ||
}; | ||
|
||
const handleSignUp = () => { | ||
navigate('/signup'); | ||
}; | ||
|
||
const handleLogin = () => { | ||
// 로그인 로직 추가 | ||
console.log('로그인 시도:', email, password); | ||
axios.post('http://127.0.0.1:8000/sign/login', | ||
{ | ||
user_id: email, | ||
user_pw : password | ||
}, {headers:{'XSRF-Token':Cookies.get('csrftoken')}}) | ||
.then(res => { | ||
alert('로그인 성공!'); | ||
navigate('/home'); | ||
}) | ||
.catch(err => { | ||
console.error('login error', err); | ||
}) | ||
}; | ||
|
||
return ( | ||
<> | ||
<Background> | ||
<ImageContainer> | ||
<LogoContainer> | ||
<Logo src={logo}/> | ||
<Text> | ||
다양한 성향의 여행자들이 모이는 이곳은 Planet Travel | ||
</Text> | ||
</LogoContainer> | ||
<Earth src={earth}/> | ||
</ImageContainer> | ||
<Passport src={passport}/> | ||
<Backpack src={backpack}/> | ||
<LoginContainer> | ||
<Text>지금 바로 로그인하기</Text> | ||
<EmailInput | ||
value={email} | ||
onChange={handleEmailChange} | ||
placeholder='이메일' | ||
/> | ||
<PwInput | ||
value={password} | ||
onChange={handlePasswordChange} | ||
placeholder='비밀번호' | ||
/> | ||
<LoginButton onClick={handleLogin}>로그인</LoginButton> | ||
<Container> | ||
<H4>계정이 없으신가요? </H4> | ||
<SignUpButton onClick={handleSignUp}> | ||
회원가입 및 성향테스트하기 | ||
</SignUpButton> | ||
</Container> | ||
</LoginContainer> | ||
</Background> | ||
</> | ||
); | ||
}; | ||
|
||
export default LandingPage; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters