Skip to content

[Feature/#257] 타임라인 성과 요약 패널 UI 구현#261

Merged
jjjsun merged 8 commits into
developfrom
feature/#257
Jun 25, 2026
Merged

[Feature/#257] 타임라인 성과 요약 패널 UI 구현#261
jjjsun merged 8 commits into
developfrom
feature/#257

Conversation

@jjjsun

@jjjsun jjjsun commented Jun 23, 2026

Copy link
Copy Markdown
Collaborator

🚨 관련 이슈

Closed #257

✨ 변경사항

  • 🐞 BugFix Something isn't working
  • 💻 CrossBrowsing Browser compatibility
  • 🌏 Deploy Deploy
  • 🎨 Design Markup & styling
  • 📃 Docs Documentation writing and editing (README.md, etc.)
  • ✨ Feature Feature
  • 🔨 Refactor Code refactoring
  • ⚙️ Setting Development environment setup
  • ✅ Test Test related (storybook, jest, etc.)

✏️ 작업 내용

TimelinePerformancePanel UI 구현

  • 타임라인 캠페인 바 클릭 시 노출할 성과 요약 패널 UI 틀 구현
  • 공통 컴포넌트인 Drawer 재사용하였습니다.
  • 헤더는 타임라인명, 기간, 성과 뱃지, 성과 지표 태그, 더보기 메뉴(수정/삭제)

AI 요약 영역

  • idle -> loading -> done 으로 3단계로 UI 상태표시합니다.
  • 요약전: 요약하기 생성 버튼
  • 요약후: 버튼 숨김 + 요약 문단 표시
  • aiSummary가 비어있으면, 요약하기 버튼을 노출하고, 요약본이 있다면 패널 열때 바로 요약 표시되도록 표시

성과 지표/차트/플랫폼 기여

  • 선택 지표 수만큼 KPI 영역 가로로 균등 분할되도록 구현진행했습니다 (최소 1개, 최대 4개)
  • 일별 변화 추이는 직전 이슈에서 만든 TimelinePeriodSelector 사용하였고, 추후 차트 라이브러리 구축예정입니다.
  • 플랫폼 기여 정보: 각 로고의 wordmark 아이콘 삽입하였고, progress bar를 그라데이션으로 이루어지도록 설정했습니다.

공통/타입/mock

  • ITimelineSummaryPanelDataperformanceStatus 추가
  • TIMELINE_SUMMARY_PANEL_MOCK, `TIMELINE_SUMMARY_PANEL_NO_AI_MOCK 추가
  • ROAS 단위 mock을 '배'로 수정
  • 공통 컴포넌트 DropdownMenu에 삭제 메뉴 옵션 추가
  • 공통 유틸 파일에 shadow-Soft-xs 유틸추가

💻 구현 화면

전체 너비

image image image image

모바일 화면 너비

image image image

😅 미완성 작업

N/A
(mock데이터 사용중이어서 날짜기간선택이 안맞는 부분이 있습니다. 해당 부분은 API연동과 같이 진행예정)

📢 논의 사항 및 참고 사항

성과 요약 패널 카드/섹션에 기존에 유틸파일에 존재하는 shadow-Soft를 적용했을때, 그림자가 조금 뚜렷하게 보여서, 유틸파일에 더 약한 shadow-Soft-xs 유틸을 추가했습니다.
기존 것은 변경하지 않았고, 추가만 진행했습니다.
디자인 시스템적 관점에서 추가가 조금 부담스러우시면, 패널을 shadow-Soft로 되돌리거나 다른 방식인 border만으로 진행하는 부분으로 맞출수도 있습니다! 의견 남겨주세요!

💬 리뷰어 가이드 (P-Rules)
P1: 필수 반영 (Critical) - 버그 가능성, 컨벤션 위반. 해결 전 머지 불가.
P2: 적극 권장 (Recommended) - 더 나은 대안 제시. 가급적 반영 권장.
P3: 제안 (Suggestion) - 아이디어 공유. 반영 여부는 드라이버 자율.
P4: 단순 확인/칭찬 (Nit) - 사소한 오타, 칭찬 등 피드백.

Summary by CodeRabbit

  • New Features

    • 타임라인 화면에 축, 격자, 바, 기간 선택, 성과 패널이 추가되어 한 화면에서 일정을 더 직관적으로 볼 수 있게 되었습니다.
    • 항목 드롭다운에서 위험 항목을 더 눈에 띄게 표시할 수 있습니다.
    • Storybook 예시가 추가되어 주요 타임라인 UI를 미리 확인할 수 있습니다.
  • Bug Fixes

    • 성과 상태 표시와 라벨이 최신 상태로 맞춰졌습니다.
    • 요약 패널의 AI 생성/표시 흐름이 개선되었습니다.

@jjjsun jjjsun requested review from Seojegyeong and YermIm June 23, 2026 20:12
@jjjsun jjjsun self-assigned this Jun 23, 2026
@jjjsun jjjsun added 🎨 Html&css 마크업 & 스타일링 ✅ Test test 관련(storybook, jest...) ✨ Feature 기능 개발 labels Jun 23, 2026
@coderabbitai

coderabbitai Bot commented Jun 23, 2026

Copy link
Copy Markdown

Review Change Stack

Warning

Review limit reached

@jjjsun, we couldn't start this review because you've reached your PR review rate limit.

More reviews will be available in 45 minutes and 4 seconds. Learn how PR review limits work.

Your organization has used up its prepaid credits, and credit purchases are no longer available. Enable the review add-on in the billing tab to keep reviews running — you're only billed for reviews past your plan's rate limits ($0.25/file).

⌛ How to resolve this issue?

After more reviews become available, a review can be triggered using the @coderabbitai review command as a PR comment. Alternatively, push new commits to this PR.

To avoid repeated limits, reduce automatic review volume by pausing incremental auto-reviews earlier, using label-based review opt-in, excluding WIP or generated PR titles, or requesting reviews manually when the PR is ready. If your team needs uninterrupted high-volume reviews, an organization admin can enable usage-based credits.

🚦 How do rate limits work?

CodeRabbit enforces per-developer PR review limits for each organization. Most developers receive the normal plan review availability.

For paid Pro and Pro+ PR reviews, CodeRabbit uses adaptive limits for sustained high-volume activity. When a developer's recent PR review activity reaches the 95th percentile or higher among CodeRabbit users, additional reviews become available more gradually as earlier reviews age out of the rolling window.

Please see our Fair Usage Limits Policy for further information.

ℹ️ Review info
⚙️ Run configuration

Configuration used: Path: .coderabbit.yaml

Review profile: CHILL

Plan: Pro

Run ID: b1330149-55d9-47af-9e22-d39fa09b38b0

📥 Commits

Reviewing files that changed from the base of the PR and between bdbceea and 5a982f4.

📒 Files selected for processing (1)
  • src/components/timeline/TimelinePerformancePanel.tsx
📝 Walkthrough

Walkthrough

타임라인 레이아웃/성과 상태 상수를 신규 정의하고, TimelineAxis, TimelineGrid, TimelineBar 그리드 컴포넌트와 TimelinePeriodSelector, TimelinePerformancePanel 패널 컴포넌트를 추가했습니다. DropdownMenudanger 스타일을 확장하고, 관련 Storybook 스토리 및 mock 데이터를 갱신했습니다.

Changes

타임라인 성과 요약 패널 및 그리드 UI

Layer / File(s) Summary
레이아웃 상수, 성과 상태 타입 및 UI 타입 정의
src/constants/timeline/layout.ts, src/constants/timeline/statusStyle.ts, src/constants/timeline/viewUnit.ts, src/types/timeline/api.ts, src/types/timeline/ui.ts, src/types/timeline/summary.ts
타임라인 픽셀 상수 5종, 성과 상태 스타일 매핑, 뷰 단위 옵션 배열을 신규 추가하고, ABOVE_AVERAGE로 성과 상태값을 교체하며 ITimelineCampaignBar.performanceStatus를 필수화하고 colorClass를 제거했습니다. ITimelineSummaryPanelDataperformanceStatus 필드를 추가했습니다.
Mock 데이터 갱신
src/types/timeline/timeline.mock.ts
TIMELINE_GRID_MOCK 주간 구성을 현재 주차로 재구성하고, TIMELINE_SUMMARY_PANEL_MOCKperformanceStatus/ROAS unit 변경을 반영하며, AI 미사용 케이스용 TIMELINE_SUMMARY_PANEL_NO_AI_MOCK을 신규 추가했습니다.
TimelineAxis / TimelineGrid / TimelineBar 그리드 컴포넌트
src/components/timeline/TimelineAxis.tsx, src/components/timeline/TimelineGrid.tsx, src/components/timeline/TimelineBar.tsx
날짜 축(TimelineAxis), 격자 배경(TimelineGrid), 캠페인 바 카드(TimelineBar) 세 컴포넌트를 신규 구현했습니다. 레이아웃 상수 기반으로 크기·위치를 계산하고, isToday/isWeekend/performanceStatus 조건 스타일을 적용합니다.
TimelinePeriodSelector 컴포넌트
src/components/timeline/TimelinePeriodSelector.tsx, src/components/timeline/TimelinePeriodSelector.stories.tsx
보기 단위 드롭다운과 이전/다음 기간 이동 버튼을 제공하는 컴포넌트를 신규 추가했습니다. mousedown 기반 외부 클릭 감지, aria 접근성 속성, TIMELINE_VIEW_UNIT_OPTIONS 기반 옵션 렌더링을 포함합니다. Storybook Default/Interactive 스토리도 함께 추가했습니다.
TimelinePerformancePanel 컴포넌트
src/components/timeline/TimelinePerformancePanel.tsx, src/components/timeline/TimelinePerformancePanel.stories.tsx
AI 요약 상태 머신(idle/loading/done), KPI 지표 카드, 차트 placeholder, 플랫폼 기여 진행률 바, 삭제/수정 드롭다운을 포함하는 성과 요약 패널을 신규 구현했습니다. Closed/Open/OpenWithSummary/Interactive 4개 Storybook 시나리오도 함께 추가했습니다.
DropdownMenu danger 스타일 확장
src/components/common/dropdownmenu/DropdownMenu.tsx
TMenuItemdanger?: boolean, labelClassName?: string을 추가하고, 버튼·아이콘·라벨 span 클래스 분기에 danger 우선 로직을 추가하여 text-info-red 기반 스타일을 적용했습니다.
TimelineCanvas Storybook 스토리
src/components/timeline/TimelineCanvas.stories.tsx
mock 데이터로 TimelineAxis, TimelineGrid, TimelineBar를 조합 렌더링하고, 마운트 시 스크롤을 오른쪽 끝으로 이동하는 Canvas 미리보기 스토리를 신규 추가했습니다.

Sequence Diagram(s)

sequenceDiagram
  participant User as 사용자
  participant TimelineBar as TimelineBar
  participant TimelinePerformancePanel as TimelinePerformancePanel
  participant TimelinePeriodSelector as TimelinePeriodSelector

  User->>TimelineBar: 캠페인 바 클릭 (onBarClick)
  TimelineBar->>TimelinePerformancePanel: bar 데이터 전달, isOpen=true
  TimelinePerformancePanel->>TimelinePerformancePanel: aiState 초기화 (idle 또는 done)

  User->>TimelinePerformancePanel: "요약하기 생성" 버튼 클릭
  TimelinePerformancePanel->>TimelinePerformancePanel: aiState = loading (스켈레톤 표시)
  TimelinePerformancePanel->>TimelinePerformancePanel: AI_SUMMARY_LOADING_MS 경과 후 aiState = done

  User->>TimelinePeriodSelector: 보기 단위 변경 (DAY/WEEK/MONTH)
  TimelinePeriodSelector->>TimelinePerformancePanel: onViewUnitChange(unit)
  TimelinePerformancePanel->>TimelinePerformancePanel: viewUnit 갱신, chartPeriodIndex = 0

  User->>TimelinePeriodSelector: 이전/다음 기간 버튼 클릭
  TimelinePeriodSelector->>TimelinePerformancePanel: onPrevPeriod / onNextPeriod
  TimelinePerformancePanel->>TimelinePerformancePanel: chartPeriodIndex 갱신
Loading

Estimated code review effort

🎯 4 (Complex) | ⏱️ ~60 minutes

Possibly related PRs

Suggested reviewers

  • Seojegyeong
  • YermIm
🚥 Pre-merge checks | ✅ 4 | ❌ 1

❌ Failed checks (1 warning)

Check name Status Explanation Resolution
Docstring Coverage ⚠️ Warning Docstring coverage is 0.00% which is insufficient. The required threshold is 80.00%. Write docstrings for the functions missing them to satisfy the coverage threshold.
✅ Passed checks (4 passed)
Check name Status Explanation
Title check ✅ Passed 제목이 타임라인 성과 요약 패널 구현이라는 핵심 변경과 일치합니다.
Description check ✅ Passed 필수 섹션인 관련 이슈, 변경사항, 작업 내용, 미완성 작업, 참고 사항이 모두 채워져 있습니다.
Linked Issues check ✅ Passed 성과 요약 패널, 상태 전환, Drawer 재사용, KPI/차트 placeholder, Storybook까지 이슈 요구를 충족합니다.
Out of Scope Changes check ✅ Passed 그리드·바·스토리북·타입/상수 추가는 패널 구현을 위한 보조 변경으로 보이며 뚜렷한 무관 변경은 없습니다.

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

✨ Finishing Touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Commit unit tests in branch feature/#257

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.

@github-actions

github-actions Bot commented Jun 23, 2026

Copy link
Copy Markdown

📚 Storybook 배포 완료

항목 링크
📖 Storybook https://69a147b60a56365d9e2185ef-dmnvglyalo.chromatic.com/
🔍 Chromatic https://www.chromatic.com/build?appId=69a147b60a56365d9e2185ef&number=361

@coderabbitai coderabbitai Bot left a comment

Copy link
Copy Markdown

Choose a reason for hiding this comment

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

Actionable comments posted: 5

🧹 Nitpick comments (4)
src/components/timeline/TimelinePeriodSelector.tsx (1)

90-121: 🎯 Functional Correctness | 🔵 Trivial | ⚡ Quick win

role="menu"를 유지할 거면 키보드 상호작용을 함께 맞춰주세요.

현재 구조는 menu/menuitem 역할을 선언했는데, 화살표 키 이동·ESC 닫기·초기 포커스 이동 처리가 없어 ARIA 기대 동작과 어긋납니다.
두 가지 중 하나로 정리하는 걸 권장합니다: (1) menu 패턴에 맞는 키보드 핸들링 추가, (2) 단순 리스트 선택 UI에 맞는 role로 단순화.

As per path instructions, "접근성: 시맨틱 HTML, ARIA 속성 사용 확인."

🤖 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/components/timeline/TimelinePeriodSelector.tsx` around lines 90 - 121,
The TimelinePeriodSelector component declares menu and menuitem roles but lacks
required keyboard interactions for the menu pattern. Either implement proper
keyboard navigation (arrow keys to move between TIMELINE_VIEW_UNIT_OPTIONS
items, ESC to close the menu, and initial focus management) in the menu
structure with role="menu" and the button elements with role="menuitem", or
simplify the roles to role="listbox" with appropriate ARIA attributes if a full
menu pattern is unnecessary for this simple selection UI. Choose whichever
approach better matches your component's interaction design.

Source: Path instructions

src/components/timeline/TimelinePerformancePanel.stories.tsx (2)

26-26: 📐 Maintainability & Code Quality | 🔵 Trivial | 💤 Low value

ClosedPreivew 오탈자는 ClosedPreview로 정리하는 게 좋아요.

동작에는 영향 없지만 스토리 가독성과 검색성이 좋아집니다.

Also applies to: 52-52

🤖 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/components/timeline/TimelinePerformancePanel.stories.tsx` at line 26, Fix
the typo in the function name ClosedPreivew by renaming it to ClosedPreview.
Update all references to this function throughout the file to use the correct
spelling, including where the function is defined and where it is called or
exported.

10-10: 📐 Maintainability & Code Quality | 🔵 Trivial | ⚡ Quick win

여기도 @/ alias import 규칙으로 맞춰주세요.

상대경로 import 대신 alias import를 사용해야 규칙과 일관됩니다.

제안 패치
-import TimelinePerformancePanel from "./TimelinePerformancePanel";
+import TimelinePerformancePanel from "`@/components/timeline/TimelinePerformancePanel`";

As per coding guidelines, "**/*.{ts,tsx}: Use @/ alias for all imports."

🤖 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/components/timeline/TimelinePerformancePanel.stories.tsx` at line 10, The
import statement for TimelinePerformancePanel in
TimelinePerformancePanel.stories.tsx is using a relative path import instead of
the `@/` alias pattern. Replace the relative import path
"./TimelinePerformancePanel" with the corresponding `@/` alias import path to
maintain consistency with the project's import guidelines. Update the import
statement to use `@/components/timeline/TimelinePerformancePanel`.

Source: Coding guidelines

src/components/timeline/TimelineCanvas.stories.tsx (1)

7-9: 📐 Maintainability & Code Quality | 🔵 Trivial | ⚡ Quick win

로컬 컴포넌트 import를 @/ alias로 통일해주세요.

현재 상대경로 import가 프로젝트 규칙과 불일치합니다.

제안 패치
-import TimelineAxis from "./TimelineAxis";
-import TimelineBar from "./TimelineBar";
-import TimelineGrid from "./TimelineGrid";
+import TimelineAxis from "`@/components/timeline/TimelineAxis`";
+import TimelineBar from "`@/components/timeline/TimelineBar`";
+import TimelineGrid from "`@/components/timeline/TimelineGrid`";

As per coding guidelines, "**/*.{ts,tsx}: Use @/ alias for all imports."

🤖 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/components/timeline/TimelineCanvas.stories.tsx` around lines 7 - 9, The
relative path imports for TimelineAxis, TimelineBar, and TimelineGrid components
in the import statements are not following the project's coding guideline that
requires using the `@/` alias for all imports. Replace all three relative import
paths (./) with the `@/` alias import format, using the appropriate path to each
component through the components directory structure to maintain consistency
with project standards.

Source: Coding guidelines

🤖 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/components/common/dropdownmenu/DropdownMenu.tsx`:
- Around line 119-123: In the DropdownMenu component, when constructing the
className for menu items, the `danger` state only applies red color styling to
the button/label text, but the icon color rules remain in the default blue hover
state, breaking semantic consistency. Update the icon styling logic to also
check the `danger` condition (it.danger) and apply red color classes to the icon
when danger is true, ensuring the icon styling is aligned with the button/label
styling. This same fix should be applied to all similar locations in the
component where this pattern occurs (also check around lines 144-146).

In `@src/components/timeline/TimelineBar.tsx`:
- Around line 14-21: The ITimelineBarProps interface is missing an onBarClick
callback handler that is needed to implement the timeline bar click
functionality. Add an onBarClick property to the interface that accepts a
callback with the ITimelineCampaignBar parameter. In the TimelineBar component,
add an onClick handler to the clickable bar/card element (in the section around
lines 40-47) that invokes the onBarClick callback when the bar is clicked.
Additionally, ensure the menu button click handler (around lines 65-70) calls
stopPropagation to prevent the bar click event from being triggered when the
menu button is clicked, keeping these two interactions separate.

In `@src/components/timeline/TimelinePerformancePanel.stories.tsx`:
- Line 35: The className in the button element contains a typo with
"rounded-log" which is not a valid Tailwind utility class and will not apply the
intended border-radius styling. Replace "rounded-log" with "rounded-lg" in the
className prop to apply the correct Tailwind utility for large rounded corners.

In `@src/components/timeline/TimelinePerformancePanel.tsx`:
- Around line 137-141: The handleGenerateSummary function changes aiState to
"done" after the timeout, but it doesn't actually populate data.aiSummary with
any content. Since the summary content rendering depends on data.aiSummary being
populated, the UI shows a done state with no actual summary to display. Modify
the handleGenerateSummary function to call the actual summary generation logic
(such as an API call or data fetching mechanism) during the loading period, and
ensure that data.aiSummary is properly populated with the generated summary
before setting aiState to "done". This way the display condition and state
transition will align correctly.

In `@src/types/timeline/timeline.mock.ts`:
- Line 36: The summary field in the mock object contains Korean text that
references "1월 23일" (January 23rd), but the period and trend data in the same
mock object is based on 2026-06 (June 2026), causing a mismatch between the
summary description and the actual mock data. Update the summary field to
reference dates that are consistent with the June 2026 time period, replacing
the January date reference with appropriate dates from the June 2026 period so
the mock summary accurately reflects the data being provided.

---

Nitpick comments:
In `@src/components/timeline/TimelineCanvas.stories.tsx`:
- Around line 7-9: The relative path imports for TimelineAxis, TimelineBar, and
TimelineGrid components in the import statements are not following the project's
coding guideline that requires using the `@/` alias for all imports. Replace all
three relative import paths (./) with the `@/` alias import format, using the
appropriate path to each component through the components directory structure to
maintain consistency with project standards.

In `@src/components/timeline/TimelinePerformancePanel.stories.tsx`:
- Line 26: Fix the typo in the function name ClosedPreivew by renaming it to
ClosedPreview. Update all references to this function throughout the file to use
the correct spelling, including where the function is defined and where it is
called or exported.
- Line 10: The import statement for TimelinePerformancePanel in
TimelinePerformancePanel.stories.tsx is using a relative path import instead of
the `@/` alias pattern. Replace the relative import path
"./TimelinePerformancePanel" with the corresponding `@/` alias import path to
maintain consistency with the project's import guidelines. Update the import
statement to use `@/components/timeline/TimelinePerformancePanel`.

In `@src/components/timeline/TimelinePeriodSelector.tsx`:
- Around line 90-121: The TimelinePeriodSelector component declares menu and
menuitem roles but lacks required keyboard interactions for the menu pattern.
Either implement proper keyboard navigation (arrow keys to move between
TIMELINE_VIEW_UNIT_OPTIONS items, ESC to close the menu, and initial focus
management) in the menu structure with role="menu" and the button elements with
role="menuitem", or simplify the roles to role="listbox" with appropriate ARIA
attributes if a full menu pattern is unnecessary for this simple selection UI.
Choose whichever approach better matches your component's interaction design.
🪄 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: 907db7ed-3067-40e1-b8a9-0216ec855b11

📥 Commits

Reviewing files that changed from the base of the PR and between 8896a8e and 7711a21.

📒 Files selected for processing (17)
  • src/components/common/dropdownmenu/DropdownMenu.tsx
  • src/components/timeline/TimelineAxis.tsx
  • src/components/timeline/TimelineBar.tsx
  • src/components/timeline/TimelineCanvas.stories.tsx
  • src/components/timeline/TimelineGrid.tsx
  • src/components/timeline/TimelinePerformancePanel.stories.tsx
  • src/components/timeline/TimelinePerformancePanel.tsx
  • src/components/timeline/TimelinePeriodSelector.stories.tsx
  • src/components/timeline/TimelinePeriodSelector.tsx
  • src/constants/timeline/layout.ts
  • src/constants/timeline/statusStyle.ts
  • src/constants/timeline/viewUnit.ts
  • src/styles/utilities.css
  • src/types/timeline/api.ts
  • src/types/timeline/summary.ts
  • src/types/timeline/timeline.mock.ts
  • src/types/timeline/ui.ts

Comment thread src/components/common/dropdownmenu/DropdownMenu.tsx
Comment thread src/components/timeline/TimelineBar.tsx
Comment thread src/components/timeline/TimelinePerformancePanel.stories.tsx Outdated
Comment thread src/components/timeline/TimelinePerformancePanel.tsx
Comment thread src/types/timeline/timeline.mock.ts
@Seojegyeong

Copy link
Copy Markdown
Collaborator

P4: 페이지가 아니라 이미 떠 있는 Drawer안의 내부 콘텐츠라 border-surface-300/(40~50) 정도의 연한 border로 구분하는 것도 좋을 것 같습니다!

@jjjsun

jjjsun commented Jun 24, 2026

Copy link
Copy Markdown
Collaborator Author

P4: 페이지가 아니라 이미 떠 있는 Drawer안의 내부 콘텐츠라 border-surface-300/(40~50) 정도의 연한 border로 구분하는 것도 좋을 것 같습니다!

넵 의견 감사합니다! 새로생성한 shadow-Soft-xs 삭제하고 border로 다시 수정작업진행해보겠습니다!

@YermIm YermIm left a comment

Copy link
Copy Markdown
Collaborator

Choose a reason for hiding this comment

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

P4: 확인했습니다!

@jjjsun jjjsun merged commit 902d09d into develop Jun 25, 2026
3 checks passed
@jjjsun jjjsun deleted the feature/#257 branch June 25, 2026 09:50
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

✨ Feature 기능 개발 🎨 Html&css 마크업 & 스타일링 ✅ Test test 관련(storybook, jest...)

Projects

None yet

Development

Successfully merging this pull request may close these issues.

✨ [Feature] 타임라인 성과 요약 패널 UI 구현

3 participants