Skip to content

Commit

Permalink
refactor multiplayer and singleplayer questions in one file
Browse files Browse the repository at this point in the history
  • Loading branch information
pelazas committed Apr 27, 2024
1 parent df380ad commit 6a86f78
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 181 deletions.
Original file line number Diff line number Diff line change
@@ -1,20 +1,24 @@
import { FC, useEffect, useMemo, useState } from 'react'
import { Player, Question4Answers } from './GameSinglePlayer'
import { FC, useCallback, useEffect, useMemo, useState } from 'react'
import { Player, Question4Answers } from './singleplayer/GameSinglePlayer'
import axios from 'axios';
import shuffleAnswers from '../util/SuffleAnswers';
import calculatePoints from '../util/CalculatePoints';
import shuffleAnswers from './util/SuffleAnswers';
import calculatePoints from './util/CalculatePoints';
import { SocketProps } from './multiplayer/GameMultiPlayer';
import "./QuestionsGame.scss"

interface PlayingGameProps {
questions: Question4Answers[]
setCurrentStage: (n: number) => void;
setPlayers: (players:Player[]) => void;
players: Player[];

setPlayers?: (players:Player[]) => void;
players?: Player[];
socket?: SocketProps;
partyCode?: string;
}

const PlayingGame: FC<PlayingGameProps> = ({questions, setCurrentStage, setPlayers, players}) => {
const PlayingGame: FC<PlayingGameProps> = ({questions, setCurrentStage, setPlayers, players, socket, partyCode}) => {

const uuid = localStorage.getItem("userUUID");
//const apiEndpoint = 'http://conoceryvencer.xyz:8000'
const apiEndpoint = process.env.REACT_APP_API_ENDPOINT || 'http://localhost:8000';

const [currentQuestion, setCurrentQuestion] = useState(0);
Expand All @@ -26,8 +30,42 @@ const PlayingGame: FC<PlayingGameProps> = ({questions, setCurrentStage, setPlaye

const answersShuffled = useMemo(() => shuffleAnswers(questions), [questions]);

const endGame = useCallback(async () => {
const totalPoints = calculatePoints(correctAnswers, questions.length);
const requestData = {
"players": [{
"uuid": uuid,
"nCorrectAnswers": correctAnswers,
"nWrongAnswers": questions.length - correctAnswers,
"totalScore": totalPoints,
"isWinner": false
}]
};

const previousScore = parseInt(localStorage.getItem("score"));
localStorage.setItem("score", (previousScore + totalPoints).toString());

await axios.post(`${apiEndpoint}/updateStats`, requestData);
if(players){
players.map(player => {
const randomPoints = Math.floor(Math.random() * (1000 - 100 + 1) / 50) * 50 + 100;
if(player.isBot){
player.points += randomPoints;
}else {
player.points += calculatePoints(correctAnswers, questions.length);
}
return player;
})
setPlayers(players);
setCurrentStage(3);
}
if(socket)
socket.emit('playerFinished', partyCode, totalPoints);

}, [correctAnswers, questions.length, uuid, apiEndpoint, socket, partyCode, players, setPlayers, setCurrentStage]);

useEffect(() => {
const intervalId = setInterval(() => {
const intervalId = setInterval(async () => {
if((currentQuestion+1) < questions.length){
if (seconds > 0) {
setSeconds(prevSeconds => prevSeconds - 1);
Expand All @@ -36,12 +74,15 @@ const PlayingGame: FC<PlayingGameProps> = ({questions, setCurrentStage, setPlaye
setSelectedAnswer(null);
clearInterval(intervalId);
setSeconds(10);
if(currentQuestion+2 === questions.length && partyCode){ // is multiplayer
await endGame()
}
}
}
}, 1000);

return () => clearInterval(intervalId);
}, [seconds, currentQuestion, questions]);
}, [seconds, currentQuestion, questions, partyCode, endGame]);

const handleAnswerClick = async (answer: string, isCorrect:boolean) => {
setSeconds(10);
Expand All @@ -58,39 +99,12 @@ const PlayingGame: FC<PlayingGameProps> = ({questions, setCurrentStage, setPlaye
}, 1000);
setIsWaiting(false);
}
if(currentQuestion+2 === questions.length && partyCode){
await endGame();
}

};

const finishGame = async() => {
const totalPoints = calculatePoints(correctAnswers, questions.length);
// the player has finished the game
// update stats for each player
players.map(player => {
const randomPoints = Math.floor(Math.random() * (1000 - 100 + 1) / 50) * 50 + 100;
if(player.isBot){
player.points += randomPoints;
}else {
player.points += calculatePoints(correctAnswers, questions.length);
}
return player;
})
setPlayers(players);

const requestData ={ "players": [{
"uuid": uuid,
"nCorrectAnswers": correctAnswers,
"nWrongAnswers": questions.length - correctAnswers,
"totalScore": totalPoints,
"isWinner": false
}]}

// update score in localstorage
const previousScore = parseInt(localStorage.getItem("score"))
localStorage.setItem("score", (previousScore + totalPoints).toString())
setCurrentStage(3);
await axios.post(`${apiEndpoint}/updateStats`, requestData);
}

const getAnswers = () => {
const answers = answersShuffled[currentQuestion];
if (answers.length > 4) {
Expand Down Expand Up @@ -131,7 +145,8 @@ const PlayingGame: FC<PlayingGameProps> = ({questions, setCurrentStage, setPlaye
<>
<p data-testid="result">You answered {correctAnswers} out of {questions.length} questions correctly.</p>
<p data-testid="points">You earned {calculatePoints(correctAnswers, questions.length)} points.</p>
<button onClick={() => finishGame()} data-testid="next-button">Next</button>
{partyCode && <p data-testid="waiting">Waiting for the rest of the players to finish...</p>}
{players &&<button onClick={() => endGame()} data-testid="next-button">Next</button>}
</>
)}
</div>
Expand Down
4 changes: 2 additions & 2 deletions webapp/src/components/game/multiplayer/GameMultiPlayer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@ import MenuMultiplayer from './MenuMultiplayer';
import { Container } from '@mui/material';
import LobbyMultiPlayer from './LobbyMultiPlayer';
import { Question4Answers } from '../singleplayer/GameSinglePlayer';
import QuestionsMultiPlayer from './QuestionsMultiPlayer';
import ScoreboardGame from '../ScoreboardGame';
import PlayingGame from '../PlayingGame';

interface GameMultiPlayerProps {

Expand Down Expand Up @@ -114,7 +114,7 @@ const GameMultiPlayer: FC<GameMultiPlayerProps> = () => {
<Container sx={{ mt: 9 }}>
{stage === 1 && <MenuMultiplayer socket={socket} handleCurrentStage={handleCurrentStage} handlePartyCode={handlePartyCode}/>}
{stage === 2 && <LobbyMultiPlayer socket={socket} handleCurrentStage={handleCurrentStage} partyCode={partyCode} users={users}/>}
{stage === 3 && <QuestionsMultiPlayer socket={socket} handleCurrentStage={handleCurrentStage} questions={questions} partyCode={partyCode}/>}
{stage === 3 && <PlayingGame socket={socket} setCurrentStage={handleCurrentStage} questions={questions} partyCode={partyCode}/>}
{stage === 4 && <ScoreboardGame userScoresMultiPlayer={sortedUsersByPoints}/>}
</Container>
)
Expand Down
137 changes: 0 additions & 137 deletions webapp/src/components/game/multiplayer/QuestionsMultiPlayer.tsx

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import axios from 'axios';
import { useState, useEffect } from 'react';
import LobbyGame from './LobbyGameSinglePlayer';
import PlayingGame from './PlayingGameSinglePlayer';
import PlayingGame from '../PlayingGame';
import ScoreboardGame from '../ScoreboardGame';
import { Container } from '@mui/material';

Expand Down

0 comments on commit 6a86f78

Please sign in to comment.