wrapped all team data in a single object and socket message

This commit is contained in:
Quentin Roussel
2024-03-29 02:03:43 +01:00
parent 11a62dfb54
commit 00e8959173
5 changed files with 49 additions and 15 deletions

View File

@@ -3,16 +3,28 @@
import { useSocket } from "@/context/socketContext";
import { useTeamConnexion } from "@/context/teamConnexionContext";
import { useTeamContext } from "@/context/teamContext";
import { useEffect } from "react";
export default function useGame() {
const {teamSocket} = useSocket();
const {teamId} = useTeamConnexion();
const {currentPosition, enemyPosition, gameState} = useTeamContext();
const { teamSocket } = useSocket();
const { teamId } = useTeamConnexion();
const { teamInfos, gameState } = useTeamContext();
function sendCurrentPosition() {
teamSocket.emit("send_position");
}
useEffect(() => console.log("teamInfos", teamInfos), [teamInfos]);
return { sendCurrentPosition, enemyPosition, currentPosition, teamId, gameState};
return {
sendCurrentPosition,
enemyPosition: teamInfos?.enemyLocation || null,
currentPosition: teamInfos?.currentLocation || null,
startingArea: teamInfos?.startingArea || null,
captureCode: teamInfos?.captureCode || null,
name: teamInfos?.name || null,
teamId,
gameState,
};
}

View File

@@ -1,8 +1,8 @@
import { useState } from "react";
import { useEffect} from "react";
export function useSocketListener(socket, event, callback) {
return useState(() => {
socket.on(event, callback);
useEffect(() => {
socket.on(event,callback);
return () => {
socket.off(event, callback);
}