100 lines
3.9 KiB
PHP
100 lines
3.9 KiB
PHP
<?php
|
|
require_once __DIR__ . '/db/config.php';
|
|
|
|
// Assume a logged-in coach with ID 1
|
|
$coach_id = 1;
|
|
|
|
$pdo = db();
|
|
|
|
// Get teams for the coach
|
|
$stmt = $pdo->prepare('SELECT * FROM teams WHERE coach_id = ?');
|
|
$stmt->execute([$coach_id]);
|
|
$teams = $stmt->fetchAll();
|
|
|
|
?>
|
|
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>Coach Dashboard - Golf Tournament</title>
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
<link rel="stylesheet" href="assets/css/custom.css">
|
|
</head>
|
|
<body>
|
|
|
|
<nav class="navbar navbar-expand-lg navbar-dark bg-primary">
|
|
<div class="container">
|
|
<a class="navbar-brand" href="index.php">Golf Tournament</a>
|
|
<div class="collapse navbar-collapse" id="navbarNav">
|
|
<ul class="navbar-nav ms-auto">
|
|
<li class="nav-item"><a class="nav-link" href="index.php">Home</a></li>
|
|
<li class="nav-item"><a class="nav-link" href="add_score.php">Add Score</a></li>
|
|
<li class="nav-item"><a class="nav-link" href="admin.php">Admin</a></li>
|
|
<li class="nav-item"><a class="nav-link active" href="coach.php">Coach</a></li>
|
|
<li class="nav-item"><a class="nav-link" href="results.php">Results</a></li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
|
|
<div class="container mt-5">
|
|
<h1 class="text-center mb-4">Coach's Dashboard</h1>
|
|
|
|
<?php foreach ($teams as $team): ?>
|
|
<div class="card shadow-sm mt-4">
|
|
<div class="card-body">
|
|
<h2 class="card-title">Team: <?= htmlspecialchars($team['name']) ?></h2>
|
|
<?php
|
|
$stmt = $pdo->prepare('
|
|
SELECT p.name as player_name, s.id as score_id, s.total_score, c.name as course_name, s.played_at
|
|
FROM scores s
|
|
JOIN players p ON s.player_id = p.id
|
|
JOIN courses c ON s.course_id = c.id
|
|
WHERE s.team_id = ?
|
|
ORDER BY s.played_at DESC
|
|
');
|
|
$stmt->execute([$team['id']]);
|
|
$scores = $stmt->fetchAll();
|
|
?>
|
|
<?php if ($scores): ?>
|
|
<table class="table table-striped">
|
|
<thead>
|
|
<tr>
|
|
<th>Player</th>
|
|
<th>Course</th>
|
|
<th>Score</th>
|
|
<th>Date</th>
|
|
<th>Action</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<?php foreach ($scores as $score): ?>
|
|
<tr>
|
|
<td><?= htmlspecialchars($score['player_name']) ?></td>
|
|
<td><?= htmlspecialchars($score['course_name']) ?></td>
|
|
<td><?= htmlspecialchars($score['total_score']) ?></td>
|
|
<td><?= date('Y-m-d', strtotime($score['played_at'])) ?></td>
|
|
<td><a href="edit_score.php?score_id=<?= $score['score_id'] ?>" class="btn btn-sm btn-primary">Edit</a></td>
|
|
</tr>
|
|
<?php endforeach; ?>
|
|
</tbody>
|
|
</table>
|
|
<?php else: ?>
|
|
<p>No scores recorded for this team yet.</p>
|
|
<?php endif; ?>
|
|
</div>
|
|
</div>
|
|
<?php endforeach; ?>
|
|
|
|
</div>
|
|
|
|
<footer class="bg-light text-center text-lg-start mt-5">
|
|
<div class="text-center p-3" style="background-color: rgba(0, 0, 0, 0.05);">
|
|
© 2025 Golf Tournament
|
|
</div>
|
|
</footer>
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
|
|
</body>
|
|
</html>
|