Skip to content

Conversation

@yongb2n
Copy link
Contributor

@yongb2n yongb2n commented Feb 4, 2025

📌 PR 템플릿

🏷️ PR 타입 (PR Type)

아래 해당 사항에 체크해 주세요.

  • 🐛 버그 수정 (Bugfix)
  • ✨ 기능 개발 (Feature)
  • 🎨 코드 스타일 변경 (Code style update) - 포매팅, 로컬 변수 등
  • ♻️ 리팩토링 (Refactoring) - 기능 변화 없음, API 변경 없음
  • 🛠️ 빌드 관련 변경 (Build related changes)
  • 📝 문서 내용 변경 (Documentation)
  • 🔄 기타 (Other) - 설명 작성

📝 요약 (Summary)

PR의 목적과 간단한 설명을 적어주세요.


🔍 상세 내용 (Describe your changes)

변경 사항을 구체적으로 작성해 주세요.

  • 주요 변경점 예시: "버튼 스타일 변경" 등

🔗 관련 이슈 또는 링크 (Issue Number or Link)

이슈 번호나 관련 링크가 있다면 추가해 주세요.


✅ 체크리스트 (Checklist)

PR 작성 시 아래 사항들을 점검해 주세요.

  • 빌드가 성공적으로 되었나요?
  • 코드에 주석을 추가했나요?
  • 모든 테스트가 통과했나요?
  • 관련 문서가 업데이트되었나요?

📸 스크린샷 (선택 사항)

변경 사항이 UI와 관련이 있다면 스크린샷을 추가해 주세요.


📝 기타 사항

PR과 관련된 기타 사항이 있다면 적어주세요.

Summary by CodeRabbit

  • 새로운 기능
    • 테스트 페이지 UI가 재구성되어, 팀 모집 리스트 대신 댓글 작성 폼과 댓글 목록이 표시됩니다.
    • 사용자 인터페이스에 프로필 아이콘, 댓글 내용, 작성자 정보 및 작성 시간이 한눈에 보이는 댓글 요소가 추가되었습니다.
    • 새롭게 추가된 시렌 아이콘이 인터페이스에서 사용 가능해졌습니다.

@yongb2n yongb2n self-assigned this Feb 4, 2025
@yongb2n yongb2n linked an issue Feb 4, 2025 that may be closed by this pull request
3 tasks
@yongb2n yongb2n marked this pull request as draft February 4, 2025 07:53
@coderabbitai
Copy link

coderabbitai bot commented Feb 4, 2025

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 @coderabbitai review command as a PR comment. Alternatively, push new commits to this PR.

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.

📥 Commits

Reviewing files that changed from the base of the PR and between 1e8ecbb and b968663.

⛔ Files ignored due to path filters (1)
  • src/assets/icons/ic-trashbin.svg is excluded by !**/*.svg
📒 Files selected for processing (3)
  • src/app/(pages)/test-page/page.tsx (1 hunks)
  • src/assets/IconList.ts (2 hunks)
  • src/components/comment/CommentList.tsx (1 hunks)

Walkthrough

이 PR은 테스트 페이지의 컴포넌트에서 기존 팀 모집 데이터를 불러오던 로직을 제거하고, 모의 댓글 데이터와 관련 UI 요소(프로필 아이콘, 댓글 입력 폼, 댓글 리스트)를 도입하는 변경사항을 포함합니다. 또한, 댓글 입력 및 리스트를 위한 새로운 컴포넌트들이 추가되었고, 관련 컴포넌트들이 중앙에서 재-export 되도록 수정되었습니다. 마지막으로, shared form 컴포넌트의 name 속성 타입이 FormField에서 string으로 변경되었습니다.

Changes

파일 변경 요약
src/app/…/test-page/page.tsx 팀 모집 데이터 호출 로직 제거 및 모의 댓글 데이터와 관련 UI 요소(프로필 아이콘, Comment, CommentList) 도입
src/assets/IconList.ts 신규 IcSiren 아이콘 추가 및 export 목록 업데이트
src/components/comment/Comment.tsx
src/components/comment/CommentList.tsx
src/components/comment/index.ts
댓글 입력 폼과 댓글 리스트를 위한 새로운 컴포넌트 추가 및 중앙화 (index 파일 재-export)
src/components/shared/form/Form.tsx FormPassword, FormTextAreaname 속성 타입을 FormField에서 string으로 변경

Sequence Diagram(s)

sequenceDiagram
    participant 사용자
    participant Page
    participant Comment
    participant CommentList
    participant Form

    사용자가->>Page: 테스트 페이지 요청
    Page->>Comment: 댓글 폼 렌더링 (모의 데이터 사용)
    Page->>CommentList: 댓글 리스트 렌더링
    사용자가->>Comment: 댓글 입력 및 제출
    Comment->>Form: 입력값 검증 및 처리
    Form-->>Comment: 검증 결과 반환
    Comment->>콘솔: 제출 데이터 로그 출력
Loading

Possibly related PRs

Suggested reviewers

  • yellowjang
  • KingNono1030

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?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

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)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@yongb2n yongb2n marked this pull request as ready for review February 6, 2025 09:09
@yongb2n yongb2n requested a review from KingNono1030 February 6, 2025 09:10
@yongb2n yongb2n changed the title [#188] 🌱 complete initail setup of Comment component [#188] ✨ 댓글 컴포넌트 구현 Feb 6, 2025
Copy link

@coderabbitai coderabbitai bot left a 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: 컴포넌트 구조와 스타일링을 개선해주세요.

컴포넌트 구현에서 몇 가지 개선할 점이 있습니다:

  1. 하드코딩된 width 값들은 반응형 디자인에 제약이 될 수 있습니다.
  2. 불필요한 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

📥 Commits

Reviewing files that changed from the base of the PR and between 14d04b9 and 1e8ecbb.

⛔ Files ignored due to path filters (1)
  • src/assets/icons/ic-siren.svg is 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: 신고하기 기능 구현이 필요합니다.

드롭다운 메뉴의 신고하기 기능이 아직 구현되지 않았네요.

신고하기 기능 구현 시 다음과 같은 사항들을 고려해보시면 좋을 것 같아요:

  1. 신고 사유 선택
  2. 신고 내용 입력
  3. 중복 신고 방지
  4. 신고 처리 상태 표시

구현에 도움이 필요하시다면 말씀해주세요!


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

Comment on lines 9 to 21
const mock = [
{
writer: {
id: 1,
nickname: '닉네임인데용',
imageUrl:
'',
},
content:
'whatisthat@naver.com로 간단한 소개서 작성하여 보내주시면 확인 후 연락드리겠습니다!',
createdAt: '2024. 09. 26 10:28:42',
},
]
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

이미지 URL과 데이터 구조를 최적화해주세요.

mock 데이터 구조에서 몇 가지 개선이 필요해 보입니다:

  1. base64로 인코딩된 이미지 URL은 성능에 영향을 줄 수 있습니다.
  2. 이메일 주소가 콘텐츠에 직접 노출되어 있습니다.

다음과 같이 개선해보세요:

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.

Suggested change
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;
}

Copy link
Contributor

@KingNono1030 KingNono1030 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

고생하셨습니다 !

@KingNono1030 KingNono1030 merged commit d64a110 into dev Feb 10, 2025
1 check passed
@KingNono1030 KingNono1030 deleted the feat/common-comment branch February 10, 2025 08:11
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[FEATURE] [common 컴포넌트] Comment

3 participants