snp-connection-monitoring/docs/design/prompts/new-component.md
HYOJIN c2a71c1b77 feat(design): 디자인 시스템 적용 (CSS 토큰, Button/Badge, 차트, 다크모드) (#48)
- 디자인 시스템 가이드 문서 11개 생성 (docs/design/)
- CSS 변수 토큰 시스템 (@theme + :root/.dark 전환)
- cn() 유틸리티 (clsx + tailwind-merge)
- Button/Badge 공통 컴포넌트 (variant/size, 다크모드 대응)
- 하드코딩 Tailwind 색상 → CSS 변수 토큰 리팩토링 (30개 파일)
- 차트 팔레트 다크모드 색상 업데이트 (CHART_COLORS_HEX)
- 버튼 다크모드 채도/대비 강화 (primary-600 기반)

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-15 16:38:00 +09:00

2.5 KiB

새 컴포넌트 생성 프롬프트 템플릿

아래 템플릿을 복사하여 Claude에게 컴포넌트 생성을 요청할 때 사용한다.


기본 템플릿

[파일] frontend/src/components/{경로}/{ComponentName}.tsx

[계약]
interface {ComponentName}Props {
  // Props 정의
  className?: string;
}

[제약]
- docs/design/code-conventions.md 의 규칙 준수
- CSS 변수 토큰 사용 (HEX 하드코딩 금지)
- cn() 유틸리티 사용 (src/utils/cn.ts)
- Lucide React 아이콘만 사용
- any 타입 금지, strict 모드
- forwardRef 적용 (DOM 접근 필요한 경우)
- prefers-reduced-motion 고려

실제 사용 예시

버튼 컴포넌트

[파일] frontend/src/components/ui/Button.tsx

[계약]
interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
  variant?: 'primary' | 'secondary' | 'accent' | 'outline' | 'ghost' | 'danger';
  size?: 'sm' | 'md' | 'lg';
  loading?: boolean;
  leftIcon?: React.ReactNode;
  rightIcon?: React.ReactNode;
  className?: string;
}

[참조] docs/design/components.md (Button 섹션)

[제약]
- CSS 변수 토큰 사용
- cn() 사용
- forwardRef 적용
- disabled + loading 상태 처리
- focus-visible ring 적용

데이터 테이블 컴포넌트

[파일] frontend/src/components/ui/DataTable.tsx

[계약]
interface Column<T> {
  key: keyof T;
  header: string;
  width?: string;
  render?: (value: T[keyof T], row: T) => React.ReactNode;
}

interface DataTableProps<T> {
  columns: Column<T>[];
  data: T[];
  loading?: boolean;
  emptyMessage?: string;
  className?: string;
}

[제약]
- CSS 변수 토큰 사용
- 로딩 시 스켈레톤 표시
- 빈 상태 메시지 표시
- 반응형 (모바일에서 가로 스크롤)

상태 Badge

[파일] frontend/src/components/ui/StatusBadge.tsx

[계약]
type StatusType = 'success' | 'warning' | 'danger' | 'info' | 'default';

interface StatusBadgeProps {
  status: StatusType;
  label: string;
  dot?: boolean;
  className?: string;
}

[참조] docs/design/components.md (Badge 섹션)

[제약]
- 시멘틱 컬러 사용 (--color-success 등)
- dot prop이 true이면 상태 점 표시

체크리스트 (컴포넌트 생성 전)

  • 기존 컴포넌트로 해결 가능한지 확인 (src/components/ 탐색)
  • Props 인터페이스 설계 완료
  • 담당 디자인 문서 섹션 참조 (docs/design/components.md)
  • 파일 경로 결정 (ui/ vs 도메인 폴더)
  • 접근성 요구사항 파악 (aria, focus, keyboard)