Refactor score display
This commit is contained in:
parent
4721b8d68c
commit
8a839555c6
1 changed files with 27 additions and 15 deletions
42
src/game.jsx
42
src/game.jsx
|
@ -67,8 +67,26 @@ const GridButton = ({ onClick, symbol, turn, disabled, won }) => {
|
||||||
};
|
};
|
||||||
|
|
||||||
export default ({ players }) => {
|
export default ({ players }) => {
|
||||||
const [score, updateScore] = useImmer({ X: 0, O: 0, ties: 0 });
|
const initialScore = {
|
||||||
|
X: {
|
||||||
|
value: 0,
|
||||||
|
display: `X (${players.X})`,
|
||||||
|
bg: "bg-blue-700",
|
||||||
|
},
|
||||||
|
ties: {
|
||||||
|
value: 0,
|
||||||
|
display: "ties",
|
||||||
|
bg: "bg-silver-700",
|
||||||
|
},
|
||||||
|
O: {
|
||||||
|
value: 0,
|
||||||
|
display: `O (${players.O})`,
|
||||||
|
bg: "bg-yellow-700",
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
const [grid, updateGrid] = useImmer(Array(9).fill(""));
|
const [grid, updateGrid] = useImmer(Array(9).fill(""));
|
||||||
|
const [score, updateScore] = useImmer(initialScore);
|
||||||
|
|
||||||
const [restartModal, setRestartModal] = useState(false);
|
const [restartModal, setRestartModal] = useState(false);
|
||||||
const [roundModal, setRoundModal] = useState(false);
|
const [roundModal, setRoundModal] = useState(false);
|
||||||
|
@ -111,9 +129,9 @@ export default ({ players }) => {
|
||||||
const nextRound = () => {
|
const nextRound = () => {
|
||||||
updateScore((score) => {
|
updateScore((score) => {
|
||||||
if (winner) {
|
if (winner) {
|
||||||
score[winner]++;
|
score[winner].value++;
|
||||||
} else {
|
} else {
|
||||||
score.ties++;
|
score.ties.value++;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -160,18 +178,12 @@ export default ({ players }) => {
|
||||||
</main>
|
</main>
|
||||||
|
|
||||||
<footer className="center flex-row justify-between text-navy-700">
|
<footer className="center flex-row justify-between text-navy-700">
|
||||||
<div className="center h-20 w-36 rounded-2xl bg-blue-700">
|
{Object.values(score).map((value) => (
|
||||||
<p className="text-base uppercase">X ({players.X})</p>
|
<div className={`center h-20 w-36 rounded-2xl ${value.bg}`}>
|
||||||
<p className="text-h-m uppercase">{score.X}</p>
|
<p className="text-base uppercase">{value.display}</p>
|
||||||
</div>
|
<p className="text-h-m uppercase">{value.value}</p>
|
||||||
<div className="center h-20 w-36 rounded-2xl bg-silver-700">
|
</div>
|
||||||
<p className="text-base uppercase">Ties</p>
|
))}
|
||||||
<p className="text-h-m uppercase">{score.ties}</p>
|
|
||||||
</div>
|
|
||||||
<div className="center h-20 w-36 rounded-2xl bg-yellow-700">
|
|
||||||
<p className="text-base uppercase">O ({players.O})</p>
|
|
||||||
<p className="text-h-m uppercase">{score.O}</p>
|
|
||||||
</div>
|
|
||||||
</footer>
|
</footer>
|
||||||
</div>
|
</div>
|
||||||
<Modal
|
<Modal
|
||||||
|
|
Reference in a new issue