mirror of
https://github.com/Vikeo/LifeTrinket.git
synced 2025-11-19 09:18:02 +00:00
Feature/game score tracking (#48)
This commit is contained in:
71
src/Components/ScoreDisplay/ScoreDisplay.tsx
Normal file
71
src/Components/ScoreDisplay/ScoreDisplay.tsx
Normal file
@@ -0,0 +1,71 @@
|
||||
import { twc } from 'react-twc';
|
||||
import { Player } from '../../Types/Player';
|
||||
import { GameScore } from '../../Contexts/GlobalSettingsContext';
|
||||
|
||||
const ScoreContainer = twc.div`
|
||||
absolute bottom-4 left-1/2 -translate-x-1/2
|
||||
bg-background-default/90 backdrop-blur-sm
|
||||
rounded-lg p-4
|
||||
shadow-lg
|
||||
z-40
|
||||
min-w-[200px]
|
||||
`;
|
||||
|
||||
const Title = twc.h3`
|
||||
text-sm font-semibold text-text-secondary
|
||||
uppercase tracking-wide mb-3
|
||||
`;
|
||||
|
||||
const ScoreList = twc.div`
|
||||
flex flex-col gap-2
|
||||
`;
|
||||
|
||||
const ScoreItem = twc.div`
|
||||
flex items-center justify-between gap-4
|
||||
`;
|
||||
|
||||
const PlayerInfo = twc.div`
|
||||
flex items-center gap-2
|
||||
`;
|
||||
|
||||
const PlayerColor = twc.div`
|
||||
w-4 h-4 rounded-full
|
||||
`;
|
||||
|
||||
const PlayerName = twc.span`
|
||||
text-text-primary font-medium
|
||||
`;
|
||||
|
||||
const Score = twc.span`
|
||||
text-text-primary font-bold text-lg
|
||||
`;
|
||||
|
||||
type ScoreDisplayProps = {
|
||||
players: Player[];
|
||||
gameScore: GameScore;
|
||||
};
|
||||
|
||||
export const ScoreDisplay = ({ players, gameScore }: ScoreDisplayProps) => {
|
||||
const hasAnyScore = Object.values(gameScore).some((score) => score > 0);
|
||||
|
||||
if (!hasAnyScore) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return (
|
||||
<ScoreContainer>
|
||||
<Title>Match Score</Title>
|
||||
<ScoreList>
|
||||
{players.map((player) => (
|
||||
<ScoreItem key={player.index}>
|
||||
<PlayerInfo>
|
||||
<PlayerColor style={{ backgroundColor: player.color }} />
|
||||
<PlayerName>{player.name || `Player ${player.index + 1}`}</PlayerName>
|
||||
</PlayerInfo>
|
||||
<Score>{gameScore[player.index] || 0}</Score>
|
||||
</ScoreItem>
|
||||
))}
|
||||
</ScoreList>
|
||||
</ScoreContainer>
|
||||
);
|
||||
};
|
||||
Reference in New Issue
Block a user