34628-vm/register.php
2025-10-03 14:17:07 +00:00

151 lines
4.8 KiB
PHP

<?php
require_once 'db/config.php';
$error = '';
$success = '';
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$name = $_POST['name'] ?? '';
$email = $_POST['email'] ?? '';
$password = $_POST['password'] ?? '';
$role_id = $_POST['role_id'] ?? 3; // Default to 'Funcionário'
if (empty($name) || empty($email) || empty($password)) {
$error = 'Por favor, preencha todos os campos.';
} elseif (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
$error = 'Formato de e-mail inválido.';
} else {
try {
$pdo = db();
// Check if email already exists
$stmt = $pdo->prepare('SELECT COUNT(*) FROM users WHERE email = ?');
$stmt->execute([$email]);
if ($stmt->fetchColumn() > 0) {
$error = 'Este e-mail já está cadastrado.';
} else {
$hashed_password = password_hash($password, PASSWORD_DEFAULT);
$stmt = $pdo->prepare('INSERT INTO users (name, email, password, role_id) VALUES (?, ?, ?, ?)');
$stmt->execute([$name, $email, $hashed_password, $role_id]);
$success = 'Usuário cadastrado com sucesso! Você pode fazer o login agora.';
}
} catch (PDOException $e) {
$error = 'Erro no banco de dados: ' . $e->getMessage();
}
}
}
// Fetch roles for the dropdown
try {
$pdo = db();
$roles = $pdo->query('SELECT * FROM roles')->fetchAll();
} catch (PDOException $e) {
$roles = [];
$error = 'Erro ao carregar os papéis de usuário.';
}
?>
<!DOCTYPE html>
<html lang="pt-BR">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Cadastro - Gestão Agrícola</title>
<link rel="stylesheet" href="assets/css/style.css?v=<?php echo time(); ?>">
<style>
body {
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background-color: #f4f6f9;
}
.register-container {
background: #fff;
padding: 40px;
border-radius: 8px;
box-shadow: 0 4px 10px rgba(0,0,0,0.1);
width: 100%;
max-width: 450px;
text-align: center;
}
.register-container h2 {
margin-bottom: 20px;
color: #2c3e50;
}
.form-group {
margin-bottom: 15px;
text-align: left;
}
.form-group label {
display: block;
margin-bottom: 5px;
}
.form-group input, .form-group select {
width: 100%;
padding: 10px;
border: 1px solid #ccc;
border-radius: 4px;
}
.btn {
background-color: #27ae60;
color: #fff;
padding: 12px;
border: none;
border-radius: 4px;
cursor: pointer;
width: 100%;
font-size: 1rem;
}
.error {
color: #e74c3c;
margin-bottom: 15px;
}
.success {
color: #27ae60;
margin-bottom: 15px;
}
.login-link {
margin-top: 20px;
}
</style>
</head>
<body>
<div class="register-container">
<h2>Cadastro de Usuário</h2>
<?php if ($error): ?><p class="error"><?php echo $error; ?></p><?php endif; ?>
<?php if ($success): ?><p class="success"><?php echo $success; ?></p><?php endif; ?>
<form action="register.php" method="POST">
<div class="form-group">
<label for="name">Nome Completo</label>
<input type="text" id="name" name="name" required>
</div>
<div class="form-group">
<label for="email">E-mail</label>
<input type="email" id="email" name="email" required>
</div>
<div class="form-group">
<label for="password">Senha</label>
<input type="password" id="password" name="password" required>
</div>
<div class="form-group">
<label for="role_id">Função</label>
<select id="role_id" name="role_id">
<?php foreach ($roles as $role): ?>
<option value="<?php echo htmlspecialchars($role['id']); ?>" <?php echo $role['id'] == 3 ? 'selected' : ''; ?>>
<?php echo htmlspecialchars($role['name']); ?>
</option>
<?php endforeach; ?>
</select>
</div>
<button type="submit" class="btn">Cadastrar</button>
</form>
<div class="login-link">
<p>Já tem uma conta? <a href="login.php">Faça o login</a></p>
</div>
</div>
</body>
</html>