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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
import axios from 'axios';
import { validate as validateEmail } from 'email-validator';
import { FormEvent } from 'react';
import { NavBar } from '../components/navbar';
import { CenteredPage } from '../components/page';
import { Vierkant, Input, Button } from '../components/ui';
function submitRegister(event?: FormEvent<HTMLFormElement>) {
event.preventDefault();
var formData = {
username: (document.getElementById("username") as HTMLInputElement).value,
email: (document.getElementById("email") as HTMLInputElement).value,
password: (document.getElementById("password") as HTMLInputElement).value
}
if ( !formData.username ||
!formData.email ||
!formData.password ) {
alert("Vul alsjeblieft alle velden in!");
return;
}
var passwordRegex: RegExp = /^(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9]).{8,}$/;
/*
* ^ Begin string
* (?=.*[A-Z]) Minimaal één hoofdletter
* (?=.*[a-z]) Minimaal één kleine letter
* (?=.*[0-9]) Minimaal één getal
* .{8,} Minimaal acht tekens in lengte
* $ Ende string
* https://stackoverflow.com/questions/5142103/regex-to-validate-password-strength
*/
//TODO: alert -> react toast / material-ui snackbar
if ( formData.username.length > 35 ) {
alert("Je gebruikersnaam kan maximaal 35 tekens lang zijn!");
return;
}
if ( !validateEmail(formData.email) ) {
alert("Voer alsjeblieft een geldig e-mail adres in!");
return;
}
//TODO: wachtwoord max 72 tekens ivm bcrypt
if ( !formData.password.match(passwordRegex) ) {
alert("Je wachtwoord moet minimaal 8 tekens lang zijn en een hoofdletter, kleine letter, en een nummer bevatten!");
return;
}
axios({
method: "post",
url: `${window.location.origin}/api/auth/signup`,
headers: {"content-type": "application/json"},
data: formData
})
.then(() => {
//TODO: email verificatie
// redirect naar home, automatische login
window.location.pathname = "/";
})
.catch(error => {
alert("Er is iets fout gegaan!");
console.log(error);
});
}
export default function RegisterPage() {
return (
<div>
<NavBar/>
<CenteredPage width={500} style={{ height: "100vh" }}>
<div style={{
position: "relative",
top: "50%",
transform: "translateY(-50%)",
margin: "0 auto",
textAlign: "center"
}}>
<Vierkant>
<form onSubmit={submitRegister}>
<Input autocomplete="username" id="username" label="gebruikersnaam" style={{ marginBottom: 12 }}></Input>
<Input autocomplete="email" id="email" label="email" style={{ marginBottom: 12 }}></Input>
<Input autocomplete="new-password" id="password" label="wachtwoord" type="password"></Input>
<Button text="Registreren" style={{ marginTop: 24 }} onclick={submitRegister}></Button>
<input type="submit" style={{ display: "none" }}/>
</form>
</Vierkant>
</div>
</CenteredPage>
</div>
);
}
|