besitz.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. <?php
  2. require_once 'db_config.php';
  3. $msg = "";
  4. // Status-Update Logik
  5. if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['update_status'])) {
  6. $stmt = $pdo->prepare("INSERT INTO besitzstatus (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. $spieler = $pdo->query("SELECT * FROM spieler ORDER BY name ASC")->fetchAll();
  13. $spiele = $pdo->query("SELECT s.*, t.bezeichnung as typ_name FROM spiele s LEFT JOIN game_typen t ON s.typ_id = t.id ORDER BY s.titel ASC")->fetchAll();
  14. ?>
  15. <!DOCTYPE html>
  16. <html lang="de">
  17. <head>
  18. <meta charset="UTF-8">
  19. <title>EXIT - Bestandsverwaltung</title>
  20. <style>
  21. /* THEME VARIABLEN */
  22. :root {
  23. --bg: #f4f7f6; --card: #ffffff; --text: #333; --border: #ddd; --accent: #e67e22;
  24. --table-head: #f8f9fa;
  25. }
  26. .dark-theme {
  27. --bg: #121212; --card: #1e1e1e; --text: #e0e0e0; --border: #333;
  28. --table-head: #2a2a2a;
  29. }
  30. body { font-family: 'Segoe UI', sans-serif; background: var(--bg); color: var(--text); padding: 20px; transition: 0.3s; }
  31. .container { max-width: 1200px; margin: auto; }
  32. header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
  33. h1 { color: var(--accent); margin: 0; }
  34. .alert { background: #27ae60; color: white; padding: 10px; border-radius: 5px; margin-bottom: 20px; text-align: center; transition: opacity 0.5s; }
  35. table { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 8px; overflow: hidden; border: 1px solid var(--border); }
  36. th, td { padding: 12px; border-bottom: 1px solid var(--border); text-align: left; }
  37. th { background: var(--table-head); color: var(--accent); text-transform: uppercase; font-size: 0.85em; }
  38. .game-info { display: flex; align-items: center; gap: 15px; }
  39. .game-info img { width: 40px; height: 40px; object-fit: cover; border-radius: 4px; border: 1px solid var(--border); }
  40. select { background: var(--card); color: var(--text); border: 1px solid var(--border); padding: 8px; border-radius: 4px; width: 100%; cursor: pointer; transition: 0.3s; }
  41. select.besitzt { border-left: 4px solid #27ae60; }
  42. select.verkauft { border-left: 4px solid #f39c12; }
  43. select.nicht { border-left: 4px solid #7f8c8d; }
  44. .back-link { color: var(--accent); text-decoration: none; font-weight: bold; border: 1px solid var(--accent); padding: 5px 15px; border-radius: 6px; }
  45. .theme-toggle { background: var(--card); border: 1px solid var(--border); color: var(--text); padding: 8px 12px; border-radius: 20px; cursor: pointer; font-size: 1.1rem; }
  46. </style>
  47. <script>
  48. if (localStorage.getItem('theme') === 'dark') document.documentElement.classList.add('dark-theme');
  49. </script>
  50. </head>
  51. <body>
  52. <div class="container">
  53. <header>
  54. <a href="index.php" class="back-link">← Dashboard</a>
  55. <div style="display: flex; align-items: center; gap: 15px;">
  56. <button onclick="toggleTheme()" class="theme-toggle" id="theme-icon">🌙</button>
  57. </div>
  58. </header>
  59. <h1>📦 Bestandsverwaltung</h1>
  60. <p style="margin-bottom: 20px; opacity: 0.7;">Wer besitzt welches Spiel?</p>
  61. <?php if ($msg): ?><div class="alert" id="msg-box"><?= $msg ?></div><?php endif; ?>
  62. <table>
  63. <thead>
  64. <tr>
  65. <th>Spiel</th>
  66. <?php foreach ($spieler as $s): ?>
  67. <th><?= htmlspecialchars($s['name']) ?></th>
  68. <?php endforeach; ?>
  69. </tr>
  70. </thead>
  71. <tbody>
  72. <?php foreach ($spiele as $sp): ?>
  73. <tr>
  74. <td>
  75. <div class="game-info">
  76. <img src="<?= htmlspecialchars($sp['bild_url'] ?: 'https://via.placeholder.com/40') ?>">
  77. <div>
  78. <strong><?= htmlspecialchars($sp['titel']) ?></strong><br>
  79. <small style="opacity: 0.6;"><?= htmlspecialchars($sp['typ_name']) ?></small>
  80. </div>
  81. </div>
  82. </td>
  83. <?php foreach ($spieler as $s):
  84. $st_stmt = $pdo->prepare("SELECT status FROM besitzstatus WHERE spieler_id = ? AND spiel_id = ?");
  85. $st_stmt->execute([$s['id'], $sp['id']]);
  86. $current = $st_stmt->fetchColumn() ?: 'nicht besitzt';
  87. $class = ($current == 'besitzt') ? 'besitzt' : (($current == 'verkauft') ? 'verkauft' : 'nicht');
  88. ?>
  89. <td>
  90. <form method="POST" style="margin:0;">
  91. <input type="hidden" name="update_status" value="1">
  92. <input type="hidden" name="spieler_id" value="<?= $s['id'] ?>">
  93. <input type="hidden" name="spiel_id" value="<?= $sp['id'] ?>">
  94. <select name="status" class="<?= $class ?>" onchange="this.form.submit()">
  95. <option value="besitzt" <?= $current == 'besitzt' ? 'selected' : '' ?>>Besitzt</option>
  96. <option value="nicht besitzt" <?= $current == 'nicht besitzt' ? 'selected' : '' ?>>Nicht</option>
  97. <option value="verkauft" <?= $current == 'verkauft' ? 'selected' : '' ?>>Verkauft</option>
  98. </select>
  99. </form>
  100. </td>
  101. <?php endforeach; ?>
  102. </tr>
  103. <?php endforeach; ?>
  104. </tbody>
  105. </table>
  106. </div>
  107. <script>
  108. function toggleTheme() {
  109. const isDark = document.documentElement.classList.toggle('dark-theme');
  110. localStorage.setItem('theme', isDark ? 'dark' : 'light');
  111. document.getElementById('theme-icon').innerText = isDark ? '☀️' : '🌙';
  112. }
  113. if (localStorage.getItem('theme') === 'dark') {
  114. document.getElementById('theme-icon').innerText = '☀️';
  115. }
  116. setTimeout(function() {
  117. var msg = document.getElementById('msg-box');
  118. if(msg) msg.style.opacity = '0';
  119. }, 2000);
  120. </script>
  121. </body>
  122. </html>