-
Notifications
You must be signed in to change notification settings - Fork 2
[#188] ✨ 댓글 컴포넌트 구현 #223
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[#188] ✨ 댓글 컴포넌트 구현 #223
Conversation
|
Warning Rate limit exceeded@yongb2n has exceeded the limit for the number of commits or files that can be reviewed per hour. Please wait 4 minutes and 8 seconds before requesting another review. ⌛ How to resolve this issue?After the wait time has elapsed, a review can be triggered using the We recommend that you space out your commits to avoid hitting the rate limit. 🚦 How do rate limits work?CodeRabbit enforces hourly rate limits for each developer per organization. Our paid plans have higher rate limits than the trial, open-source and free plans. In all cases, we re-allow further reviews after a brief timeout. Please see our FAQ for further information. ⛔ Files ignored due to path filters (1)
📒 Files selected for processing (3)
Walkthrough이 PR은 테스트 페이지의 컴포넌트에서 기존 팀 모집 데이터를 불러오던 로직을 제거하고, 모의 댓글 데이터와 관련 UI 요소(프로필 아이콘, 댓글 입력 폼, 댓글 리스트)를 도입하는 변경사항을 포함합니다. 또한, 댓글 입력 및 리스트를 위한 새로운 컴포넌트들이 추가되었고, 관련 컴포넌트들이 중앙에서 재-export 되도록 수정되었습니다. 마지막으로, shared form 컴포넌트의 Changes
Sequence Diagram(s)sequenceDiagram
participant 사용자
participant Page
participant Comment
participant CommentList
participant Form
사용자가->>Page: 테스트 페이지 요청
Page->>Comment: 댓글 폼 렌더링 (모의 데이터 사용)
Page->>CommentList: 댓글 리스트 렌더링
사용자가->>Comment: 댓글 입력 및 제출
Comment->>Form: 입력값 검증 및 처리
Form-->>Comment: 검증 결과 반환
Comment->>콘솔: 제출 데이터 로그 출력
Possibly related PRs
Suggested reviewers
Poem
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Nitpick comments (2)
src/components/comment/Comment.tsx (1)
47-70: Form 컴포넌트 구조가 잘 잡혔어요! 💫다만, 접근성 향상을 위해 몇 가지 개선사항을 제안드립니다.
<Form methods={methods} onSubmit={methods.handleSubmit(onSubmit)} className='flex gap-x-8' > <Form.TextArea name='comment' size='lg' placeholder={placeholder} className={commentStyle} + aria-label={variant === 'comment' ? '댓글 입력' : '답글 입력'} /> <div className='flex items-end'> <Button type='submit' backgroundColor='transparentBlue' textColor='blue' size='sm' + aria-label={variant === 'comment' ? '댓글 등록' : '답글 등록'} > 등록 </Button> </div> </Form>src/app/(pages)/test-page/page.tsx (1)
23-46: 컴포넌트 구조와 스타일링을 개선해주세요.컴포넌트 구현에서 몇 가지 개선할 점이 있습니다:
- 하드코딩된 width 값들은 반응형 디자인에 제약이 될 수 있습니다.
- 불필요한 Fragment 중첩이 있습니다.
다음과 같이 개선해보세요:
export default function Page(): JSX.Element { return ( - <> - <div className='m-auto flex w-1200 gap-x-8'> + <div className='m-auto flex max-w-[1200px] w-full gap-x-8 px-4'> <IcProfile width={48} height={48} /> <Comment variant='comment' size='lg' /> </div> - <div className='m-auto flex w-1064 flex-col gap-x-8 gap-y-4'> + <div className='m-auto flex max-w-[1064px] w-full flex-col gap-x-8 gap-y-4 px-4'> <Text.Body variant='body2' color='highlight'> @망곰쓰 귀여워 </Text.Body> <Comment variant='reply' size='sm' /> </div> - <> <CommentList writer={mock[0].writer} content={mock[0].content} createdAt={mock[0].createdAt} /> - </> - </> ) }
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
⛔ Files ignored due to path filters (1)
src/assets/icons/ic-siren.svgis excluded by!**/*.svg
📒 Files selected for processing (6)
src/app/(pages)/test-page/page.tsx(1 hunks)src/assets/IconList.ts(2 hunks)src/components/comment/Comment.tsx(1 hunks)src/components/comment/CommentList.tsx(1 hunks)src/components/comment/index.ts(1 hunks)src/components/shared/form/Form.tsx(2 hunks)
✅ Files skipped from review due to trivial changes (1)
- src/components/comment/index.ts
🔇 Additional comments (7)
src/components/comment/Comment.tsx (2)
9-13: 인터페이스 설계가 깔끔하네요! 👏variant와 size prop을 통해 컴포넌트의 유연성을 확보하셨네요. 재사용성이 높은 설계입니다.
42-45: 서버 통신 로직 구현이 필요해요.현재는 콘솔 로그만 출력하고 있네요. API 통신 구현 시 에러 처리도 고려해주세요.
서버 통신 로직 구현에 도움이 필요하시다면 말씀해주세요!
src/components/comment/CommentList.tsx (3)
8-18: 인터페이스 설계가 명확해요! ✨Writer 인터페이스와 CommentListProps가 잘 분리되어 있습니다.
55-73: 신고하기 기능 구현이 필요합니다.드롭다운 메뉴의 신고하기 기능이 아직 구현되지 않았네요.
신고하기 기능 구현 시 다음과 같은 사항들을 고려해보시면 좋을 것 같아요:
- 신고 사유 선택
- 신고 내용 입력
- 중복 신고 방지
- 신고 처리 상태 표시
구현에 도움이 필요하시다면 말씀해주세요!
45-52:⚠️ Potential issue하드코딩된 멘션 처리가 필요합니다.
현재 "@망곰아 사랑해"가 하드코딩되어 있네요. API 응답에서 멘션 정보를 받아와서 처리해야 할 것 같습니다.
멘션 데이터 처리 로직 구현에 도움이 필요하시다면 말씀해주세요!
src/assets/IconList.ts (1)
72-72: 아이콘 추가가 깔끔하게 되었네요! 👍기존 패턴을 잘 따르고 있습니다.
Also applies to: 144-144
src/components/shared/form/Form.tsx (1)
84-84: 타입 변경이 적절해 보입니다! 🎯FormField에서 string으로 타입을 변경하셨네요. 더 간단하면서도 타입 안정성을 유지하고 있습니다.
Also applies to: 111-111
| const mock = [ | ||
| { | ||
| writer: { | ||
| id: 1, | ||
| nickname: '닉네임인데용', | ||
| imageUrl: | ||
| '', | ||
| }, | ||
| content: | ||
| 'whatisthat@naver.com로 간단한 소개서 작성하여 보내주시면 확인 후 연락드리겠습니다!', | ||
| createdAt: '2024. 09. 26 10:28:42', | ||
| }, | ||
| ] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
이미지 URL과 데이터 구조를 최적화해주세요.
mock 데이터 구조에서 몇 가지 개선이 필요해 보입니다:
- base64로 인코딩된 이미지 URL은 성능에 영향을 줄 수 있습니다.
- 이메일 주소가 콘텐츠에 직접 노출되어 있습니다.
다음과 같이 개선해보세요:
const mock = [
{
writer: {
id: 1,
nickname: '닉네임인데용',
- imageUrl: '...',
+ imageUrl: '/images/profile-default.jpg',
},
content:
- 'whatisthat@naver.com로 간단한 소개서 작성하여 보내주시면 확인 후 연락드리겠습니다!',
+ '간단한 소개서 작성하여 보내주시면 확인 후 연락드리겠습니다!',
createdAt: '2024. 09. 26 10:28:42',
},
]
+ type Writer = {
+ id: number;
+ nickname: string;
+ imageUrl: string;
+ }
+ type Comment = {
+ writer: Writer;
+ content: string;
+ createdAt: string;
+ }📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
| const mock = [ | |
| { | |
| writer: { | |
| id: 1, | |
| nickname: '닉네임인데용', | |
| imageUrl: | |
| '', | |
| }, | |
| content: | |
| 'whatisthat@naver.com로 간단한 소개서 작성하여 보내주시면 확인 후 연락드리겠습니다!', | |
| createdAt: '2024. 09. 26 10:28:42', | |
| }, | |
| ] | |
| const mock = [ | |
| { | |
| writer: { | |
| id: 1, | |
| nickname: '닉네임인데용', | |
| imageUrl: '/images/profile-default.jpg', | |
| }, | |
| content: '간단한 소개서 작성하여 보내주시면 확인 후 연락드리겠습니다!', | |
| createdAt: '2024. 09. 26 10:28:42', | |
| }, | |
| ] | |
| type Writer = { | |
| id: number; | |
| nickname: string; | |
| imageUrl: string; | |
| } | |
| type Comment = { | |
| writer: Writer; | |
| content: string; | |
| createdAt: string; | |
| } |
KingNono1030
left a comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
고생하셨습니다 !
📌 PR 템플릿
🏷️ PR 타입 (PR Type)
📝 요약 (Summary)
🔍 상세 내용 (Describe your changes)
🔗 관련 이슈 또는 링크 (Issue Number or Link)
✅ 체크리스트 (Checklist)
📸 스크린샷 (선택 사항)
📝 기타 사항
Summary by CodeRabbit