Skip to content

Commit

Permalink
Merge pull request #73 from hufs-sports-live/chore/game-type
Browse files Browse the repository at this point in the history
[CHORE] api 변경에 따른 타입 및 관련 컴포넌트 변경
  • Loading branch information
seongminn authored Nov 22, 2023
2 parents 6ac8c11 + 325208e commit c7e983c
Show file tree
Hide file tree
Showing 8 changed files with 43 additions and 36 deletions.
12 changes: 6 additions & 6 deletions src/components/common/Game/index.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import GameWrapper from './GameWrapper';
import Label from './Label';
import Score from './Score';
import Status from './Status';
import Team from './Team';
import GameWrapper from './pieces/GameWrapper';
import Label from './pieces/Label';
import Score from './pieces/Score';
import Status from './pieces/Status';
import Team from './pieces/Team';

export const Game = Object.assign(GameWrapper, {
export const GameBanner = Object.assign(GameWrapper, {
Label,
Score,
Status,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,7 @@ type GameProps = GameDetailType & {
className?: string;
};

export const GameContext = createContext<null | GameDetailType>(
{} as GameDetailType,
);
export const GameContext = createContext<GameDetailType>({} as GameDetailType);

export default function GameWrapper({
className,
Expand All @@ -19,7 +17,14 @@ export default function GameWrapper({
}: GameProps) {
return (
<GameContext.Provider value={props}>
<div className={$(className)}>{children}</div>
<div
className={$(
'relative h-full min-h-[200px] justify-center rounded-xl bg-gray-1 shadow-lg',
className,
)}
>
{children}
</div>
</GameContext.Provider>
);
}
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ type LabelProps = {
};

export default function Label({ className }: LabelProps) {
const { name } = useGameContext();
const { gameName } = useGameContext();

return <div className={$(className)}>{name}</div>;
return <div className={$(className)}>{gameName}</div>;
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,9 @@ type ScoreProps = {
};

export default function Score({ teamIndex, className }: ScoreProps) {
const { firstTeamScore, secondTeamScore } = useGameContext();
const { gameTeams } = useGameContext();

return (
<span className={$(className)}>
{teamIndex === 1 ? firstTeamScore : secondTeamScore}
</span>
);
const [targetTeam] = gameTeams.filter(team => team.gameTeamId === teamIndex);

return <span className={$('text-3xl', className)}>{targetTeam.score}</span>;
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import { GAME_STATUS } from '@/constants/gameStatus';
import { useGameContext } from '@/hooks/useGameContext';
import { $ } from '@/utils/core';

Expand All @@ -7,7 +6,7 @@ type StatusProps = {
};

export default function Status({ className }: StatusProps) {
const { gameStatus } = useGameContext();
const { gameQuarter } = useGameContext();

return <div className={$(className)}>{GAME_STATUS[gameStatus]}</div>;
return <div className={$('px-5', className)}>{gameQuarter}</div>;
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,19 +9,20 @@ type TeamProps = {
};

export default function Team({ teamIndex, className }: TeamProps) {
const { firstTeam, secondTeam } = useGameContext();
const { gameTeams } = useGameContext();

const targetTeamInfo = teamIndex === 1 ? firstTeam : secondTeam;
const targetTeamInfo = gameTeams[teamIndex - 1];

return (
<div className={$(className)}>
<Image
width="100"
height="100"
width="65"
height="65"
src={targetTeamInfo.logoImageUrl}
alt={`${targetTeamInfo.name}팀 로고`}
alt={`${targetTeamInfo.gameTeamName}팀 로고`}
className="my-5"
/>
<span>{targetTeamInfo.name}</span>
<span>{targetTeamInfo.gameTeamName}</span>
</div>
);
}
2 changes: 1 addition & 1 deletion src/hooks/useGameContext.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { useContext } from 'react';

import { GameContext } from '@/components/common/Game/GameWrapper';
import { GameContext } from '@/components/common/Game/pieces/GameWrapper';
import { GameDetailType } from '@/types/game';

type GameContextType = () => GameDetailType;
Expand Down
20 changes: 12 additions & 8 deletions src/types/game.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,21 +5,25 @@ export type GameType = {
startTime: string;
firstTeamScore: number;
secondTeamScore: number;
gameStatus: GameStatusType;
gameStatus: GameQuarterType;
statusChangedAt: string;
firstTeam: GameTeamType;
secondTeam: GameTeamType;
};

export interface GameDetailType extends GameType {
records: GameRecordType[];
videoId: string;
}
export type GameDetailType = {
gameTeams: GameTeamType[];
startTime: string;
videoId: number;
gameQuarter: GameQuarterType;
gameName: string;
};

export type GameTeamType = {
id: number;
name: string;
gameTeamId: number;
gameTeamName: string;
logoImageUrl: string;
score: number;
};

export type GameRecordType = {
Expand All @@ -37,7 +41,7 @@ export type GameCommentType = {
isBlocked: boolean;
};

export type GameStatusType =
export type GameQuarterType =
| 'BEFORE'
| 'FIRST_HALF'
| 'BREAK_TIME'
Expand Down

0 comments on commit c7e983c

Please sign in to comment.