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

@@ -1,7 +1,8 @@
"use client"; "use client";
import ActionDrawer from '@/components/team/actionDrawer'; import ActionDrawer from '@/components/team/actionDrawer';
import { useTeamConnexion } from '@/context/teamConnexionContext'; import { useTeamConnexion } from '@/context/teamConnexionContext';
import useGame, { GameState } from '@/hook/useGame'; import useGame from '@/hook/useGame';
import { GameState } from '@/util/gameState';
import dynamic from 'next/dynamic'; import dynamic from 'next/dynamic';
import React from 'react' import React from 'react'
@@ -16,7 +17,7 @@ export default function Track() {
useProtect(); useProtect();
return ( return (
gameState == GameState.PLAYING && <div className='h-full'> gameState == GameState.PLAYING && <div className='h-full'>
<LiveMap currentPosition={currentPosition} enemyPosition={enemyPosition} /> <LiveMap />
<ActionDrawer /> <ActionDrawer />
</div> </div>
) )

View File

@@ -26,6 +26,9 @@ function MapPan(props) {
export default function LiveMap({ ...props}) { export default function LiveMap({ ...props}) {
const {currentPosition, enemyPosition} = useGame(); const {currentPosition, enemyPosition} = useGame();
useEffect(() => {
console.log('Current position', currentPosition);
}, [currentPosition]);
return ( return (
<MapContainer {...props} className='min-h-full z-0' center={[0,0]} zoom={0} scrollWheelZoom={true}> <MapContainer {...props} className='min-h-full z-0' center={[0,0]} zoom={0} scrollWheelZoom={true}>
<TileLayer <TileLayer
@@ -58,3 +61,16 @@ export default function LiveMap({ ...props}) {
</MapContainer> </MapContainer>
) )
} }
export function PlacementMap({ ...props}) {
const {currentPosition, startingArea} = useGame();
return (
<MapContainer {...props} className='min-h-full w-full' scrollWheelZoom={true}>
<TileLayer
attribution='&copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
/>
<MapPan center={currentPosition}/>
</MapContainer>
)
}

View File

@@ -1,23 +1,28 @@
"use client"; "use client";
import { useLocation } from "@/hook/useLocation"; import { useLocation } from "@/hook/useLocation";
import { useSocketListener } from "@/hook/useSocketListener"; import { useSocketListener } from "@/hook/useSocketListener";
import { createContext, useContext, useEffect, useMemo, useState } from "react"; import { createContext, useContext, useEffect, useMemo, useRef, useState } from "react";
import { useSocket } from "./socketContext"; import { useSocket } from "./socketContext";
import { useTeamConnexion } from "./teamConnexionContext"; import { useTeamConnexion } from "./teamConnexionContext";
import { GameState } from "@/util/gameState";
const teamContext = createContext() const teamContext = createContext()
function TeamProvider({children}) { function TeamProvider({children}) {
const [enemyPosition, setEnemyPosition] = useState(); const [teamInfos, setTeamInfos] = useState({});
const [currentPosition, setCurrentPosition] = useState();
const [gameState, setGameState] = useState(GameState.SETUP); const [gameState, setGameState] = useState(GameState.SETUP);
const measuredLocation = useLocation(10000); const measuredLocation = useLocation(10000);
const {teamSocket} = useSocket(); const {teamSocket} = useSocket();
const {loggedIn} = useTeamConnexion(); const {loggedIn} = useTeamConnexion();
const teamInfosRef = useRef();
teamInfosRef.current = teamInfos;
useSocketListener(teamSocket, "update_team", (newTeamInfos) => {
setTeamInfos({...teamInfosRef.current, ...newTeamInfos});
});
useSocketListener(teamSocket, "game_state", setGameState); useSocketListener(teamSocket, "game_state", setGameState);
useSocketListener(teamSocket, "enemy_position", setEnemyPosition);
useSocketListener(teamSocket, "live_location", setCurrentPosition);
//Send the current position to the server when the user is logged in //Send the current position to the server when the user is logged in
useEffect(() => { useEffect(() => {
@@ -27,7 +32,7 @@ function TeamProvider({children}) {
} }
}, [loggedIn, measuredLocation]); }, [loggedIn, measuredLocation]);
const value = useMemo(() => ({enemyPosition, currentPosition, gameState}), [enemyPosition, currentPosition, gameState]); const value = useMemo(() => ({teamInfos, gameState}), [teamInfos, gameState]);
return ( return (
<teamContext.Provider value={value}> <teamContext.Provider value={value}>
{children} {children}

View File

@@ -3,16 +3,28 @@
import { useSocket } from "@/context/socketContext"; import { useSocket } from "@/context/socketContext";
import { useTeamConnexion } from "@/context/teamConnexionContext"; import { useTeamConnexion } from "@/context/teamConnexionContext";
import { useTeamContext } from "@/context/teamContext"; import { useTeamContext } from "@/context/teamContext";
import { useEffect } from "react";
export default function useGame() { export default function useGame() {
const { teamSocket } = useSocket(); const { teamSocket } = useSocket();
const { teamId } = useTeamConnexion(); const { teamId } = useTeamConnexion();
const {currentPosition, enemyPosition, gameState} = useTeamContext(); const { teamInfos, gameState } = useTeamContext();
function sendCurrentPosition() { function sendCurrentPosition() {
teamSocket.emit("send_position"); 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,7 +1,7 @@
import { useState } from "react"; import { useEffect} from "react";
export function useSocketListener(socket, event, callback) { export function useSocketListener(socket, event, callback) {
return useState(() => { useEffect(() => {
socket.on(event,callback); socket.on(event,callback);
return () => { return () => {
socket.off(event, callback); socket.off(event, callback);