Skip to content

모바일 반응형 및 UI 버그 수정#709

Merged
HA-SEUNG-JEONG merged 4 commits into
developfrom
fix/bug
May 27, 2026
Merged

모바일 반응형 및 UI 버그 수정#709
HA-SEUNG-JEONG merged 4 commits into
developfrom
fix/bug

Conversation

@HA-SEUNG-JEONG
Copy link
Copy Markdown
Contributor

@HA-SEUNG-JEONG HA-SEUNG-JEONG commented May 27, 2026

Problem

  • 모바일/태블릿 뷰포트에서 공통 레이아웃(헤더, 푸터, 사이드바), 클래스 페이지, 마이페이지의 UI가 Figma 디자인과 불일치하거나 레이아웃이 깨지는 문제 존재
  • 마이페이지 > 기본 정보 섹션의 레이아웃이 Figma 디자인(node 2090:12203)과 다름 — 레이블 폰트, 이메일 표시 방식, 휴대폰 번호 UI 구조 불일치
  • 모바일 nav에서 빌더 티켓 클릭 시 피드백 없이 반응 없음
  • spacing 토큰 중 16 배수 값이 rem/px 혼재

Solution

  • 공통 레이아웃 반응형 클래스 및 breakpoint 정리
  • 클래스 페이지(탭 내비, 로드맵, QnA, 피드) 모바일 반응형 수정
  • 마이페이지 기본 정보 섹션을 Figma 스펙에 맞게 재구성
    • ProfileRow 레이블: Bold → Regular, 컬럼 170px → 200px
    • 인증완료 값: 14px Regular → 16px Bold
    • 이메일: disabled input → 인라인 텍스트 + "변경 불가"
    • 휴대폰 번호: 1행(select+input+button) → 3행 구조 (국가 드롭다운 / 입력+인증하기 / 취소하기)
    • 행 간격: 40px → 30px
  • 빌더 티켓 버튼에 "준비 중" 토스트 추가
  • 16 배수 spacing 토큰 rem으로 통일

Changes

Bug Fixes

File Description
src/app/(service)/(my)/my-page/page.tsx 기본 정보 섹션 Figma 정합, 디스코드 배너 border 수정
src/app/global.css spacing 토큰 rem 통일
src/app/(landing)/class/[slug]/* 클래스 페이지 모바일 반응형 수정
src/components/common/layout/* 공통 레이아웃 모바일 반응형 개선
src/components/common/layout/sidebar/my-page-mobile-nav.tsx 빌더 티켓 "준비 중" 토스트 추가

Result

  • 모바일(390px) · 태블릿(768px) · 데스크톱(1280px) 3개 뷰포트에서 레이아웃 정상 렌더링
  • 마이페이지 기본 정보 섹션이 Figma 디자인과 일치
  • 빌더 티켓 클릭 시 준비 중 안내 토스트 노출

Screenshots

스크린샷: public/pr-screenshots/706/ 참조

Test plan

  • 모바일(390px) 뷰포트에서 클래스 목록/상세/QnA/피드 레이아웃 확인
  • 태블릿(768px) 뷰포트에서 동일 페이지 레이아웃 확인
  • 마이페이지 > 기본 정보: 레이블 Regular, 인증완료 Bold, 이메일 텍스트 표시 확인
  • 마이페이지 > 기본 정보: 휴대폰 번호 3행 구조 확인
  • 모바일 nav 빌더 티켓 클릭 시 "준비 중" 토스트 노출 확인

🤖 Generated with Claude Code

HA-SEUNG-JEONG and others added 2 commits May 27, 2026 10:38
- 닉네임 row: 중복확인/저장 버튼을 flex 컨테이너로 묶어 함께 줄바꿈
- 휴대폰 번호 row: select/button shrink-0 + input min-w-0 로 버튼 잘림 방지
- 배너 섹션: flex-col sm:flex-row 로 모바일 수직 스택 처리

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
@vercel
Copy link
Copy Markdown

vercel Bot commented May 27, 2026

The latest updates on your projects. Learn more about Vercel for GitHub.

Project Deployment Actions Updated (UTC)
study-platform-client-dev Ready Ready Preview, Comment May 27, 2026 2:24am

@coderabbitai
Copy link
Copy Markdown

coderabbitai Bot commented May 27, 2026

📝 Walkthrough

Walkthrough

마이페이지 프로필 정보 입력 구간의 스타일과 닉네임 버튼 레이아웃이 조정되고, 기본 정보 섹션의 인증완료/이메일/휴대폰 번호 UI가 재구성되었습니다. 배너 섹션의 반응형 레이아웃이 변경되었으며, 모바일 네비게이션에 builder-ticket 항목이 추가되고 comingSoon 상태를 지원하는 토스트 기능이 구현되었습니다.

Changes

마이페이지 UI 및 네비게이션 개선

Layer / File(s) Summary
프로필 정보 입력 구간 스타일 및 레이아웃 업데이트
src/app/(service)/(my)/my-page/page.tsx
ProfileRow 레이블의 폰트/색상 관련 Tailwind 클래스가 변경되고, 닉네임 입력 필드와 중복 확인/저장 버튼을 감싸는 레이아웃 구조가 조정되었습니다.
기본 정보 섹션 및 배너 레이아웃 재구성
src/app/(service)/(my)/my-page/page.tsx
인증완료 상태 표시, 이메일 안내 문구, 휴대폰 번호 입력 영역이 새로운 레이아웃으로 교체되었습니다. 국가코드(+82) 표시 블록과 취소하기 버튼이 추가되었고, 배너 섹션의 반응형 클래스와 테두리 색상이 변경되었습니다.
모바일 네비게이션 builder-ticket 항목 및 comingSoon 기능
src/components/common/layout/sidebar/my-page-mobile-nav.tsx
NAV_ITEMS에서 builder-ticket 항목이 추가되고 comingSoon 상태가 설정되었습니다. useToastStore를 통해 comingSoon 항목 클릭 시 토스트 메시지를 표시하고 라우팅을 차단하는 분기 로직이 구현되었습니다.

Estimated code review effort

🎯 2 (Simple) | ⏱️ ~12 minutes

Possibly related PRs

Suggested labels

release:minor

Poem

🐰 마이페이지 UI 다듬어지니
닉네임 확인 버튼 재배치하고
이메일, 휴대폰도 새 옷 입고
모바일 네비는 티켓 준비 중~
사용자 경험 한 단계 업 📱✨

🚥 Pre-merge checks | ✅ 5
✅ Passed checks (5 passed)
Check name Status Explanation
Title check ✅ Passed PR 제목이 변경사항의 주요 목표(모바일 반응형 버그 수정 및 UI 개선)를 명확하게 요약하고 있습니다.
Docstring Coverage ✅ Passed No functions found in the changed files to evaluate docstring coverage. Skipping docstring coverage check.
Linked Issues check ✅ Passed Check skipped because no linked issues were found for this pull request.
Out of Scope Changes check ✅ Passed Check skipped because no linked issues were found for this pull request.
Description Check ✅ Passed Check skipped - CodeRabbit’s high-level summary is enabled.

✏️ Tip: You can configure your own custom pre-merge checks in the settings.

✨ Finishing Touches
📝 Generate docstrings
  • Create stacked PR
  • Commit on current branch
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Commit unit tests in branch fix/bug

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

HA-SEUNG-JEONG and others added 2 commits May 27, 2026 11:07
- ProfileRow 레이블: Bold→Regular, 컬럼 170px→200px
- 인증완료 값: 14r→16b (Bold)
- 이메일: disabled input→텍스트 표시 + 변경불가 inline
- 휴대폰 번호: 1행→3행 (국가드롭다운/입력+인증하기/취소하기)
- 기본 정보 행 간격: gap-500(40px)→gap-375(30px)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
border-border-subtle → border-[#D5D7DA]

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Copy link
Copy Markdown

@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

🤖 Prompt for all review comments with AI agents
Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.

Inline comments:
In `@src/app/`(service)/(my)/my-page/page.tsx:
- Line 370: Replace the arbitrary Tailwind color class used in the component's
className (the token "border-[`#D5D7DA`]" string) with the project's design token
class (e.g., "border-border-subtle"); update the className value in the element
where className contains "border-[`#D5D7DA`]" so it uses the token class instead
of an arbitrary color token to comply with global.css token usage.
🪄 Autofix (Beta)

Fix all unresolved CodeRabbit comments on this PR:

  • Push a commit to this branch (recommended)
  • Create a new PR with the fixes

ℹ️ Review info
⚙️ Run configuration

Configuration used: Path: .coderabbit.yaml

Review profile: CHILL

Plan: Pro

Run ID: 9f4a2c2d-dfd0-4a38-8ea1-06ee5d7a8713

📥 Commits

Reviewing files that changed from the base of the PR and between 79cffa0 and 6233f15.

📒 Files selected for processing (2)
  • src/app/(service)/(my)/my-page/page.tsx
  • src/components/common/layout/sidebar/my-page-mobile-nav.tsx

target="_blank"
rel="noopener noreferrer"
className="border-border-subtle rounded-200 flex flex-1 items-center justify-center gap-175 overflow-hidden border bg-gray-50 py-250 transition-colors hover:bg-gray-100"
className="border-[#D5D7DA] rounded-200 flex flex-1 items-center justify-center gap-175 overflow-hidden border bg-gray-50 py-250 transition-colors hover:bg-gray-100"
Copy link
Copy Markdown

Choose a reason for hiding this comment

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

⚠️ Potential issue | 🟡 Minor | ⚡ Quick win

임의 색상 클래스 대신 토큰 클래스 사용 필요

border-[#D5D7DA]는 하드코딩된 arbitrary color라서 현재 스타일 규칙을 위반합니다. 토큰 클래스(border-border-subtle 등)로 교체해주세요.

수정 제안
- className="border-[`#D5D7DA`] rounded-200 flex flex-1 items-center justify-center gap-175 overflow-hidden border bg-gray-50 py-250 transition-colors hover:bg-gray-100"
+ className="border-border-subtle rounded-200 flex flex-1 items-center justify-center gap-175 overflow-hidden border bg-gray-50 py-250 transition-colors hover:bg-gray-100"

As per coding guidelines src/app/**/*.{tsx,jsx} and src/**/*.{ts,tsx,css}: “Do not use arbitrary Tailwind values… Use only defined tokens from global.css.”

📝 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
className="border-[#D5D7DA] rounded-200 flex flex-1 items-center justify-center gap-175 overflow-hidden border bg-gray-50 py-250 transition-colors hover:bg-gray-100"
className="border-border-subtle rounded-200 flex flex-1 items-center justify-center gap-175 overflow-hidden border bg-gray-50 py-250 transition-colors hover:bg-gray-100"
🤖 Prompt for AI Agents
Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.

In `@src/app/`(service)/(my)/my-page/page.tsx at line 370, Replace the arbitrary
Tailwind color class used in the component's className (the token
"border-[`#D5D7DA`]" string) with the project's design token class (e.g.,
"border-border-subtle"); update the className value in the element where
className contains "border-[`#D5D7DA`]" so it uses the token class instead of an
arbitrary color token to comply with global.css token usage.

@HA-SEUNG-JEONG HA-SEUNG-JEONG merged commit 67c8acc into develop May 27, 2026
14 checks passed
@HA-SEUNG-JEONG HA-SEUNG-JEONG deleted the fix/bug branch May 27, 2026 05:45
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.

1 participant