1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
import { v4 as uuidv4 } from 'uuid';
import axios from 'axios';
import { NavBar } from '../components/navbar';
import { CenteredPage } from '../components/page';
import { Vierkant, Input, Button } from '../components/ui';
var ids = {
email: uuidv4(),
password: uuidv4()
}
function submitLogin() {
var formData = {
email: (document.getElementById(ids.email) as HTMLInputElement).value,
password: (document.getElementById(ids.password) as HTMLInputElement).value
}
if ( !formData.email ||
!formData.password ) {
alert("Vul alsjeblieft alle velden in!");
return;
}
axios({
method: "post",
url: `${window.location.origin}/api/auth/login`,
headers: {"content-type": "application/json"},
data: formData
})
.then(() => window.location.pathname = "/")
.catch(error => {
if (error.response.status === 401) {
alert("Verkeerde gebruikersnaam/wachtwoord combinatie!")
return;
}
alert("Er is iets fout gegaan!");
});
}
export default function LoginPage() {
return (
<div>
<NavBar/>
<CenteredPage width={500} style={{ height: "100vh" }}>
<div style={{
position: "relative",
top: "50%",
transform: "translateY(-50%)",
margin: "0 auto",
textAlign: "center"
}}>
<Vierkant>
<Input id={ids.email} label="email of gebruikersnaam" style={{ marginBottom: 12 }}></Input>
<Input id={ids.password} label="wachtwoord" type="password"></Input>
<div style={{
marginTop: 24,
gridGap: 24,
display: "grid",
gridTemplateColumns: "1fr 1fr"
}}>
<Button text="Registreren" style={{ backgroundColor: "var(--background-alt)" }} onclick={() => window.location.pathname = "/register"}></Button>
<Button text="Inloggen" onclick={submitLogin}></Button>
</div>
</Vierkant>
</div>
</CenteredPage>
</div>
);
}
|