name: omd:init description: "프로젝트 루트에 DESIGN.md를 부트스트랩 — 실제 기업 레퍼런스 중 컨텍스트 매칭으로 추천하고 선택된 레퍼런스의 톤&매너를 보존한 variation을 생성. DESIGN.md 부재 상태에서의 UI 작업 또는 '디자인 시스템 세팅', 'set up our design system', 「デザインシステムを作って」, 「建立設計系統」류의 요청에 트리거. CLAUDE.md / AGENTS.md / Cursor rule shim도 함께 설치."
omd:init — DESIGN.md Bootstrap
프로젝트에 DESIGN.md + AI 코딩 에이전트용 shim 3종을 한 번에 세팅. 레퍼런스 톤&매너는 preserve하고, 사용자 프로젝트 맥락은 controlled-vocabulary delta_set으로만 반영.
CLI 호출 없음 — Read/Write/Bash(파일 작업만) 툴로 직접 처리. (이전 버전은 omd init recommend 등 CLI subcommand를 호출했으나 현재 CLI binary는 install-skills만 노출. 이 skill은 self-contained하게 동작.)
전체 플로우
Phase 1: 사용자 맥락 파악 (1-2 질문)
Phase 2: 레퍼런스 추천 (fingerprint 기반 in-head 점수)
Phase 3: 사용자가 1개 선택
Phase 3.5: 적용 형태 확인 (루트 부트스트랩 / 참고용 저장 / 기존 파일 교체 여부)
Phase 4: 레퍼런스 DESIGN.md Read + delta_set 추출
Phase 4.5: Philosophy Layer 입력 수집
Phase 5: Hybrid variation으로 DESIGN.md 작성
Phase 6: Shim 3종 설치 (omd:sync skill 위임)
Phase 7: 요약 출력
Phase 1 — 맥락 파악
이미 충분한 description이 있으면 skip. 부족하면 최대 2개 질문:
- 프로젝트 유형/도메인 (SaaS / 랜딩 / 대시보드 / 이커머스 / 커뮤니티 등)
- 분위기 키워드 (warm, minimal, premium, playful, dense, airy 등)
한 번에 하나씩, 또는 통합해서 한 번에. 질문 쌓지 말 것.
Phase 2 — 레퍼런스 추천 (file-based, no CLI)
2.1 카탈로그 로드
다음 파일을 Read 툴로 전체 로드 (있는 순서대로 fallback):
.claude/data/reference-fingerprints.json(사용자 프로젝트에 설치된 카탈로그 — 표준 경로)node_modules/oh-my-design-cli/data/reference-fingerprints.json(npm 설치 직접 경로)data/reference-fingerprints.json(개발 환경)
스키마: { count, items: [{ id, primary_color_hex, category, visual_theme, voice_fingerprint, tone_keywords, antipatterns, signature_motion, has_personas, category_raw }] }.
추가 보조 파일 (있으면 같이 로드):
.claude/data/vocabulary.json— controlled vocab axes/keywords.claude/data/reference-tags.md— human-readable keyword matrix
2.2 task 분석 (silent, in-head)
사용자의 description에서 다음 추출:
- 명시 brand hint: 한글/영문 brand 이름 직접 언급 (예: "토스 같은" →
toss, "뱅크샐러드 톤" →banksalad, "Linear-clone" →linear.app). brand 이름과 id 매핑은 일반 지식 사용 +items[].id또는items[].category_raw에서 cross-check. - vocab 키워드: warm / minimal / dense / playful / formal / editorial / clinical 등 (vocabulary.json 참조)
- 카테고리 추측: Consumer Tech / Fintech / Productivity / E-commerce / Design Tools / Developer Tools / AI & LLM / Mobility / HR / Real Estate / Healthcare / Government
2.3 점수 계산 (in-head, deterministic)
각 item에 대해:
- brand hint match → +5점
tone_keywords∩ task vocab 키워드 → 매칭당 +1점category일치 → +1점
Top 5 정렬. 모든 추천 id는 items[].id에 반드시 존재 — hallucination 금지.
2.4 사용자에게 제시
prose로:
"<task 핵심 한 줄>"을 보니 <top1.id>가 가장 잘 맞을 것 같아요 — <visual_theme 핵심 한 줄 + 매칭 키워드 1-2개>.
이대로 가시려면 go (또는 <top1.id>).
다른 후보: <top2.id> (한 줄 이유) · <top3.id> (...) · <top4.id> (...) · <top5.id> (...)
본인이 아는 다른 reference 있으면 id로 알려주세요 (예: vercel) — 카탈로그에 없으면 알려드립니다.
vocab axis conflict 있으면 (예: formal ↔ playful) 먼저 알리고 우선시할 축을 묻기.
Claude Code 채널이면 위 prose 대신 AskUserQuestion 툴 1개로 제시 (사용자가 화살표로 고르는 selectable UI — #21). question 1개에 top-5 후보 id 5개를 option으로:
question: ""<task 핵심 한 줄>"에 맞는 레퍼런스를 골라주세요"
header: "Reference"
options: top1~top5 각각 → label = <id>, description = fingerprint 기반 1줄 (<category> · <tone_keywords 1-2개>)
- top1에는 label에 "(추천)" 표시
(AskUserQuestion이 자동 "Other"를 추가하므로 카탈로그의 다른 id를 자유 입력으로 답하는 것도 그대로 가능.) Codex / OpenCode 등 AskUserQuestion이 없는 채널은 위 prose 포맷 유지. 점수 계산·채택 로직(Phase 3)은 어느 쪽이든 동일.
Phase 3 — 사용자 선택
go또는 top-5 안 id → 그 id 채택- top-5 밖이지만 카탈로그 안 id → 그대로 채택
- 카탈로그에 없는 id → "해당 id는 카탈로그에 없어요. top-5 중에서 골라주세요."
- "중단" → 종료
Phase 3.5 — 적용 형태 확인
레퍼런스 확정 직후, 어떻게 적용할지 묻는다. 먼저 프로젝트 루트에 DESIGN.md가
이미 있는지 확인하고, Claude Code 채널이면 AskUserQuestion 1개 (타 채널은
prose)로:
- 루트에 DESIGN.md 없음:
- 프로젝트 디자인 시스템으로 설정 (추천) —
<id>톤을 보존한 변형본을 루트DESIGN.md로 부트스트랩 (Phase 4~7 전체 진행) - 참고용으로만 저장 — 루트 변경 없음.
<id>원본을design-references/<id>.md로 복사하고 종료. "나중에 프로젝트에 적용하려면 다시 omd:init을 불러주세요" 안내. (변형 생성·셤 설치 안 함)
- 프로젝트 디자인 시스템으로 설정 (추천) —
- 루트에 DESIGN.md 이미 있음 (option description에 그 파일의 §0/§1 요약
한 줄을 보여줄 것):
- 교체 (추천) — 기존 파일은
DESIGN_DEPRECATED.md로 보존됨을 명시 - 참고용으로만 저장 — 위와 동일
- 중단
- 교체 (추천) — 기존 파일은
②(참고용) 선택 시: Phase 4.1로 원문만 확보해 design-references/<id>.md에
attribution 1줄(소스 URL + 날짜)과 함께 저장 → Phase 7 요약만 출력하고 종료.
Phase 4.2~6은 건너뛴다.
Phase 4 — 레퍼런스 DESIGN.md 로드
4.1 경로 결정
선택된 id를 <id>로 하고, 다음 순서로 Read (먼저 존재하는 것 사용):
.claude/data/references/<id>/DESIGN.md(installer가 복사 — npx 설치 기본 경로)node_modules/oh-my-design-cli/web/references/<id>/DESIGN.md(로컬 npm 설치 직접 경로)web/references/<id>/DESIGN.md(개발 레포)https://oh-my-design.kr/design-systems/<id>.md를 fetch (WebFetch 또는curl -fsSL) — 1~3 로컬 경로가 전부 없을 때 (npx 설치가 기본 경로라 흔한 상황). 200이면 응답 본문이 곧 reference DESIGN.md다. 가져온 내용을.claude/data/references/<id>/DESIGN.md로 저장해 다음 실행부터는 로컬 캐시(경로 1)로 잡히게 한다.
4까지 전부 실패하면 절대 DESIGN.md를 임의로 지어내지 말 것. 사용자에게
"레퍼런스 <id> 원문을 찾지 못했어요 (오프라인이거나 카탈로그 미배포).
네트워크 연결 후 재시도하거나 다른 레퍼런스를 골라주세요"라고 보고하고 종료.
전체 내용을 reference_md 변수로 보관 (Phase 5의 입력).
4.2 기존 DESIGN.md 처리
프로젝트 루트에 이미 DESIGN.md가 있으면 (Phase 3.5에서 이미 "교체"를 확인받은
상태 — 여기서 다시 묻지 않는다):
- Read로 내용 확인
- Bash로
mv DESIGN.md DESIGN_DEPRECATED.md DESIGN_DEPRECATED.md최상단에 다음 헤더 prepend (Edit 툴):<!-- omd:deprecated replaced_at: <ISO-8601 today> replaced_by: ./DESIGN.md (bootstrapped from <id>) reason: omd:init bootstrap -->
4.3 init-context 기록
.omd/init-context.json 작성 (없으면 mkdir):
{
"reference_id": "<id>",
"description": "<원본 사용자 description>",
"mode": "clone | inspired",
"delta_set": {
"axes": { /* description에서 추출한 vocab axis ↦ shift 값 */ },
"voiceHints": [ /* 추출된 voice 힌트 */ ],
"matchedKeywords": [ /* 매칭된 vocab 키워드 */ ],
"warnings": [ /* axis conflict 등 */ ]
},
"bootstrapped_at": "<ISO-8601>"
}
빌더(oh-my-design.kr/builder)발 프롬프트에는 "Components: button, input, ..." 목록과
"(builder config: "requested_components": ["button", "input", ...]
키로 함께 기록하고, builder URL은 출처 표기용으로만 보존 — fetch하지 말 것.
mode 값 결정:
- omd:reference-capture가 먼저 돌았으면 그 결과 사용 (
.omd/init-context.json기존값) - 아직 정해지지 않았으면 사용자에게 묻기 (omd:reference-capture Phase 0과 동일한 prompt). 라이브 캡쳐 없이 omd:init만 단독으로 도는 경우는 사실상 inspired 외엔 의미 없으므로 기본
inspired.
axes 표준 키: color.hue_deg (도), color.saturation_pct (%p), color.lightness_pct (%p), radius.delta_px (px), density.shift (-2 ~ +2), tracking.shift (-0.01em ~ +0.01em).
Phase 4.5 — Philosophy Layer 입력 수집 (CRITICAL)
§11 (Brand Narrative), §12 (Principles), §13 (Personas)는 레퍼런스의 검증된 historical facts에 기반. 단순 domain swap하면 거짓 brand claim을 ship하는 사고가 난다.
Phase 5B 진입 전 사용자에게 한 번에 묻기:
DESIGN.md의 §11-13 (Brand Narrative / Principles / Personas)에는 사실 정보가 들어갑니다. 다음을 알려주시거나 "skip"이라고 답해주세요:
1. 프로젝트 이름 / 창립 시점 (대략)
2. 핵심 thesis 한 문장 (e.g. Airbnb의 "Belong Anywhere")
3. 공식 tagline 또는 거부하는 카테고리 default
4. 타겟 사용자 segment 2-4개
답변 받으면 → §11-13에 반영
"skip" → §11-13은 [FILL IN: ...] placeholder + omd:limitation 코멘트
부분 답변은 받은 부분만 사용, 나머지 skip.
Phase 5 — Hybrid Variation 생성 (핵심)
reference_md + .omd/init-context.json delta_set을 입력으로 새 DESIGN.md 작성.
Phase 5A — Voice Fingerprint 내부 추출 (silent)
출력 금지. 작성 전 머릿속으로 파악:
- 평균 문장 길이 밴드
- 어휘 register (engineering-terse / editorial-warm / clinical / playful 중)
- 은유 밀도
- 기술 밀도 (token-heavy / prose-heavy / balanced)
- 문단 리듬 (list-forward / paragraph-forward)
Phase 5B emit하는 모든 내러티브를 이 fingerprint에 정확히 맞춰야 한다.
Phase 5B — 새 DESIGN.md emit
엄격 규칙 (위반 = regression):
Section 구조 frozen: 레퍼런스의 H2/H3 heading을 같은 순서로 그대로. 추가/삭제/이름 변경 금지.
Token 값 해석 우선순위 (위에서 아래로):
assets/_reference/<id>/tokens.jsonlive_overrides블록 — 현재 라이브 사이트의 토큰 (omd:reference-capture가 라이브 inspect로 얻은 값). 있으면 이걸 base로.web/references/<id>/DESIGN.md(또는node_modules/.../web/references/<id>/DESIGN.md) — DESIGN.md가 brand intent로 기록한 canonical 값. live_overrides 없으면 이걸 base로.delta_set.axes— 사용자 customization. base 위에 가산.- 색상: HSL 변환 후
color.hue_deg/saturation_pct/lightness_pct적용. - radius:
radius.delta_px만큼 가산 (음수도 가능).
- 색상: HSL 변환 후
- 그 외 토큰은 손대지 말 것. "개선" 금지.
- canonical과 live가 충돌하면 사용자에게 한 줄로 알림 + 라이브 사용 (예: "Banksalad canonical은
#04c5842px radius, 라이브는#13bd7e41px pill — 라이브 기준으로 진행합니다. canonical로 가시려면 'use canonical'이라고 알려주세요."). - 단 brand essence (voice·principles·motion philosophy·voice samples)는 canonical 절대 권위. live는 visual surface(토큰·컴포넌트 shape)에만 적용.
내러티브는 Phase 5A fingerprint에 매칭: 도메인 예시 교체 시 문장 길이/register/은유 밀도 그대로. 명사만 swap, 동사/형용사/framing 손대지 말 것.
새 philosophy 도입 금지: OmD v0.1 layer, 없던 원칙 추가 금지. delta-derived 노트는 새 bullet으로 넣지 말고 기존 bullet에 자연스럽게 통합.
해결 불가능 delta는 top-of-file HTML comment:
<!-- omd:unresolved: <axis> -->상단 추가, 해당 token은 건드리지 않음.Voice hints 반영:
delta_set.voiceHints는 Voice 섹션 내러티브에 반영하되 레퍼런스 voice 스타일 안에서만. "contractions ok" → Voice 원칙 bullet에 한 줄 추가.§11-13 처리 분기:
- Phase 4.5에서 정보 제공: 그 정보로 §11/12/13 작성. verbatim 인용은 사용자가 직접 준 표현만. 레퍼런스의 시간 표현·공식 인용 모두 사용자 맥락으로 대체.
- Phase 4.5에서 skip: §11-13 본문을
[FILL IN: <섹션 목적 한 줄>]placeholder + 각 섹션 상단<!-- omd:limitation Reference §X requires project-specific facts. Replace before shipping; do not fabricate. -->. - §14 (States), §15 (Motion): 일반 Hybrid 적용 (구체 명사만 swap).
Frontmatter:
--- omd: 0.1 brand: <Project Name or "Project"> bootstrapped_from: <id> bootstrapped_at: <ISO-8601> ---
Phase 5C — 파일 작성
Write 툴로 DESIGN.md emit.
Phase 6 — Shim 설치
CLI subcommand 없음. 두 가지 옵션:
옵션 A (권장): omd:sync skill 위임. 같은 conversation에서 Skill 툴로:
Skill: omd:sync
args: --force
omd:sync skill이 CLAUDE.md, AGENTS.md, .cursor/rules/omd-design.mdc shim 3종을 생성/갱신하고 .omd/sync.lock.json 업데이트.
옵션 B: omd:sync skill을 호출할 수 없는 환경이면 직접 Write로 shim 작성. 템플릿은 .claude/skills/omd-sync/SKILL.md (설치 경로; dev 레포에서는 skills/omd-sync/SKILL.md) §"shim body" 참조. 최소한:
CLAUDE.md: managed block (" ... ") 안에 DESIGN.md 참조 + 핵심 token 요약AGENTS.md: 동일 패턴.cursor/rules/omd-design.mdc: 전체 파일 omd 전용 — frontmatter + DESIGN.md 인용
이후 .omd/sync.lock.json에 각 shim의 hash 기록.
Phase 7 — 요약 출력
한 문단으로:
- Base reference + 프로젝트 context 한 줄 요약
- 적용된 주요 delta 2-3개 (e.g. "primary hue shifted warm by +12°, radius +4px")
- 생성된 파일 목록 (DESIGN.md + shims)
- DESIGN_DEPRECATED.md 있으면 언급
- 다음 스텝:
omd:apply로 UI 작업 시작 또는omd:harness로 전체 surface 디자인 또는omd:remember로 선호 추가 로깅
예시:
✓ DESIGN.md created (based on banksalad, 한국 핀테크 랜딩 맥락)
- primary hue 유지 (#04c584 그대로)
- radius 유지 (2px 시스템)
- voice hints: 데이터 어드바이저 톤
Shim files:
✓ CLAUDE.md (managed block)
✓ AGENTS.md (managed block)
✓ .cursor/rules/omd-design.mdc
Next:
- UI 작업 시작 → omd:apply로 자동 라우팅됨
- 전체 surface 디자인 (랜딩, 대시보드 등) → omd:harness
- 디자인 선호 로깅 → /omd:remember <note>
금지
- Phase 5A fingerprint를 출력하지 말 것 (내부 전용).
delta_set.axes에 없는 token을 마음대로 바꾸지 말 것.- 레퍼런스에 없는 section/heading을 추가하지 말 것.
.omd/init-context.json을 직접 편집할 때 schema 어기지 말 것.- DESIGN.md가 이미 있는데 백업 없이 덮어쓰지 말 것 (Phase 4.2 rename 절차 준수).
- 존재하지 않는 CLI subcommand (
omd init recommend,omd init prepare,omd sync)를 호출하지 말 것 — 현 CLI binary는install-skills만 제공.