diff --git a/API/Services/GameManager/GameManager.cs b/API/Services/GameManager/GameManager.cs index f6f7ad6..6efa140 100644 --- a/API/Services/GameManager/GameManager.cs +++ b/API/Services/GameManager/GameManager.cs @@ -131,27 +131,28 @@ public class GameManager(IGameRepository gameRepository, IHubContext { - await Task.Delay(delay); - - var g = gameRepository.GetOne(gameId); - if (g != null && g.State != GameState.Running) + try { - gameRepository.Destroy(gameId); + await Task.Delay(delay); - await hubContext.Clients.Group(gameId).SendAsync("GameDestroyed"); + var g = gameRepository.GetOne(gameId); + if (g == null) + return; + + if (g.State != GameState.Running || g.Players.Count == 0) + { + gameRepository.Destroy(gameId); + await hubContext.Clients.Group(gameId).SendAsync("GameDestroyed"); + } + + Console.WriteLine($"Scheduled deletion of game {gameId} executed. {gameRepository.GetAll().Count}"); + } + catch (Exception ex) + { + Console.WriteLine($"Error deleting game {gameId}: {ex}"); } }); } diff --git a/GUI/src/components/GameCreationMenu.vue b/GUI/src/components/GameCreationMenu.vue index f047dda..c5fc0e6 100644 --- a/GUI/src/components/GameCreationMenu.vue +++ b/GUI/src/components/GameCreationMenu.vue @@ -34,6 +34,7 @@ function gameFieldPreset(x: number, y: number) { required > -import { computed } from 'vue'; +import { computed, ref } from 'vue'; import type { GameEnded } from '@/scripts/logic/signalR/GameConnection'; -defineEmits(['restartGame']); +const emit = defineEmits(['restartGame']); const props = defineProps<{ gameEndedInformation: GameEnded | null }>(); +const restarted = ref(false); const message = computed(() => { + if(restarted.value) { + return 'Das Spiel wird neugestartet...'; + } switch (props.gameEndedInformation?.method) { case 'PlayerDisconnected': return `Bei dem Spieler ${props.gameEndedInformation.player?.name} ist die Verbindung abgebrochen :(`; @@ -18,6 +22,12 @@ const message = computed(() => { return ''; } }); + +function restartClicked() { + emit('restartGame'); + + restarted.value = true; +}