tell-ai-ui-critic
Allows capturing and diagnosing GitHub repositories by cloning them, reading the README, installing dependencies, booting the dev server, and capturing the local UI automatically.
Powers the taste engine's richer rationales and art-direction refinement for generating detailed design critiques and redesign descriptions.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@tell-ai-ui-criticcapture and diagnose my login page for AI tells"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Tell
Every AI-built UI has a tell.
Tell is an open-source design critic that reads the rendered UI of your product, names exactly what makes it look AI-generated, and helps you art-direct a distinctive redesign — without leaving Cursor.
Quick start · Features · How it works · Use it in Cursor · Project structure

The shipped README demo asset lives in docs/media/tell-demo.gif. Raw Playwright recordings can be regenerated under output/playwright/, which stays ignored as local build output.
The problem
You can ship a whole product in a weekend now. That's the good news.
The bad news is that most of what gets shipped looks identical. Inter everywhere. One purple gradient in the hero. A soft shadow on every card. Rounded corners at exactly 8 pixels. It isn't ugly — it's forgettable. And as you and your AI agent keep iterating, the surface quietly drifts: six almost-identical grays, focus rings that only half the app bothers with, an empty state nobody designed.
You can feel that something is off, but you can't name it. "Add more whitespace" isn't a direction. Hiring a designer for a day is $800 and a two-week wait. Your demo is tomorrow.
Tell fixes the part that's actually hard: knowing what's wrong, and showing you a better direction you can ship yourself.
Related MCP server: Sketch Context MCP
What Tell does
Tell looks at your product the way a person does — it opens the page in a real browser and reads what actually renders, not your source code. Then it does four things:
Names the tells. It points at the specific patterns that read as generic, with evidence you can see on the screenshot.
Catches the drift. It flags where your design has quietly become inconsistent across the surface.
Uses taste, not lint rules. It tells the difference between a lazy default and a deliberate choice, and explains why.
Closes the loop in Cursor. You describe a direction in plain English (or with your voice), and Tell drafts the redesign as a diff you apply right inside your editor.
No new dashboard to babysit. No design handoff. No leaving your workflow.
Features
Feature | What it does | |
🔍 | Rendered capture | Opens your URL in a headless browser and records a full screenshot plus a computed-style fingerprint — fonts, colors, shadows, radii, spacing, contrast, and interactive states. |
🎯 | 8 genericness detectors | Deterministic checks for the classic AI tells: |
📉 | 6 consistency-drift detectors | Catches the slow decay: |
🧠 | Taste engine | Classifies every finding as generic, drift, or intentional with a plain-English rationale and a confidence score. A reflection pass rejects any reasoning that contradicts the measured facts. |
🎙️ | Voice art-direction | Say "warmer, more editorial, less shadow" and Tell breaks the instruction into action items, maps it to a direction preset, and refines with Gemini when available. Text presets keep the demo safe when mic access fails. |
🪄 | Redesign as a diff | Turns a chosen direction into a unified diff. It never auto-applies — you stay in control. |
↔️ | Before/after seam | A draggable diagonal reveal between your captured page and a live reconciliation — same content, restyled from detected tokens with contrast ratios called out. |
🐙 | GitHub repo setup | Paste |
📄 | Multi-page scanning | Discovers routes from the captured snapshot; scan each page to catch drift that only shows on some routes. |
🔌 | Cursor MCP server | Run the whole pipeline from Cursor chat with |
How it works
Tell is one pipeline, shared by both the web app and the Cursor MCP server. Everything up to the taste step is deterministic — no model, no network — so results are reproducible run to run. The model is only used for judgment and for drafting diffs.
flowchart LR
url["Your URL or a\nlocal route"] --> capture["Capture\nrendered UI"]
capture --> fingerprint["Build a\ndesign fingerprint"]
fingerprint --> tells["Detect\ngenericness tells"]
fingerprint --> drift["Detect\nconsistency drift"]
tells --> taste["Taste engine\n(generic / drift / intentional)"]
drift --> taste
voice["Voice / text\nart-direction"] --> taste
taste --> report["Tell Report +\nbefore/after seam"]
report --> contrast["Contrast floor +\nreachable-state feedback"]
taste --> diff["Redesign diff"]
diff --> cursor["Apply in Cursor\nvia MCP"]Why deterministic-first matters: the parts that must be trustworthy — reading the page and measuring it — never hallucinate. The model only weighs in where judgment is genuinely needed, and even then its rationale is checked against the hard facts before you see it.
Quick start
You'll need Node 20+ and pnpm 9+.
git clone <your-repo-url> tell
cd tell
pnpm installThen start the Tell app:
pnpm dev # the Tell app → http://localhost:3000The one-click way — point Tell at a GitHub repo. Paste a repo URL (e.g. github.com/owner/app) into the bar and hit Set up & run. Tell clones it, reads the README + package.json to figure out how to start it, installs, boots the dev server on a free port, verifies the URL responds, and captures localhost automatically. The UI blocks duplicate clicks, hides stale captures while work is running, and surfaces success or failure in plain language. If the run steps aren't clear, Tell shows what it found from the README and asks you to start it and paste the URL — no guessing.
The direct way — capture any URL. Paste a live URL (your deployed app, or a local http://localhost:3000) and hit Capture.
Either way: read the report, walk every page from the Pages strip, drag the before/after seam, art-direct a new direction, draft the diff, and copy it back into Cursor.
Run the deliberately bland fixture in a second terminal and capture it:
pnpm dev:fixture # a deliberately bland sample app → http://localhost:3001No time to wait on live capture? Tell ships with a committed report at
fixtures/reports/tell-report.jsonand loads it automatically as an offline fallback, so the demo always works.
Copy .env.example to .env and fill in what you have. Tell runs fully without keys — the taste and redesign steps simply fall back to their deterministic behavior.
GEMINI_API_KEY= # powers richer taste/voice direction parsing
CURSOR_API_KEY= # enables Cursor-SDK-backed redesign drafts
CURSOR_MODEL=composer-2.5 # optional; defaults to composer-2.5
CURSOR_AGENT_TIMEOUT_MS=75000
ANTHROPIC_API_KEY= # reserved for richer source-aware diffs (optional)pnpm test # run the golden detector tests
pnpm typecheck # strict type-check across every package
pnpm capture:fixture # capture the sample app to a fresh report
pnpm diagnose:fixture # diagnose the sample app from a captureUse it in Cursor
Tell registers itself as an MCP server, so you can drive the whole pipeline from Cursor's Agent chat.
Open this repo in Cursor — the
tellserver is already registered in.cursor/mcp.json.In Agent chat, ask for a diagnosis in plain English:
"Run
tell_diagnoseonhttp://localhost:3001and draft an editorial redesign."Review the findings and the proposed diff, then apply it — Tell hands you the patch, but you decide what lands.
Available tools
Tool | What it returns |
| The rendered screenshot + computed-style evidence for a URL. |
| The full report: findings, taste verdicts, and the Tell score. |
| A redesign proposal (patch text) for one finding or the whole report. |
| The unified diff plus instructions — it never writes files for you. |
Project structure
Tell is a pnpm monorepo. Each package has one job.
tell/
├── packages/
│ ├── schema/ # zod contracts shared by everything
│ ├── core/ # capture + fingerprint + detectors (pure, no model)
│ ├── taste/ # taste engine + voice/text art-direction
│ ├── redesign/ # turns a direction into a diff
│ └── mcp/ # the Cursor-facing MCP server
├── apps/
│ └── web/ # the Tell app: report, before/after seam, voice director
├── fixtures/
│ ├── generic-app/ # a deliberately bland app used as demo input
│ └── reports/ # a committed report artifact for offline demos
└── docs/ # design system and reference notesTech stack
Layer | Choice |
Language | TypeScript (strict) |
Monorepo | pnpm workspaces |
Capture | Playwright / Chrome DevTools Protocol |
Web app | Next.js 14 + Tailwind CSS |
Taste reasoning | Google Gemini with deterministic fallback |
Redesign diffs | Deterministic reconciliation CSS; Anthropic-ready interface |
Editor integration | Model Context Protocol (stdio) |
Validation | zod |
Tests | Vitest (golden detector tests) |
Roadmap
Deterministic capture → fingerprint → 14 detectors
Taste engine with reflection + safe fallback
Tell Report with draggable before/after seam
Voice art-direction with text-preset fallback
Cursor MCP server (
capture/diagnose/redesign/apply)Live URL capture (any reachable HTTP URL, with offline artifact fallback)
GitHub repo setup — clone, install, run, and capture localhost
Token-grounded live reconciliation in the before/after seam
Contrast-grounded reconciliation with readable text/control pairings
Multi-page route discovery and per-page scanning
Per-state evidence thumbnails (hover, focus, error) in the report
A shareable, hosted report link
Contributing
Contributions are welcome. The short version:
Fork the repo and create a branch:
git checkout -b feature/your-ideaMake your change and keep it green:
pnpm typecheck && pnpm testOpen a pull request describing the why, not just the what.
New detectors are the highest-leverage contribution — they live in packages/core/src/detectors and each ships with a golden test.
License
Released under the MIT License.
The sample app under fixtures/generic-app/ is a deliberately bland demo target used only as input for Tell — it is not part of the product. See CONTRIBUTIONS.md for the full breakdown of what's original work versus demo input.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/ashishpatill/tell-ai-ui-critic'
If you have feedback or need assistance with the MCP directory API, please join our Discord server