---
name: figma-design-rule-extractor
description: |
  Figma 디자인 시스템을 분석하여 .claude/rules/design-system/ 규칙 파일을 생성합니다.
  디자인 토큰, 공통 컴포넌트, 레이아웃 패턴, 타이포그래피, 간격 체계 등
  자체 디자인 시스템 구성에 필요한 모든 정보를 추출하고 규칙화합니다.
  Figma 디자인 규칙 추출, 디자인 시스템 문서화, design-system rule 생성 시 사용하세요.
license: MIT
metadata:
  author: hanssem
  version: "4.0.0"
  category: design-system
allowed-tools: Bash Read Write Edit Glob
---

# Figma Design Rule Extractor

Figma MCP를 활용하여 디자인 시스템을 분석하고, `.claude/rules/design-system/` 규칙 파일을 생성합니다.

## 핵심 원칙

| 원칙 | 설명 |
|------|------|
| **Rule Output Only** | .css/.js 파일 생성 X → 규칙 파일만 생성 |
| **Comprehensive Analysis** | 토큰뿐 아니라 컴포넌트, 레이아웃, 패턴까지 분석 |
| **Conflict Detection** | 기존 규칙과 충돌 시 사용자 확인 후 진행 |
| **Parallel Processing** | 깊은 레이어 구조는 병렬 처리 |

---

## 실행 워크플로우

```
┌─────────────────────────────────────────────────────────────┐
│  Step 1: 사용자 정보 수집 & 충돌 감지                         │
│  - Figma URL, clientLanguages, clientFrameworks             │
│  - 기존 .claude/rules/design-system/ 존재 여부 확인          │
│  - 충돌 시 사용자에게 처리 방법 질문                          │
└─────────────────────────────────────────────────────────────┘
                              │
                              ▼
┌─────────────────────────────────────────────────────────────┐
│  Step 2: 구조 분석 (get_metadata)                            │
│  - 전체 레이어 구조 파악                                     │
│  - 깊은 depth 감지 시 하위 nodeId 목록화 → 병렬 처리 준비     │
└─────────────────────────────────────────────────────────────┘
                              │
                              ▼
┌─────────────────────────────────────────────────────────────┐
│  Step 3: 병렬 정보 수집                                      │
│  ┌─────────────┬─────────────┬─────────────┐               │
│  │ 토큰 추출    │ 컴포넌트 분석 │ 레이아웃 분석│               │
│  │ (variables) │ (metadata)  │ (metadata)  │               │
│  └─────────────┴─────────────┴─────────────┘               │
└─────────────────────────────────────────────────────────────┘
                              │
                              ▼
┌─────────────────────────────────────────────────────────────┐
│  Step 4: 분석 & 정리                                         │
│  - 공통 컴포넌트 식별 및 중복 개수 집계                       │
│  - 레이아웃 패턴 추출 (Header, Footer, Sidebar 등)           │
│  - 토큰 체계 정리 (Color, Spacing, Typography, Radius 등)   │
└─────────────────────────────────────────────────────────────┘
                              │
                              ▼
┌─────────────────────────────────────────────────────────────┐
│  Step 5: 규칙 파일 생성                                      │
│  - Progressive Disclosure 원칙에 따라 구조화                 │
│  - .claude/rules/design-system/ 디렉토리 생성               │
└─────────────────────────────────────────────────────────────┘
```

---

## Step 1: 사용자 정보 수집 & 충돌 감지

### 필수 질문

| 항목 | 설명 |
|------|------|
| **Figma URL** | 디자인 시스템 파일 URL |
| **Node ID** (선택) | 특정 페이지/프레임 (전체 파일은 생략) |
| **clientLanguages** | `typescript`, `css` 등 |
| **clientFrameworks** | `react`, `nextjs`, `tailwind` 등 |

### 프로젝트 내 기존 자산 감지

**반드시 다음 파일/디렉토리 존재 여부 확인:**

```bash
# 토큰 관련
ls tailwind.config.* 2>/dev/null
ls **/tokens.* **/design-tokens.* 2>/dev/null
ls **/variables.scss **/variables.css 2>/dev/null

# 컴포넌트 관련
ls -d components/ ui/ src/components/ src/ui/ 2>/dev/null

# 기존 규칙
ls .claude/rules/design-system/ 2>/dev/null
```

**기존 자산이 있을 경우 반드시 질문:**

> 📁 프로젝트에 기존 디자인 자산이 발견되었습니다.
>
> **토큰 파일:**
> - `tailwind.config.ts` (Tailwind 설정)
> - `src/styles/tokens.css` (CSS 변수)
>
> **컴포넌트:**
> - `src/components/` (23개 컴포넌트)
> - `src/ui/` (12개 UI 요소)
>
> **기존 규칙:**
> - `.claude/rules/design-system/` (이전 추출본)
>
> 어떻게 처리할까요?
>
> 1. **참조하여 병합** - 기존 자산과 Figma 정보를 비교하여 통합
> 2. **Figma 우선** - Figma 정보로 덮어쓰기 (기존 자산은 참고용으로만)
> 3. **기존 유지** - 기존 자산 기준, Figma에서 누락된 것만 추가
> 4. **취소** - 작업 중단, 수동 검토 후 재시도

상세 충돌 해결: [references/conflict.md](references/conflict.md)

---

## Step 2-3: 정보 수집 (병렬 처리)

### 병렬 처리 기준

레이어 depth가 3 이상이거나, 최상위 노드가 5개 이상일 경우 **서브에이전트로 병렬 처리**:

```
# 순차 처리 (작은 파일)
get_metadata(fileKey, nodeId) → 전체 분석

# 병렬 처리 (큰 파일) - Task 도구로 에이전트 병렬 실행
├─ Task(figma-metadata-agent, nodeId_1)   # 페이지 1 분석
├─ Task(figma-metadata-agent, nodeId_2)   # 페이지 2 분석
├─ Task(figma-token-agent, fileKey)       # 토큰 추출
└─ 결과 병합
```

### 병렬 처리용 에이전트

| 에이전트 | 역할 | 도구 |
|---------|------|------|
| `figma-metadata-agent` | 특정 nodeId의 메타데이터 추출 | `get_metadata` |
| `figma-token-agent` | 전체 파일의 토큰 추출 | `get_variable_defs` |

에이전트 정의: [agents/](agents/) 디렉토리 참조

### 추출 대상

| 카테고리 | 추출 항목 | MCP 도구 | 에이전트 |
|---------|----------|----------|---------|
| **토큰** | Color, Spacing, Typography, Radius, Shadow | `get_variable_defs` | figma-token-agent |
| **컴포넌트** | 이름, 중복 개수, Description, Annotation | `get_metadata` | figma-metadata-agent |
| **레이아웃** | Header, Footer, Sidebar, Grid 패턴 | `get_metadata` | figma-metadata-agent |
| **패턴** | 반복되는 구조, 공통 프레임 | `get_metadata` | figma-metadata-agent |

상세 추출 방법: [references/extraction.md](references/extraction.md)

---

## Step 4: 분석 기준

### 공통 컴포넌트 식별

동일/유사 이름의 컴포넌트를 그룹화하고 중복 개수를 집계:

```markdown
| 컴포넌트 | 변형 | 중복 개수 | 비고 |
|---------|------|----------|------|
| Button | Primary, Secondary, Ghost | 47 | 공통화 권장 |
| Input | Text, Select, Checkbox | 23 | 공통화 권장 |
| Card | Default, Elevated | 15 | 공통화 권장 |
| Badge | - | 3 | 검토 필요 |
```

### 레이아웃 패턴 식별

```markdown
| 패턴 | 구성 | 사용처 |
|------|------|--------|
| AppShell | Header + Sidebar + Main | 대시보드 |
| AuthLayout | Center + Card | 로그인/회원가입 |
| ListDetail | List + Detail Panel | 목록 상세 |
```

상세 분석 기준: [references/analysis.md](references/analysis.md)

---

## Step 5: 출력 구조

### 생성되는 규칙 파일

```
.claude/rules/design-system/
├── AGENTS.md              # 진입점 - 규칙 개요
├── RULE.md                # 2단계 - 핵심 규칙 (<500줄)
└── references/            # 3단계 - 상세 문서
    ├── tokens.md          # 토큰 상세 (Color, Spacing, Typography)
    ├── components.md      # 공통 컴포넌트 목록 및 가이드
    ├── layouts.md         # 레이아웃 패턴
    └── annotations.md     # 디자이너 노트 및 Description
```

### Progressive Disclosure 적용

| 단계 | 파일 | 내용 |
|------|------|------|
| 1단계 | AGENTS.md | 개요, 언제 참조해야 하는지 |
| 2단계 | RULE.md | 핵심 규칙, 토큰 사용법, 금지 사항 |
| 3단계 | references/* | 전체 토큰 목록, 컴포넌트 상세, 레이아웃 가이드 |

상세 출력 형식: [references/output.md](references/output.md)

---

## MCP 설정 안내

MCP 호출 실패 시:

```
Figma MCP가 설정되지 않았습니다.

설정 방법:
1. Figma > Settings > Personal access tokens에서 토큰 생성
2. ~/.claude/mcp_settings.json에 추가:

{
  "mcpServers": {
    "figma": {
      "command": "npx",
      "args": ["-y", "@anthropic/figma-mcp"],
      "env": { "FIGMA_ACCESS_TOKEN": "your-token" }
    }
  }
}

3. Claude Code 재시작
```

---

## 사용 예시

```bash
# 기본 사용
/figma-design-rule-extractor

# URL 직접 전달
/figma-design-rule-extractor https://www.figma.com/file/ABC123/Design-System

# 특정 페이지만
/figma-design-rule-extractor https://www.figma.com/file/ABC123/Design-System?node-id=0:1
```

---

## 참조

- [추출 상세](references/extraction.md) - MCP 도구 사용법
- [분석 기준](references/analysis.md) - 컴포넌트/레이아웃 식별 기준
- [출력 형식](references/output.md) - 규칙 파일 템플릿
- [충돌 해결](references/conflict.md) - 기존 자산/규칙과의 충돌 처리

### 병렬 처리용 에이전트

- [figma-metadata-agent](agents/figma-metadata-agent.md) - 메타데이터 추출
- [figma-token-agent](agents/figma-token-agent.md) - 토큰 추출
