besitz.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <?php
  2. require_once 'db_config.php';
  3. $msg = "";
  4. // --- LOGIK: STATUS AKTUALISIEREN ---
  5. if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['update_status'])) {
  6. $stmt = $pdo->prepare("INSERT INTO besitz_status (spieler_id, spiel_id, status)
  7. VALUES (?, ?, ?)
  8. ON DUPLICATE KEY UPDATE status = VALUES(status)");
  9. $stmt->execute([(int)$_POST['spieler_id'], (int)$_POST['spiel_id'], $_POST['status']]);
  10. $msg = "Status aktualisiert!";
  11. }
  12. // --- DATEN LADEN ---
  13. $spieler = $pdo->query("SELECT * FROM spieler ORDER BY name ASC")->fetchAll();
  14. // Spiele laden mit korrekten Joins laut deinem Dump
  15. $sqlSpiele = "SELECT s.*, r.name as reihe_name, t.bezeichnung as typ_name
  16. FROM spiele s
  17. LEFT JOIN game_reihe r ON s.game_reihe_id = r.id
  18. LEFT JOIN game_typ t ON s.game_typ_id = t.id
  19. ORDER BY r.name ASC, s.titel ASC";
  20. $spiele = $pdo->query($sqlSpiele)->fetchAll();
  21. // Mapping aus der Tabelle MIT Unterstrich
  22. $statusMapping = [];
  23. $statusData = $pdo->query("SELECT spieler_id, spiel_id, status FROM besitz_status")->fetchAll();
  24. foreach ($statusData as $row) {
  25. $statusMapping[$row['spiel_id']][$row['spieler_id']] = $row['status'];
  26. }
  27. ?>
  28. <!DOCTYPE html>
  29. <html lang="de">
  30. <head>
  31. <meta charset="UTF-8">
  32. <title>EXIT - Bestand & Besitz</title>
  33. <style>
  34. :root { --bg: #f4f7f6; --card: #ffffff; --text: #333; --border: #ddd; --accent: #e67e22; }
  35. .dark-theme { --bg: #121212; --card: #1e1e1e; --text: #e0e0e0; --border: #333; }
  36. body { font-family: 'Segoe UI', sans-serif; background: var(--bg); color: var(--text); padding: 20px; transition: 0.3s; }
  37. .container { max-width: 1200px; margin: auto; }
  38. header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
  39. .btn-nav { background: var(--accent); color: white; padding: 10px 15px; border-radius: 6px; text-decoration: none; font-weight: bold; }
  40. table { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
  41. th, td { padding: 12px; border-bottom: 1px solid var(--border); text-align: left; }
  42. .reihe-divider { background: rgba(230, 126, 34, 0.1); font-weight: bold; color: var(--accent); }
  43. select { padding: 6px; border-radius: 4px; border: 1px solid var(--border); background: var(--card); color: var(--text); width: 100%; }
  44. select[data-status="besitzt"] { background: #27ae60 !important; color: white !important; }
  45. select[data-status="verkauft"] { background: #e67e22 !important; color: white !important; }
  46. select[data-status="nicht besitzt"] { opacity: 0.5; }
  47. </style>
  48. </head>
  49. <body>
  50. <div class="container">
  51. <header>
  52. <h1>📦 Bestand & Besitz</h1>
  53. <div style="display: flex; gap: 15px;">
  54. <button onclick="toggleTheme()" id="theme-icon" style="background:none; border:none; cursor:pointer; font-size:1.2rem;">🌙</button>
  55. <a href="index.php" class="btn-nav">Dashboard</a>
  56. </div>
  57. </header>
  58. <table>
  59. <thead>
  60. <tr>
  61. <th>Spiel</th>
  62. <?php foreach ($spieler as $s): ?><th><?= htmlspecialchars($s['name']) ?></th><?php endforeach; ?>
  63. </tr>
  64. </thead>
  65. <tbody>
  66. <?php
  67. $currentReihe = "";
  68. foreach ($spiele as $sp):
  69. if ($currentReihe !== $sp['reihe_name']):
  70. $currentReihe = $sp['reihe_name'];
  71. ?>
  72. <tr>
  73. <td colspan="<?= count($spieler) + 1 ?>" class="reihe-divider">
  74. <?= htmlspecialchars($currentReihe ?: 'Sonstige') ?>
  75. </td>
  76. </tr>
  77. <?php endif; ?>
  78. <tr>
  79. <td>
  80. <strong><?= htmlspecialchars($sp['titel']) ?></strong><br>
  81. <small style="opacity:0.6"><?= htmlspecialchars($sp['typ_name']) ?></small>
  82. </td>
  83. <?php foreach ($spieler as $s):
  84. $curr = $statusMapping[$sp['id']][$s['id']] ?? 'nicht besitzt';
  85. ?>
  86. <td>
  87. <form method="POST">
  88. <input type="hidden" name="update_status" value="1">
  89. <input type="hidden" name="spieler_id" value="<?= $s['id'] ?>">
  90. <input type="hidden" name="spiel_id" value="<?= $sp['id'] ?>">
  91. <select name="status" onchange="this.form.submit()" data-status="<?= $curr ?>">
  92. <option value="besitzt" <?= $curr=='besitzt'?'selected':'' ?>>Besitzt</option>
  93. <option value="nicht besitzt" <?= $curr=='nicht besitzt'?'selected':'' ?>>Nicht</option>
  94. <option value="verkauft" <?= $curr=='verkauft'?'selected':'' ?>>Verkauft</option>
  95. </select>
  96. </form>
  97. </td>
  98. <?php endforeach; ?>
  99. </tr>
  100. <?php endforeach; ?>
  101. </tbody>
  102. </table>
  103. </div>
  104. <script>
  105. function toggleTheme() {
  106. const isDark = document.documentElement.classList.toggle('dark-theme');
  107. localStorage.setItem('theme', isDark ? 'dark' : 'light');
  108. document.getElementById('theme-icon').innerText = isDark ? '☀️' : '🌙';
  109. }
  110. if (localStorage.getItem('theme') === 'dark') {
  111. document.documentElement.classList.add('dark-theme');
  112. document.getElementById('theme-icon').innerText = '☀️';
  113. }
  114. </script>
  115. </body>
  116. </html>