Skip to main content
Glama

Was es tut

Fragen Sie Claude Code (oder einen beliebigen MCP-Client):

Entwirf das Home-Dashboard für einen Fitness-Tracker. Drei konzentrische Aktivitätsringe, wöchentliches Balkendiagramm, Liste der letzten Workouts, Premium-Dark-Mode mit Neon-Akzenten.

mockit-mcp liefert ein echtes PNG-Mockup (Größe 390×844 bei 2x Skalierung, ein Viewport der iPhone-Klasse) und den zugrunde liegenden HTML/Tailwind-Quellcode – damit Sie visuell iterieren und auf SwiftUI portieren können, wenn Sie bereit für die Entwicklung sind.

Es ist keine statische Template-Engine und kein generischer KI-Müll. Der System-Prompt ist handoptimiert für erstklassige iOS-Ästhetik: echte Inhalte, SVG-Icons (keine Emojis), geschmackvolle Verläufe anstelle von Stockfotos, iOS HIG-Typografie-Skalierung und tonale Schichtung anstelle von schweren Schatten.

Highlights

  • Zwei Backends, dieselben Tools. Nutzen Sie das lokale claude CLI (Abonnement, keine Extrakosten) oder die Anthropic-API (Key + nutzungsbasierte Abrechnung). Wechseln Sie mit einer Umgebungsvariablen.

  • Echte PNG-Ausgabe. Headless Chromium via Playwright. Standard-Viewport ist 390×844 @2x (iPhone-Klasse); jede benutzerdefinierte Größe ist nur eine Umgebungsvariable entfernt.

  • Iterative Verfeinerung. iterate_screen nimmt eine Screen-ID + Feedback ("mach die Hero-Card kleiner") und erstellt eine neue Version, wobei Eltern-/Kind-Beziehungen nachverfolgt werden.

  • Festplattenbasierte Bibliothek. Jede Generierung speichert HTML + PNG + JSON-Metadaten. Durchsuchen, filtern, erneut exportieren.

  • MCP-Standard. Funktioniert mit Claude Code, Claude Desktop, Cursor, Windsurf oder jedem MCP-Client.

  • Stdio + HTTP-Transporte. Lokal für die Entwicklung ausführen oder als Netzwerkdienst für geteilte/containerisierte Nutzung.

Tools

Tool

Beschreibung

generate_screen

Text-Briefing → PNG + HTML. Optionale design_system- und project-Felder.

iterate_screen

Nimmt eine vorherige screen_id + feedback-String, erstellt eine neue Version.

list_screens

Listet Screens auf, optional gefiltert nach Projekt.

get_screen

Ruft Metadaten (oder vollständiges HTML) für einen bestimmten Screen ab.

Installation

Voraussetzungen

  • Node.js 20+

  • Entweder das angemeldete claude CLI (cli-Backend, Standard) oder einen Anthropic-API-Key (api-Backend)

  • Playwrights Chromium-Download (~170 MB, einmalig)

Schnellstart (CLI-Backend, empfohlen für lokale Entwicklung)

git clone https://github.com/karyaboyraz/mockit-mcp.git
cd mockit-mcp
npm install
npx playwright install chromium
npm run build

Zu Claude Code hinzufügen:

claude mcp add mockit -- node "$(pwd)/dist/server.js"

Fertig. Kein API-Key erforderlich – es nutzt Ihre bestehende claude CLI-Sitzung.

API-Backend (kein claude CLI auf dem Host)

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-Transport, für geteilte Bereitstellung)

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

Standardmäßig bindet docker-compose.yml den HTTP-Port nur an 127.0.0.1 und der Server erfordert MCP_HTTP_TOKEN für jede Anfrage, die nicht vom Loopback kommt. Setzen Sie diesen Server keinem öffentlichen Netzwerk aus, ohne ein starkes MCP_HTTP_TOKEN zu konfigurieren – jede Generierung belastet Ihren Anthropic-API-Key.

Verweisen Sie dann jeden Client auf die Loopback-URL:

claude mcp add --transport http mockit http://127.0.0.1:7821/mcp \
  -H "Authorization: Bearer <MCP_HTTP_TOKEN>"

Für Fernzugriff ändern Sie das Port-Binding in der docker-compose.yml auf 0.0.0.0:7821:7821 und stellen Sie sicher, dass MCP_HTTP_TOKEN gesetzt ist – andernfalls verweigert der Server den Start.

Verwendung

Fragen Sie in einem beliebigen MCP-Client einfach:

Entwirf ein Fitness-Tracker-Dashboard. Zeige den heutigen Ring-Fortschritt, ein wöchentliches Diagramm und eine Liste der letzten Workouts. Dark Mode, neon-grüner Akzent.

Das PNG erscheint inline. Das HTML wird unter designs/{project}/{name}-{id}.html gespeichert.

Für Nachbesserungen:

iterate_screen auf diesem Fitness-Dashboard — ersetze das Diagramm durch die Herzfrequenz über die Zeit und füge einen "Workout teilen"-Button darunter hinzu.

Siehe examples/ für Prompt-Muster und vollständige Ausgaben.

Konfiguration

Alles optional. Siehe .env.example für die vollständige Liste.

Env

Standard

Notizen

CLAUDE_BACKEND

cli

cli nutzt das claude CLI; api nutzt das Anthropic SDK direkt

ANTHROPIC_API_KEY

Nur für api-Backend erforderlich

ANTHROPIC_MODEL

claude-opus-4-7

Nur API-Backend. Wenn Ihr Konto keinen Opus-Zugriff hat, setzen Sie es auf claude-sonnet-4-6 oder claude-haiku-4-5

CLAUDE_CLI_PATH

claude

Pfad zum claude-Binary

CLAUDE_CLI_TIMEOUT_MS

180000

Subprocess-Timeout

MCP_TRANSPORT

stdio

stdio oder http

HTTP_PORT

7821

HTTP-Transport-Port

HTTP_HOST

127.0.0.1

Bind-Interface; Nicht-Loopback erfordert MCP_HTTP_TOKEN

MCP_HTTP_TOKEN

Bearer-Token für HTTP-Auth. Erforderlich, wenn HTTP_HOST kein Loopback ist

DESIGNS_DIR

./designs

Wo Ausgaben gespeichert werden

VIEWPORT_WIDTH

390

Render-Breite in CSS-Pixeln

VIEWPORT_HEIGHT

844

Render-Höhe in CSS-Pixeln

DEVICE_SCALE

2

Retina-Faktor (finales PNG ist WIDTH × DEVICE_SCALE breit)

PLAYWRIGHT_NO_SANDBOX

auto

auto = Sandbox außerhalb von Containern aktiviert; true zum Erzwingen der Deaktivierung, false zum Erzwingen der Aktivierung. Deaktivierung reduziert die Isolation gegenüber bösartigem Modell-HTML – tun Sie dies nur innerhalb eines Containers.

Kosten

Pro Generierung: ~3K Input-Token (System-Prompt) + ~6–12K Output-Token, abhängig von der Screen-Komplexität. Die Ausgabe dominiert die Kosten bei Opus.

Backend

Erster Aufruf

Zwischengespeicherte Nachbesserung

cli

zählt gegen Ihr Claude Code-Abonnement-Kontingent

gleich — Cache rabattiert nur den System-Prompt

api

~$0.50–0.95 (Opus 4.7)

~$0.45–0.90 (Cache rabattiert nur den System-Prompt-Input; Output-Kosten bleiben unverändert)

System-Prompt-Caching ist standardmäßig aktiviert (5 Minuten TTL). Es spart ein paar Cent pro Aufruf, ist aber kein Rabatt in der Größenordnung von Zehnerpotenzen – Output-Token werden weiterhin zum vollen Preis berechnet. Für echte Kostenreduzierung wechseln Sie zu einem kleineren Modell (claude-sonnet-4-6 oder claude-haiku-4-5).

Architektur

┌─────────────────┐
│   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 │    │
│  └────────────────────────────────────────────┘    │
└─────────────────────────────────────────────────────┘

Speicherlayout

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

Anpassung der Design-Stimme

Der handoptimierte System-Prompt befindet sich in src/system-prompt.ts. Hier sind die Durchsetzung der iOS HIG, die Regel gegen Stockfotos, die SF Pro-Fallback-Kette und die redaktionellen Typografie-Präferenzen kodiert. Wollen Sie stattdessen Material You oder eine Desktop-Dashboard-Stimme? Bearbeiten Sie ihn.

Entwicklung

npm run dev    # tsx watch mode, stdio transport
npm run http   # tsx watch mode, http transport on :7821
npm run build  # compile to dist/

Roadmap

  • [ ] Watch / iPad / Android Viewport-Presets

  • [ ] Multi-Screen-Flow-Generierung (Onboarding-Sequenzen)

  • [ ] HTML → SwiftUI / Jetpack Compose Port-Tool

  • [ ] Design-System-Import (Tailwind-Konfiguration, Design-Tokens)

  • [ ] Bildreferenzen (nutzen Sie --image für visuelle Inspiration)

  • [ ] Varianten-Generierung (3-5 Alternativen pro Prompt)

Mitwirken

Issues und PRs sind willkommen – siehe CONTRIBUTING.md.

Lizenz

MIT

Danksagungen

Aufgebaut auf:

Marken

iPhone, iPad, Apple Watch und iOS sind Marken von Apple Inc. Claude ist eine Marke von Anthropic, PBC. mockit-mcp ist ein unabhängiges Open-Source-Projekt und ist nicht mit Apple Inc. oder Anthropic, PBC verbunden, wird von diesen nicht unterstützt oder gesponsert. Alle anderen Produktnamen, Logos und Marken sind Eigentum ihrer jeweiligen Inhaber.

Install Server
A
license - permissive license
A
quality
C
maintenance

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