feat(api): FRO-15 Join Game (#16)

Added join game functionality

Co-authored-by: LQ63 <lkhermann@web.de>
Reviewed-on: #16
Reviewed-by: Janis <janis-e@gmx.de>
Co-authored-by: lq64 <lq@blackhole.local>
Co-committed-by: lq64 <lq@blackhole.local>
This commit is contained in:
2025-12-10 15:45:56 +01:00
committed by Janis
parent fc60234faf
commit 14e001cae6

View File

@@ -2,27 +2,37 @@
import {ref} from "vue"; import {ref} from "vue";
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
import {useQuasar} from "quasar"; import {useQuasar} from "quasar";
import axios from "axios";
const router = useRouter(); const router = useRouter();
const lobbyCode = ref(''); const lobbyCode = ref('');
const isLoading = ref(false); const isLoading = ref(false);
const $q = useQuasar(); const $q = useQuasar();
const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms)); const api = window?.__RUNTIME_CONFIG__?.API_URL;
const startGameQuasar = async() => { const startGameQuasar = async() => {
if (!lobbyCode.value) { if (!lobbyCode.value) {
$q.notify({ message: 'Lobby-Name wird benötigt', color: 'red', position: 'top', icon: 'cancel' }); $q.notify({ message: 'Lobby-Name wird benötigt', color: 'red', position: 'top', icon: 'cancel' });
return; return;
} }
isLoading.value = true; isLoading.value = true;
//TODO: Implement Logic to Start the Game and Redirect to Ingame axios.post(`${api}/joinGame`, {gameId: lobbyCode.value.toString()}, {withCredentials: true}).then(response => {
await delay(3000) const responseData = response.data
isLoading.value = false; $q.notify({
$q.notify({ message: `Lobby "${lobbyCode.value}" erfolgreich gefunden`,
message: `Lobby "${lobbyCode.value}" erfolgreich gefunden`, color: 'green-6',
color: 'green-6', icon: 'check_circle',
icon: 'check_circle', position: 'top'
position: 'top' });
}); router.push("/lobby")
router.push({ name: 'mainmenu'}); }).catch(() => {
$q.notify({
message: `Lobby "${lobbyCode.value}" nicht gefunden`,
color: 'red-6',
icon: 'cancel',
position: 'top'
})
}).finally(() =>
isLoading.value = false
)
} }
</script> </script>