53 lines
1.8 KiB
Plaintext
53 lines
1.8 KiB
Plaintext
|
<!DOCTYPE html>
|
||
|
<html lang="en">
|
||
|
<head>
|
||
|
<meta charset="UTF-8">
|
||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||
|
<title>Register</title>
|
||
|
<link rel="stylesheet" href="/css/styles.css">
|
||
|
</head>
|
||
|
<body>
|
||
|
<header>
|
||
|
<h1>Register</h1>
|
||
|
</header>
|
||
|
<main>
|
||
|
<form id="registerForm">
|
||
|
<div>
|
||
|
<label for="username">Username:</label>
|
||
|
<input type="text" id="username" name="username" required>
|
||
|
</div>
|
||
|
<div>
|
||
|
<label for="password">Password:</label>
|
||
|
<input type="password" id="password" name="password" required>
|
||
|
</div>
|
||
|
<div>
|
||
|
<label for="role">Role:</label>
|
||
|
<select id="role" name="role" required>
|
||
|
<option value="user">User</option>
|
||
|
<option value="admin">Admin</option>
|
||
|
</select>
|
||
|
</div>
|
||
|
<button type="submit">Register</button>
|
||
|
</form>
|
||
|
<p id="message"></p>
|
||
|
</main>
|
||
|
<script>
|
||
|
document.getElementById('registerForm').addEventListener('submit', async function(event) {
|
||
|
event.preventDefault();
|
||
|
const formData = {
|
||
|
username: document.getElementById('username').value,
|
||
|
password: document.getElementById('password').value,
|
||
|
role: document.getElementById('role').value
|
||
|
};
|
||
|
const response = await fetch('/api/register', {
|
||
|
method: 'POST',
|
||
|
headers: { 'Content-Type': 'application/json' },
|
||
|
body: JSON.stringify(formData)
|
||
|
});
|
||
|
const result = await response.json();
|
||
|
document.getElementById('message').textContent = result.message || result.error;
|
||
|
});
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|