import { useEffect, useState } from 'react'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' import axios from 'axios'; export default function Helpers({ gameid, user, token }) { const [helpers, setHelpers] = useState([]); const [gameLoading, setGameLoading] = useState(true); const [helping, setHelping] = useState(); useEffect(() => { async function fetchGame() { const response = await axios.post("/api/v1/games/getHelpers", { token, gameid }) .catch((error) => console.error("Error getting game")); setHelpers(response.data); setHelping(JSON.stringify(response.data).includes(user.id)); setGameLoading(false); } fetchGame(); }, [gameid, helping]); function addHelper() { axios.post("/api/v1/games/addHelper", { token, gameid }) .then(() => setHelping(true)) .catch((error) => console.error("Error adding helper")); } function removeHelper() { axios.post("/api/v1/games/removeHelper", { token, gameid }) .then(() => setHelping(false)) .catch((error) => console.error("Error removing helper")); } function handleClick(event) { if (helping) { removeHelper(); } else { addHelper(); } } if (gameLoading) { return

Loading...

} else if (helpers.length === 0) { return (

Personne

) } else { return (
{helpers.map((helper) => { if (helper.user_id === user.id) { return

Vous

} else { return

{helper.name}

} })}
) } }