Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
students
shopping-mall
Commits
033d3da9
Commit
033d3da9
authored
Dec 29, 2020
by
이재연
Browse files
로그인 기능 구현중...
parent
c856eca6
Changes
7
Expand all
Hide whitespace changes
Inline
Side-by-side
client/.eslintcache
View file @
033d3da9
This diff is collapsed.
Click to expand it.
client/src/App.js
View file @
033d3da9
import
logo
from
'
./logo.svg
'
;
import
logo
from
'
./logo.svg
'
;
import
'
./App.css
'
;
import
'
./App.css
'
;
import
{
Button
}
from
'
react-bootstrap
'
;
import
{
Button
}
from
'
react-bootstrap
'
;
import
{
Router
}
from
'
react-router-dom
'
;
import
Login
from
'
./Login
'
import
LogoutButton
from
'
./LogoutButton
'
import
{
signIn
}
from
'
./auth
'
function
App
()
{
function
App
()
{
function
btnfunc
(){
const
[
user
,
setUser
]
=
useState
(
null
);
alert
(
"
hi
"
)
console
.
log
(
"
아
"
)
const
authenticated
=
user
!=
null
;
}
return
(
const
login
=
({
id
,
password
})
=>
setUser
(
signIn
({
id
,
password
}));
<
div
className
=
"
App
"
>
<
header
className
=
"
App-header
"
>
const
logout
=
()
=>
setUser
(
null
);
<
img
src
=
{
logo
}
className
=
"
App-logo
"
alt
=
"
logo
"
/>
<
p
>
Edit
<
code
>
src
/
App
.
js
<
/code> and save to reload
.
<
/p
>
<
a
className
=
"
App-link
"
href
=
"
https://reactjs.org
"
target
=
"
_blank
"
rel
=
"
noopener noreferrer
"
>
Learn
React
<
/a
>
<
/header
>
<
/div
>
);
}
}
export
default
App
;
export
default
App
;
client/src/Auth.js
0 → 100644
View file @
033d3da9
const
users
=
[
{
id
:
'
wodus
'
,
password
:
'
123
'
},
{
id
:
'
kim
'
,
password
:
'
456
'
},
]
export
function
signIn
({
id
,
password
}){
const
user
=
users
.
find
(
user
=>
user
.
id
===
id
&&
user
.
password
===
password
);
if
(
user
===
undefined
)
throw
new
Error
();
return
user
;
}
\ No newline at end of file
client/src/AuthRoute.js
0 → 100644
View file @
033d3da9
import
React
from
'
react
'
import
{
Route
,
Redirect
}
from
"
react-router-dom
"
function
AuthRoute
({})
\ No newline at end of file
client/src/Pages/Login.js
View file @
033d3da9
...
@@ -5,8 +5,19 @@ import { Form, Col, Container, Button, Row } from 'react-bootstrap'
...
@@ -5,8 +5,19 @@ import { Form, Col, Container, Button, Row } from 'react-bootstrap'
import
{
Link
,
Redirect
}
from
'
react-router-dom
'
import
{
Link
,
Redirect
}
from
'
react-router-dom
'
function
Login
()
{
function
Login
(
authenticated
,
login
,
location
)
{
const
[
id
,
setId
]
=
useState
(
""
);
const
[
password
,
setPassword
]
=
useState
(
""
);
const
handleClick
=
()
=>
{
try
{
Login
({
id
,
password
})
}
catch
(
e
)
{
alert
(
"
Failed to login
"
)
setId
(
""
)
setPassword
(
""
)
}
}
return
(
return
(
<
div
>
<
div
>
...
@@ -24,7 +35,12 @@ function Login() {
...
@@ -24,7 +35,12 @@ function Login() {
<
Form
.
Row
>
<
Form
.
Row
>
<
Form
.
Label
for
=
"
id
"
>
User
Name
<
/Form.Label
>
<
Form
.
Label
for
=
"
id
"
>
User
Name
<
/Form.Label
>
<
Col
>
<
Col
>
<
Form
.
Control
type
=
"
text
"
id
=
"
id
"
className
=
"
mx-sm-3
"
size
=
"
sm
"
placeholder
=
"
User Name
"
><
/Form.Control
>
<
Form
.
Control
type
=
"
text
"
value
=
{
id
}
onChange
=
{({
target
:{
value
}})
=>
setId
(
value
)}
className
=
"
mx-sm-3
"
size
=
"
sm
"
placeholder
=
"
User Name
"
>
<
/Form.Control
>
<
/Col
>
<
/Col
>
<
/Form.Row
>
<
/Form.Row
>
<
/Form.Group
>
<
/Form.Group
>
...
@@ -33,11 +49,15 @@ function Login() {
...
@@ -33,11 +49,15 @@ function Login() {
<
Form
.
Row
>
<
Form
.
Row
>
<
Form
.
Label
for
=
"
password
"
>
Password
<
/Form.Label
>
<
Form
.
Label
for
=
"
password
"
>
Password
<
/Form.Label
>
<
Col
>
<
Col
>
<
Form
.
Control
type
=
"
password
"
id
=
"
password
"
className
=
"
mx-sm-3
"
size
=
"
sm
"
placeholder
=
"
Password
"
><
/Form.Control
>
<
Form
.
Control
type
=
"
password
"
value
=
{
password
}
onChange
=
{({
target
:{
value
}})
=>
setPassword
(
value
)}
className
=
"
mx-sm-3
"
size
=
"
sm
"
placeholder
=
"
Password
"
><
/Form.Control
>
<
/Col
>
<
/Col
>
<
/Form.Row
>
<
/Form.Row
>
<
/Form.Group
>
<
/Form.Group
>
<
Button
variant
=
"
outline-dark
"
type
=
"
submit
"
block
>
Login
<
/Button
>
<
Button
variant
=
"
outline-dark
"
type
=
"
submit
"
onClick
=
{
handleClick
}
block
>
Login
<
/Button
>
<
div
className
=
"
loginLine
"
>
<
div
className
=
"
loginLine
"
>
<
Link
to
=
"
/signup
"
>
SignUp
?
<
/Link
>
<
Link
to
=
"
/signup
"
>
SignUp
?
<
/Link
>
<
/div
>
<
/div
>
...
...
client/src/Pages/LogoutButton.js
0 → 100644
View file @
033d3da9
import
React
from
'
react
'
import
{
withRouter
}
from
'
react-router-dom
'
function
LogoutButton
({
logout
,
history
}){
const
handleClick
=
()
=>
{
logout
()
history
.
push
(
"
/
"
)
}
return
<
button
onClick
=
{
handleClick
}
>
Logout
<
/button
>
}
export
default
withRouter
(
LogoutButton
)
\ No newline at end of file
client/src/Pages/Signup.js
View file @
033d3da9
...
@@ -3,12 +3,14 @@ import { Redirect } from 'react-router-dom';
...
@@ -3,12 +3,14 @@ import { Redirect } from 'react-router-dom';
import
Nav1
from
'
../Components/MainNav
'
;
import
Nav1
from
'
../Components/MainNav
'
;
import
Nav2
from
'
../Components/SubNav
'
;
import
Nav2
from
'
../Components/SubNav
'
;
import
{
Form
,
Col
,
Container
,
Button
,
Row
}
from
'
react-bootstrap
'
import
{
Form
,
Col
,
Container
,
Button
,
Row
}
from
'
react-bootstrap
'
import
FormCheckInput
from
'
react-bootstrap/esm/FormCheckInput
'
;
function
Signup
()
{
function
Signup
()
{
return
(
return
(
<
div
>
<
div
>
<
Nav1
/>
<
Nav1
/>
<
Nav2
/>
<
Nav2
/>
<
Container
className
=
"
my-5
"
>
<
Container
className
=
"
my-5
"
>
...
@@ -45,7 +47,7 @@ function Signup() {
...
@@ -45,7 +47,7 @@ function Signup() {
<
Col
as
=
{
Row
}
>
<
Col
as
=
{
Row
}
>
<
Form
.
Control
type
=
"
text
"
id
=
"
number1
"
size
=
"
sm
"
maxlength
=
"
6
"
className
=
"
mx-sm-3
"
style
=
{{
width
:
'
120px
'
}}
><
/Form.Control
>
<
Form
.
Control
type
=
"
text
"
id
=
"
number1
"
size
=
"
sm
"
maxlength
=
"
6
"
className
=
"
mx-sm-3
"
style
=
{{
width
:
'
120px
'
}}
><
/Form.Control
>
-
-
<
Form
.
Control
type
=
"
text
"
id
=
"
number
1
"
size
=
"
sm
"
maxlength
=
"
1
"
className
=
"
mx-sm-3
"
style
=
{{
width
:
'
25px
'
}}
><
/Form.Control
>
<
Form
.
Control
type
=
"
text
"
id
=
"
number
2
"
size
=
"
sm
"
maxlength
=
"
1
"
className
=
"
mx-sm-3
"
style
=
{{
width
:
'
25px
'
}}
><
/Form.Control
>
******
******
<
/Col
>
<
/Col
>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment