mockit-mcp
기능
Claude Code(또는 모든 MCP 클라이언트)에 요청하세요:
피트니스 트래커용 홈 대시보드를 디자인해줘. 3개의 동심원 활동 링, 주간 막대 차트, 최근 운동 목록, 네온 액센트가 있는 프리미엄 다크 모드.
mockit-mcp는 실제 PNG 목업(iPhone급 뷰포트인 390×844, 2x 배율) 및 기반이 되는 HTML/Tailwind 소스를 반환합니다. 이를 통해 시각적으로 반복 수정하고 빌드 준비가 되면 SwiftUI로 포팅할 수 있습니다.
이것은 정적 템플릿 엔진도 아니고 저품질 AI 생성물도 아닙니다. 시스템 프롬프트는 프리미엄 iOS 미학을 위해 수작업으로 조정되었습니다: 실제 콘텐츠, SVG 아이콘(이모지 사용 안 함), 스톡 사진 대신 세련된 그라데이션, iOS HIG 타이포그래피 스케일, 무거운 그림자 대신 톤 레이어링을 사용합니다.
주요 특징
두 가지 백엔드, 동일한 도구. 로컬
claudeCLI(구독형, 추가 비용 없음) 또는 Anthropic API(키 + 호출당 요금)를 사용하세요. 환경 변수 하나로 전환할 수 있습니다.실제 PNG 출력. Playwright를 통한 헤드리스 Chromium. 기본 뷰포트는 390×844 @2x(iPhone급)이며, 환경 변수로 사용자 지정 크기를 설정할 수 있습니다.
반복적 개선.
iterate_screen은 화면 ID와 피드백("히어로 카드를 더 작게 만들어줘")을 받아 부모/자식 관계를 추적하며 새 버전을 생성합니다.디스크 기반 라이브러리. 모든 생성물은 HTML + PNG + JSON 메타데이터로 저장됩니다. 탐색, 필터링, 재내보내기가 가능합니다.
MCP 표준. Claude Code, Claude Desktop, Cursor, Windsurf 또는 모든 MCP 클라이언트와 호환됩니다.
Stdio + HTTP 전송. 개발을 위해 로컬에서 실행하거나, 공유/컨테이너 환경을 위해 네트워크 서비스로 실행하세요.
도구
도구 | 설명 |
| 텍스트 요약 → PNG + HTML. 선택적 |
| 이전 |
| 화면 목록 나열(프로젝트별 필터링 가능). |
| 특정 화면의 메타데이터(또는 전체 HTML) 가져오기. |
설치
사전 요구 사항
Node.js 20+
로그인된
claudeCLI(cli백엔드, 기본값) 또는 Anthropic API 키(api백엔드)Playwright의 Chromium 다운로드(~170 MB, 1회)
빠른 시작 (CLI 백엔드, 로컬 개발 권장)
git clone https://github.com/karyaboyraz/mockit-mcp.git
cd mockit-mcp
npm install
npx playwright install chromium
npm run buildClaude Code에 추가:
claude mcp add mockit -- node "$(pwd)/dist/server.js"완료되었습니다. API 키가 필요 없으며, 기존 claude CLI 세션을 사용합니다.
API 백엔드 (호스트에 claude CLI가 없는 경우)
echo "CLAUDE_BACKEND=api" > .env
echo "ANTHROPIC_API_KEY=sk-ant-..." >> .env
npm run build
claude mcp add mockit -- node "$(pwd)/dist/server.js"Docker (HTTP 전송, 공유 배포용)
cat > .env <<'ENV'
CLAUDE_BACKEND=api
ANTHROPIC_API_KEY=sk-ant-...
# Required if you change the port binding from 127.0.0.1 to 0.0.0.0:
MCP_HTTP_TOKEN=$(openssl rand -hex 32)
ENV
docker compose up -d --build기본적으로 docker-compose.yml은 HTTP 포트를 127.0.0.1에만 바인딩하며, 서버는 루프백이 아닌 모든 요청에 대해 MCP_HTTP_TOKEN을 요구합니다. 강력한 MCP_HTTP_TOKEN을 설정하지 않고 이 서버를 공용 네트워크에 노출하지 마십시오. 모든 생성 작업이 귀하의 Anthropic API 키를 사용합니다.
그런 다음 클라이언트를 루프백 URL로 지정하세요:
claude mcp add --transport http mockit http://127.0.0.1:7821/mcp \
-H "Authorization: Bearer <MCP_HTTP_TOKEN>"원격 액세스를 위해서는 docker-compose.yml의 포트 바인딩을 0.0.0.0:7821:7821로 변경하고 MCP_HTTP_TOKEN이 설정되었는지 확인하십시오. 그렇지 않으면 서버가 시작되지 않습니다.
사용법
모든 MCP 클라이언트에서 다음과 같이 요청하세요:
피트니스 트래커 대시보드를 디자인해줘. 오늘의 링 진행 상황, 주간 차트, 최근 운동 목록을 보여줘. 다크 모드, 네온 그린 액센트.
PNG가 인라인으로 나타납니다. HTML은 designs/{project}/{name}-{id}.html에 저장됩니다.
후속 작업:
해당 피트니스 대시보드를 반복 수정해줘 — 차트를 시간 경과에 따른 심박수로 바꾸고, 아래에 "운동 공유" 버튼을 추가해줘.
프롬프트 패턴 및 전체 출력 예시는 examples/를 참조하세요.
구성
모두 선택 사항입니다. 전체 목록은 .env.example을 참조하세요.
환경 변수 | 기본값 | 참고 |
|
|
|
| — |
|
|
| API 백엔드 전용. Opus 액세스 권한이 없으면 |
|
|
|
|
| 하위 프로세스 타임아웃 |
|
|
|
|
| HTTP 전송 포트 |
|
| 바인딩 인터페이스; 루프백이 아닌 경우 |
| — | HTTP 인증용 Bearer 토큰. |
|
| 출력물이 저장되는 위치 |
|
| CSS 픽셀 단위 렌더링 너비 |
|
| CSS 픽셀 단위 렌더링 높이 |
|
| 레티나 팩터 (최종 PNG는 |
|
|
|
비용
생성당: 약 3K 입력 토큰(시스템 프롬프트) + 화면 복잡도에 따라 약 6–12K 출력 토큰. Opus에서는 출력 비용이 지배적입니다.
백엔드 | 첫 호출 | 캐시된 후속 호출 |
| Claude Code 구독 할당량 차감 | 동일 — 캐시는 시스템 프롬프트만 할인 |
| ~$0.50–0.95 (Opus 4.7) | ~$0.45–0.90 (캐시는 시스템 프롬프트 입력만 할인; 출력 비용은 동일) |
시스템 프롬프트 캐싱은 기본적으로 켜져 있습니다(5분 TTL). 호출당 몇 센트를 절약하지만 획기적인 할인은 아닙니다. 출력 토큰은 여전히 전체 요금이 청구됩니다. 실질적인 비용 절감을 위해서는 더 작은 모델(claude-sonnet-4-6 또는 claude-haiku-4-5)으로 전환하세요.
아키텍처
┌─────────────────┐
│ MCP Client │ (Claude Code, Cursor, Windsurf, …)
└────────┬────────┘
│ tool call: generate_screen({ prompt, ... })
▼
┌─────────────────────────────────────────────────────┐
│ mockit-mcp │
│ │
│ ┌──────────────┐ ┌────────────────────────┐ │
│ │ Backend │ │ Renderer │ │
│ │ │ │ │ │
│ │ ► cli ─────┼──► │ Playwright (headless │ │
│ │ ► api ─────┘ │ Chromium @ iPhone │ │
│ │ → HTML+Tailwind │ viewport) │ │
│ └──────────────┘ │ → PNG screenshot │ │
│ └────────────────────────┘ │
│ │
│ ┌────────────────────────────────────────────┐ │
│ │ Storage (disk): HTML + PNG + JSON metadata │ │
│ └────────────────────────────────────────────┘ │
└─────────────────────────────────────────────────────┘저장소 레이아웃
designs/
└── {project-slug}/
├── {name-slug}-{id8}.html # id8 = first 8 chars of the screen UUID
├── {name-slug}-{id8}.png
└── {name-slug}-{id8}.json # full UUID, prompt, parent ID, tokens, model, cost디자인 보이스 튜닝
수작업으로 조정된 시스템 프롬프트는 src/system-prompt.ts에 있습니다. 이곳에서 iOS HIG 강제 적용, 스톡 사진 금지 규칙, SF Pro 폴백 체인, 편집 타이포그래피 선호도가 인코딩됩니다. 대신 Material You나 데스크톱 대시보드 보이스를 원하시면 수정하세요.
개발
npm run dev # tsx watch mode, stdio transport
npm run http # tsx watch mode, http transport on :7821
npm run build # compile to dist/로드맵
[ ] Watch / iPad / Android 뷰포트 프리셋
[ ] 다중 화면 흐름 생성 (온보딩 시퀀스)
[ ] HTML → SwiftUI / Jetpack Compose 포팅 도구
[ ] 디자인 시스템 가져오기 (Tailwind 설정, 디자인 토큰)
[ ] 이미지 참조 (시각적 영감을 위해
--image사용)[ ] 변형 생성 (프롬프트당 3-5개 대안)
기여
이슈 및 PR 환영합니다 — CONTRIBUTING.md를 참조하세요.
라이선스
감사의 말
다음 기술을 기반으로 구축되었습니다:
Anthropic Claude — 핵심 작업을 수행하는 모델
Model Context Protocol — 통합 표준
Playwright — 렌더러
Tailwind CSS — CDN을 통해 모든 생성된 화면에 적용
상표
iPhone, iPad, Apple Watch 및 iOS는 Apple Inc.의 상표입니다. Claude는 Anthropic, PBC의 상표입니다. mockit-mcp는 독립적인 오픈 소스 프로젝트이며 Apple Inc. 또는 Anthropic, PBC와 제휴, 보증 또는 후원되지 않습니다. 기타 모든 제품 이름, 로고 및 브랜드는 해당 소유자의 자산입니다.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/karyaboyraz/mockit-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server