-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into feat/관리자-토너먼트-페이지-전적-수정을-위한-브래킷뷰#1080
- Loading branch information
Showing
14 changed files
with
299 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
import { useRecoilValue } from 'recoil'; | ||
import { modalState } from 'utils/recoil/modal'; | ||
import TournamentRegistryModal from '../tournament/TournamentRegistryModal'; | ||
|
||
export default function TournamentModal() { | ||
const { modalName, tournamentInfo } = useRecoilValue(modalState); | ||
|
||
const content: { [key: string]: JSX.Element | null } = { | ||
'TOURNAMENT-REGISTRY': tournamentInfo ? ( | ||
<TournamentRegistryModal {...tournamentInfo} /> | ||
) : null, | ||
}; | ||
|
||
if (!modalName) return null; | ||
return content[modalName]; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
import dynamic from 'next/dynamic'; | ||
import { useSetRecoilState } from 'recoil'; | ||
import { TournamentInfo } from 'types/modalTypes'; | ||
import { QUILL_FORMATS } from 'types/quillTypes'; | ||
import { modalState } from 'utils/recoil/modal'; | ||
import { | ||
ModalButtonContainer, | ||
ModalButton, | ||
} from 'components/modal/ModalButton'; | ||
import styles from 'styles/modal/event/AnnouncementModal.module.scss'; | ||
import 'react-quill/dist/quill.bubble.css'; | ||
|
||
const Quill = dynamic(() => import('react-quill'), { | ||
ssr: false, | ||
loading: () => <p>Loading ...</p>, | ||
}); | ||
|
||
export default function TournamentRegistryModal({ | ||
title, | ||
contents, | ||
startDate, | ||
status, | ||
type, | ||
winnerId, | ||
winnerImage, | ||
endDate, | ||
}: TournamentInfo) { | ||
const setModal = useSetRecoilState(modalState); | ||
|
||
const registTournament = () => { | ||
console.log('토너먼트에 등록하시겠습니까.'); | ||
}; | ||
|
||
const closeModalButtonHandler = () => { | ||
setModal({ modalName: null }); | ||
}; | ||
|
||
return ( | ||
<div className={styles.container}> | ||
<div className={styles.title}>{title}</div> | ||
<div className={styles.title}>{startDate}</div> | ||
<Quill | ||
className={styles.quillViewer} | ||
readOnly={true} | ||
formats={QUILL_FORMATS} | ||
value={contents} | ||
theme='bubble' | ||
/> | ||
<div> | ||
<ModalButtonContainer> | ||
<ModalButton | ||
onClick={closeModalButtonHandler} | ||
value='나가기' | ||
style='positive' | ||
/> | ||
</ModalButtonContainer> | ||
<ModalButtonContainer> | ||
<ModalButton | ||
onClick={registTournament} | ||
value='등록' | ||
style='positive' | ||
/> | ||
</ModalButtonContainer> | ||
</div> | ||
</div> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
import { TournamentInfo } from 'types/modalTypes'; | ||
import styles from 'styles/tournament/TournamentCard.module.scss'; | ||
|
||
export default function TournamentCard({ | ||
tournametId, | ||
title, | ||
contents, | ||
startDate, | ||
status, | ||
type, | ||
winnerId, | ||
winnerImage, | ||
endDate, | ||
}: TournamentInfo) { | ||
return ( | ||
<div className={styles.tournamentCardContainer}> | ||
<div className={styles.text}>{title}</div> | ||
</div> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
import { useSetRecoilState } from 'recoil'; | ||
import { Modal } from 'types/modalTypes'; | ||
import { modalState } from 'utils/recoil/modal'; | ||
import TournamentCard from 'components/tournament/TournamentCard'; | ||
import styles from 'styles/tournament/TournamentContainer.module.scss'; | ||
|
||
// 내부의 토너먼트 보여주는 부분만 Component화 하면될까? 다른곳에서도 쓰일까? | ||
// 진행중인 토너먼트의 Bracket을 보여주는 부분도 다른곳에서도 쓸수있지않나? | ||
const tempData = { | ||
tournaments: [ | ||
{ | ||
tournametId: 5, | ||
title: '5회 루키 토너먼트', | ||
contents: '블라블라', | ||
startDate: '2023-11-11', | ||
status: '종료', | ||
type: 'rookie', | ||
winnerId: 'hannkim', | ||
winnerImage: '', | ||
endDate: '2023-11-11', | ||
}, | ||
{ | ||
tournametId: 6, | ||
title: '6회 마스터 토너먼트', | ||
contents: '블라블라 하이하이', | ||
startDate: '2023-11-12', | ||
status: '진행중', | ||
type: 'master', | ||
winnerId: 'hannkim', | ||
winnerImage: '', | ||
endDate: '2023-11-12', | ||
}, | ||
], | ||
totalPage: 100, | ||
}; | ||
|
||
export default function Tournament() { | ||
const setModal = useSetRecoilState<Modal>(modalState); | ||
|
||
const handleTournament = () => { | ||
setModal({ | ||
modalName: 'TOURNAMENT-REGISTRY', | ||
tournamentInfo: { | ||
tournametId: 5, | ||
title: '5회 루키 토너먼트', | ||
contents: '블라블라', | ||
startDate: '2023-11-11', | ||
status: '종료', | ||
type: 'rookie', | ||
winnerId: 'hannkim', | ||
winnerImage: '', | ||
endDate: '2023-11-11', | ||
}, | ||
}); | ||
}; | ||
return ( | ||
<div className={styles.pageWrap}> | ||
<h1 className={styles.title}>Tournament</h1> | ||
<div className={styles.tournamentContainer}> | ||
<div className={styles.tournamentTextWait}> 대기중인 토너먼트 </div> | ||
<div className={styles.waitTournamentBox}> | ||
{tempData.tournaments.map((tournament, index) => ( | ||
<TournamentCard key={index} {...tournament} /> | ||
))} | ||
</div> | ||
<div className={styles.tournamentTextOpen}> 진행중인 토너먼트 </div> | ||
<div className={styles.openTournamentBox}> | ||
<div className={styles.tournamentText}> 무언가 토너먼트의 사진 </div> | ||
</div> | ||
</div> | ||
</div> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
.tournamentCardContainer { | ||
display: flex; | ||
width: 100%; | ||
padding: 1rem; | ||
margin-bottom: 1rem; | ||
background-color: black; | ||
border: 2px solid black; | ||
border-radius: 0.3rem; | ||
|
||
.text { | ||
overflow: hidden; | ||
color: white; | ||
text-overflow: ellipsis; | ||
white-space: nowrap; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
@import 'styles/common.scss'; | ||
|
||
.pageWrap { | ||
@include pageWrap; | ||
} | ||
|
||
.title { | ||
@include pageTitle; | ||
width: fit-content; | ||
cursor: pointer; | ||
} | ||
|
||
.tournamentContainer { | ||
display: flex; | ||
height: 60vh; | ||
flex-direction: column; | ||
padding: 1rem 1rem 0rem; | ||
overflow-y: scroll; | ||
background: #d4b8f2; | ||
border-radius: $small-radius; | ||
} | ||
|
||
.waitTournamentBox { | ||
display: flex; | ||
width: 100%; | ||
flex: 5; | ||
flex-direction: column; | ||
justify-content: center; | ||
align-items: center; | ||
padding: 3rem 1rem 0; | ||
overflow-x: hidden; | ||
overflow-y: scroll; | ||
background: rgba(112, 0, 255, 0.17); | ||
border: 2px solid #c67dff; | ||
border-radius: 0.3rem; | ||
} | ||
|
||
.openTournamentBox { | ||
display: flex; | ||
width: 100%; | ||
flex: 15; | ||
flex-direction: column; | ||
padding: 0.2rem 0 0.2rem 0.2rem; | ||
margin-bottom: 1rem; | ||
overflow-x: scroll; | ||
overflow-y: scroll; | ||
background: rgba(112, 0, 255, 0.17); | ||
border: 2px solid #c67dff; | ||
border-radius: 0.3rem; | ||
} | ||
|
||
.tournamentTextWait { | ||
display: flex; | ||
flex: 1; | ||
font-weight: 700; | ||
color: black; | ||
text-align: center; /* 텍스트를 가로로 중앙에 정렬 */ | ||
} | ||
|
||
.tournamentTextOpen { | ||
display: flex; | ||
flex: 1; | ||
padding-top: 1rem; | ||
font-weight: 700; | ||
color: black; | ||
text-align: center; /* 텍스트를 가로로 중앙에 정렬 */ | ||
} |
Oops, something went wrong.