import useAdmin from "@/hook/useAdmin"; import { GameState } from '@/util/gameState'; import { useEffect, useState } from "react"; import { env } from 'next-runtime-env'; function DotLine({ label, value }) { return (
{label} {value}
); } function IconValue({ color, icon, value }) { return (

{value}

); } const TEAM_STATUS = { playing: { label: "En jeu", color: "text-custom-green" }, captured: { label: "Capturée", color: "text-custom-red" }, outofzone: { label: "Hors zone", color: "text-custom-orange" }, ready: { label: "Placée", color: "text-custom-green" }, notready: { label: "Non placée", color: "text-custom-red" }, waiting: { label: "En attente", color: "text-custom-grey" }, }; function getStatus(team, gamestate) { switch (gamestate) { case GameState.SETUP: return TEAM_STATUS.waiting; case GameState.PLACEMENT: return team.ready ? TEAM_STATUS.ready : TEAM_STATUS.notready; case GameState.PLAYING: return team.captured ? TEAM_STATUS.captured : team.outofzone ? TEAM_STATUS.outofzone : TEAM_STATUS.playing; case GameState.FINISHED: return team.captured ? TEAM_STATUS.captured : TEAM_STATUS.playing; } } export default function TeamInformation({ selectedTeamId, onClose }) { const { getTeam, getTeamName, startDate, gameState } = useAdmin(); const [imgSrc, setImgSrc] = useState(""); const team = getTeam(selectedTeamId); const NO_VALUE = "XX"; const NEXT_PUBLIC_SOCKET_HOST = env("NEXT_PUBLIC_SOCKET_HOST"); const SERVER_URL = (NEXT_PUBLIC_SOCKET_HOST == "localhost" ? "http://" : "https://") + NEXT_PUBLIC_SOCKET_HOST + "/back"; useEffect(() => { setImgSrc(`${SERVER_URL}/photo/my?team=${selectedTeamId}&t=${Date.now()}`); }, [selectedTeamId]); if (!team) return null; function formatTime(startDate) { // startDate in milliseconds const date = team.captured ? team.finishDate : Date.now(); if (date == null || startDate == null || startDate < 0) return NO_VALUE + ":" + NO_VALUE; const seconds = Math.floor((date - startDate) / 1000); const m = Math.floor(seconds / 60); const s = Math.floor(seconds % 60); return `${m}:${s.toString().padStart(2, "0")}`; } function formatDistance(distance) { // distance in meters if (distance == null || distance < 0) return NO_VALUE + "km"; return `${Math.floor(distance / 100) / 10}km`; } function formatSpeed(distance, startDate) { // distance in meters | startDate in milliseconds const date = team.captured ? team.finishDate : Date.now(); if (distance == null || distance < 0 || date == null || startDate == null || date <= startDate) return NO_VALUE + "km/h"; const speed = distance / (date - startDate); return `${Math.floor(speed * 36000) / 10}km/h`; } function formatDate(date) { // date in milliseconds const dateNow = Date.now(); if (date == null || dateNow <= date || dateNow - date >= 1_000_000) return NO_VALUE + "s"; return `${Math.floor((dateNow - date) / 1000)}s`; } return (

{getStatus(team, gameState).label}

{team.name ?? NO_VALUE}

Photo de l'équipe
0 ? "green" : "red"} icon="dude" value={team.sockets.length ?? NO_VALUE} /> = 20 ? "green" : "red"} icon="battery" value={(team.battery ?? NO_VALUE) + "%"} />
); }