Files
xxx-sphere-old/xxxthegame/src/main/resources/static/registration.html

125 lines
5.2 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<!DOCTYPE html>
<html lang="de">
<head>
<meta charset="UTF-8">
<link rel="icon" href="/img/icon.png" type="image/png">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Neues Konto erstellen xXx Sphere</title>
<link rel="stylesheet" href="/css/variables.css">
<link rel="stylesheet" href="/css/style.css">
</head>
<body>
<div class="card">
<img src="/img/icon.png" alt="Logo">
<h1>Neues Konto erstellen</h1>
<label for="name">Name</label>
<input type="text" id="name" placeholder="Dein Name" autocomplete="name" />
<label for="email">E-Mail</label>
<input type="email" id="email" placeholder="deine@email.de" autocomplete="email" />
<label for="geburtsdatum">Geburtsdatum</label>
<input type="date" id="geburtsdatum" autocomplete="bday" />
<label for="password">Passwort</label>
<input type="password" id="password" placeholder="••••••••" autocomplete="new-password" />
<label for="passwordConfirm">Passwort wiederholen</label>
<input type="password" id="passwordConfirm" placeholder="••••••••" autocomplete="new-password" />
<button class="full-width" id="registerBtn" onclick="register()">Registrieren</button>
<div class="message" id="message"></div>
<p style="text-align:center; margin-top:1.5rem; font-size:0.85rem;">
Bereits registriert? <a href="/login.html" style="color:#e94560;">Anmelden</a>
</p>
</div>
<script>
document.addEventListener('keydown', e => {
if (e.key === 'Enter') register();
});
async function register() {
const name = document.getElementById('name').value.trim();
const email = document.getElementById('email').value.trim();
const geburtsdatum = document.getElementById('geburtsdatum').value;
const password = document.getElementById('password').value;
const passwordConfirm = document.getElementById('passwordConfirm').value;
const btn = document.getElementById('registerBtn');
if (!name || !email || !geburtsdatum || !password || !passwordConfirm) {
showMessage('Bitte alle Felder ausfüllen.', 'error');
return;
}
if (!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email)) {
showMessage('Bitte eine gültige E-Mail-Adresse eingeben.', 'error');
return;
}
const today = new Date();
const birth = new Date(geburtsdatum);
const age = today.getFullYear() - birth.getFullYear()
- (today < new Date(today.getFullYear(), birth.getMonth(), birth.getDate()) ? 1 : 0);
if (age < 18) {
showMessage('Du musst mindestens 18 Jahre alt sein, um dich zu registrieren.', 'error');
return;
}
if (password !== passwordConfirm) {
showMessage('Die Passwörter stimmen nicht überein.', 'error');
return;
}
btn.disabled = true;
btn.textContent = 'Wird verarbeitet…';
hideMessage();
try {
const response = await fetch('/registration', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ name, email, password, geburtsdatum })
});
if (response.status === 202) {
window.location.href = `/activate.html?email=${encodeURIComponent(email)}`;
} else if (response.status === 422) {
showMessage('Du musst mindestens 18 Jahre alt sein, um dich zu registrieren.', 'error');
btn.disabled = false;
btn.textContent = 'Registrieren';
} else if (response.status === 400) {
showMessage('Diese E-Mail-Adresse ist bereits registriert.', 'error');
btn.disabled = false;
btn.textContent = 'Registrieren';
} else if (response.status === 409) {
showMessage('Dieser Name ist bereits vergeben.', 'error');
btn.disabled = false;
btn.textContent = 'Registrieren';
} else {
showMessage(`Fehler: HTTP ${response.status}`, 'error');
btn.disabled = false;
btn.textContent = 'Registrieren';
}
} catch (err) {
showMessage('Server nicht erreichbar.', 'error');
btn.disabled = false;
btn.textContent = 'Registrieren';
console.error(err);
}
}
function showMessage(text, type) {
const el = document.getElementById('message');
el.textContent = text;
el.className = `message ${type}`;
el.style.display = 'block';
}
function hideMessage() {
document.getElementById('message').style.display = 'none';
}
</script>
</body>
</html>