add game lists
This commit is contained in:
@@ -136,4 +136,67 @@ body {
|
||||
@media (max-width: 600px) {
|
||||
.yahtzee-table { border-radius: 40px; padding: 20px; }
|
||||
.neon-dice { font-size: 2.2rem; }
|
||||
}
|
||||
|
||||
/* Style des lignes de parties */
|
||||
.game-item-row {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
background: rgba(26, 42, 108, 0.4); /* Bleu nuit transparent */
|
||||
border: 1px solid rgba(212, 175, 55, 0.3); /* Bordure dorée subtile */
|
||||
margin-bottom: 15px;
|
||||
padding: 15px 25px;
|
||||
border-radius: 15px;
|
||||
transition: all 0.3s ease;
|
||||
}
|
||||
|
||||
.game-item-row:hover {
|
||||
background: rgba(26, 42, 108, 0.7);
|
||||
transform: translateX(5px);
|
||||
border-color: var(--gold, #d4af37);
|
||||
box-shadow: 0 0 15px rgba(212, 175, 55, 0.2);
|
||||
}
|
||||
|
||||
.game-info {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.game-name {
|
||||
font-size: 1.2rem;
|
||||
font-weight: bold;
|
||||
color: #fff;
|
||||
text-transform: uppercase;
|
||||
}
|
||||
|
||||
.game-players-count {
|
||||
font-size: 0.9rem;
|
||||
color: var(--gold, #d4af37);
|
||||
}
|
||||
|
||||
/* Bouton rejoindre */
|
||||
.btn-join {
|
||||
background: transparent;
|
||||
border: 2px solid #ff3131; /* Rouge néon */
|
||||
color: #ff3131;
|
||||
padding: 8px 20px;
|
||||
border-radius: 20px;
|
||||
cursor: pointer;
|
||||
font-weight: bold;
|
||||
text-transform: uppercase;
|
||||
transition: all 0.3s;
|
||||
}
|
||||
|
||||
.btn-join:hover {
|
||||
background: #ff3131;
|
||||
color: #fff;
|
||||
box-shadow: 0 0 15px rgba(255, 49, 49, 0.6);
|
||||
}
|
||||
|
||||
.placeholder-text {
|
||||
font-style: italic;
|
||||
opacity: 0.5;
|
||||
padding: 20px;
|
||||
}
|
||||
@@ -0,0 +1,42 @@
|
||||
async function SqlRequest(action, params = {}) {
|
||||
try {
|
||||
const response = await fetch('RequestsHandler.php', {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({ action: action, params: params })
|
||||
});
|
||||
return await response.json();
|
||||
} catch (erreur) {
|
||||
console.error("Erreur de communication :", erreur);
|
||||
}
|
||||
}
|
||||
|
||||
document.addEventListener('DOMContentLoaded', async () => {
|
||||
const gamesListContainer = document.getElementById('games_list');
|
||||
|
||||
// On récupère les parties via le handler
|
||||
const result = await SqlRequest('get_all_games');
|
||||
|
||||
if (result && result.success && result.games.length > 0) {
|
||||
// On vide le placeholder
|
||||
gamesListContainer.innerHTML = '';
|
||||
|
||||
result.games.forEach(game => {
|
||||
const gameElement = document.createElement('div');
|
||||
gameElement.className = 'game-item-row';
|
||||
|
||||
gameElement.innerHTML = `
|
||||
<div class="game-info">
|
||||
<span class="game-name">${game.game_name}</span>
|
||||
<span class="game-players-count">${game.nb_players} Joueurs</span>
|
||||
</div>
|
||||
<button class="btn-join" onclick="window.location.href='game/index.html?game_id=${game.id}'">
|
||||
Rejoindre
|
||||
</button>
|
||||
`;
|
||||
gamesListContainer.appendChild(gameElement);
|
||||
});
|
||||
} else {
|
||||
gamesListContainer.innerHTML = '<p class="placeholder-text">Aucune table ouverte pour le moment...</p>';
|
||||
}
|
||||
});
|
||||
Reference in New Issue
Block a user