35149-vm/admin_programs.php
Flatlogic Bot 7a3409404c v01
2025-10-23 20:44:05 +00:00

144 lines
5.5 KiB
PHP

<?php
include 'templates/header.php';
require_once 'db/config.php';
// Admin-only page
if (!isset($_SESSION['role_id']) || $_SESSION['role_id'] != 1) {
header('Location: dashboard.php');
exit;
}
$pdo = db();
$action = $_GET['action'] ?? 'list';
$id = $_GET['id'] ?? null;
// Fetch schools for the dropdown
$schools_stmt = $pdo->query('SELECT id, name FROM schools ORDER BY name');
$schools = $schools_stmt->fetchAll();
// Handle form submissions
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
$name = trim($_POST['name']);
$school_id = $_POST['school_id'];
if (isset($_POST['add_program'])) {
if (!empty($name) && !empty($school_id)) {
$stmt = $pdo->prepare('INSERT INTO programs (name, school_id) VALUES (?, ?)');
$stmt->execute([$name, $school_id]);
}
} elseif (isset($_POST['update_program'])) {
if (!empty($name) && !empty($school_id) && !empty($id)) {
$stmt = $pdo->prepare('UPDATE programs SET name = ?, school_id = ? WHERE id = ?');
$stmt->execute([$name, $school_id, $id]);
}
header('Location: admin_programs.php');
exit;
} elseif (isset($_POST['delete_program'])) {
if (!empty($id)) {
$stmt = $pdo->prepare('DELETE FROM programs WHERE id = ?');
$stmt->execute([$id]);
}
header('Location: admin_programs.php');
exit;
}
}
?>
<h2>Assessment Planning: Programs</h2>
<p><a href="admin.php"> &larr; Back to Admin Dashboard</a></p>
<?php if ($action === 'edit' && $id): ?>
<?php
$stmt = $pdo->prepare('SELECT * FROM programs WHERE id = ?');
$stmt->execute([$id]);
$program = $stmt->fetch();
?>
<h3>Edit Program</h3>
<form action="admin_programs.php?action=edit&id=<?php echo $id; ?>" method="post">
<div class="mb-3">
<label for="name" class="form-label">Program Name</label>
<input type="text" class="form-control" id="name" name="name" value="<?php echo htmlspecialchars($program['name']); ?>" required>
</div>
<div class="mb-3">
<label for="school_id" class="form-label">School</label>
<select class="form-select" id="school_id" name="school_id" required>
<?php foreach ($schools as $school): ?>
<option value="<?php echo $school['id']; ?>" <?php echo ($school['id'] == $program['school_id']) ? 'selected' : ''; ?>><?php echo htmlspecialchars($school['name']); ?></option>
<?php endforeach; ?>
</select>
</div>
<input type="hidden" name="id" value="<?php echo $id; ?>">
<button type="submit" name="update_program" class="btn btn-primary">Update</button>
<a href="admin_programs.php" class="btn btn-secondary">Cancel</a>
</form>
<?php elseif ($action === 'delete' && $id): ?>
<?php
$stmt = $pdo->prepare('SELECT * FROM programs WHERE id = ?');
$stmt->execute([$id]);
$program = $stmt->fetch();
?>
<h3>Delete Program</h3>
<p>Are you sure you want to delete the program "<?php echo htmlspecialchars($program['name']); ?>"?</p>
<form action="admin_programs.php?action=delete&id=<?php echo $id; ?>" method="post">
<input type="hidden" name="id" value="<?php echo $id; ?>">
<button type="submit" name="delete_program" class="btn btn-danger">Delete</button>
<a href="admin_programs.php" class="btn btn-secondary">Cancel</a>
</form>
<?php else: ?>
<h3>Add New Program</h3>
<form action="admin_programs.php" method="post">
<div class="mb-3">
<label for="name" class="form-label">Program Name</label>
<input type="text" class="form-control" id="name" name="name" required>
</div>
<div class="mb-3">
<label for="school_id" class="form-label">School</label>
<select class="form-select" id="school_id" name="school_id" required>
<option value="">Select a School</option>
<?php foreach ($schools as $school): ?>
<option value="<?php echo $school['id']; ?>"><?php echo htmlspecialchars($school['name']); ?></option>
<?php endforeach; ?>
</select>
</div>
<button type="submit" name="add_program" class="btn btn-primary">Add Program</button>
</form>
<hr>
<h3>Existing Programs</h3>
<table class="table table-striped">
<thead>
<tr>
<th>ID</th>
<th>Name</th>
<th>School</th>
<th>Actions</th>
</tr>
</thead>
<tbody>
<?php
$stmt = $pdo->query('SELECT p.id, p.name, s.name AS school_name FROM programs p JOIN schools s ON p.school_id = s.id ORDER BY p.id');
while ($row = $stmt->fetch()) {
echo "<tr>";
echo "<td>" . htmlspecialchars($row['id']) . "</td>";
echo "<td>" . htmlspecialchars($row['name']) . "</td>";
echo "<td>" . htmlspecialchars($row['school_name']) . "</td>";
echo '<td>
<a href="admin_programs.php?action=edit&id=' . $row['id'] . '" class="btn btn-sm btn-outline-primary">Edit</a>
<a href="admin_programs.php?action=delete&id=' . $row['id'] . '" class="btn btn-sm btn-outline-danger">Delete</a>
</td>';
echo "</tr>";
}
?>
</tbody>
</table>
<?php endif; ?>
<?php include 'templates/footer.php'; ?>