Agent skill
ui-analyse
UI visual analysis patterns using Gemini 3 Pro Preview multimodal capabilities. Analysis-only - no code changes. Use dev:ui-implement for applying improvements. Includes provider detection, prompting patterns, and severity guidelines.
Install this agent skill to your Project
npx add-skill https://github.com/MadAppGang/claude-code/tree/main/plugins/dev/skills/design/ui-analyse
SKILL.md
UI Analysis Skill
Overview
This skill provides patterns for analyzing UI designs visually using Gemini 3 Pro Preview. It is analysis-only - for implementing improvements, use dev:ui-implement.
Relationship to Other Skills
| Skill | Purpose | Modifies Code? |
|---|---|---|
| dev:ui-analyse | Visual analysis, issue detection | No |
| dev:ui-implement | Apply improvements from analysis | Yes |
| dev:ui-style-format | Style file specification | No |
| dev:design-references | Reference image management | No |
Provider Selection
Detection Logic
detect_gemini_provider() {
# Priority 1: Gemini Direct API (lowest latency)
if [[ -n "$GEMINI_API_KEY" ]]; then
echo "g/gemini-3-pro-preview"
return 0
fi
# Priority 2: OpenRouter (requires or/ prefix)
if [[ -n "$OPENROUTER_API_KEY" ]]; then
echo "or/google/gemini-3-pro-preview"
return 0
fi
# Priority 3: Vertex AI
if [[ -n "$GOOGLE_APPLICATION_CREDENTIALS" ]]; then
echo "vertex/gemini-3-pro-preview"
return 0
fi
# Priority 4: Gemini OAuth (check claudish)
if npx claudish --list-accounts 2>/dev/null | grep -q "gemini"; then
echo "g/gemini-3-pro-preview"
return 0
fi
# No provider
return 1
}
Model Prefix Reference
| Prefix | Provider | Env Var | Notes |
|---|---|---|---|
g/ |
Gemini Direct | GEMINI_API_KEY | Lowest latency |
or/ |
OpenRouter | OPENROUTER_API_KEY | Avoids google/ collision |
vertex/ |
Vertex AI | GOOGLE_APPLICATION_CREDENTIALS | Enterprise |
Error Messages by Provider
| Provider | Missing | Error Message | Setup Instructions |
|---|---|---|---|
| gemini_direct | GEMINI_API_KEY | "Gemini API key not found" | export GEMINI_API_KEY="your-key" from aistudio.google.com |
| openrouter | OPENROUTER_API_KEY | "OpenRouter API key not found" | export OPENROUTER_API_KEY="your-key" from openrouter.ai |
| vertex_ai | GOOGLE_APPLICATION_CREDENTIALS | "Google Cloud credentials not configured" | gcloud auth application-default login |
| gemini_oauth | OAuth session | "No Gemini OAuth session" | claudish auth gemini |
Analysis Patterns
Pattern 1: Quick Usability Scan
Analyze this UI screenshot for usability issues.
**Focus Areas**:
1. Visual hierarchy - Is the most important content prominent?
2. Affordances - Do interactive elements look clickable?
3. Consistency - Do similar elements behave similarly?
**Output**: Top 5 issues with severity and location.
Usage:
npx claudish --model "$GEMINI_MODEL" --image "$SCREENSHOT_PATH" --quiet --auto-approve <<< "
Analyze this UI screenshot for usability issues.
Focus Areas:
1. Visual hierarchy - Is the most important content prominent?
2. Affordances - Do interactive elements look clickable?
3. Consistency - Do similar elements behave similarly?
Output: Top 5 issues with severity and location."
Pattern 2: Accessibility Audit
Audit this UI for WCAG 2.1 AA compliance.
**Checklist**:
- [ ] Text contrast >= 4.5:1 (WCAG 1.4.3)
- [ ] Non-text contrast >= 3:1 (WCAG 1.4.11)
- [ ] Touch targets >= 44x44px (WCAG 2.5.5)
- [ ] Focus visible (WCAG 2.4.7)
**Output**: Pass/Fail per criterion with evidence.
Usage:
npx claudish --model "$GEMINI_MODEL" --image "$SCREENSHOT_PATH" --quiet --auto-approve <<< "
Audit this UI for WCAG 2.1 AA compliance.
Checklist:
- Text contrast >= 4.5:1 (WCAG 1.4.3)
- Non-text contrast >= 3:1 (WCAG 1.4.11)
- Touch targets >= 44x44px (WCAG 2.5.5)
- Focus visible (WCAG 2.4.7)
Output as: Pass/Fail per criterion with visual evidence."
Pattern 3: Anti-AI Design Audit
Analyze this UI for "AI-generated" patterns that should be avoided.
**Check for**:
1. Rigid symmetric grids (should be asymmetric)
2. Flat solid colors (should have gradients/texture)
3. Generic typography (should have dramatic hierarchy)
4. Static elements (should have micro-interactions)
5. Default Tailwind colors (should be bespoke palette)
**Output**: List violations with specific recommendations.
Usage:
npx claudish --model "$GEMINI_MODEL" --image "$SCREENSHOT_PATH" --quiet --auto-approve <<< "
Analyze this UI for AI-generated patterns that should be avoided.
Check for:
1. Rigid symmetric grids (should be asymmetric)
2. Flat solid colors (should have gradients/texture)
3. Generic typography (should have dramatic hierarchy)
4. Static elements (should have micro-interactions)
5. Default Tailwind colors (should be bespoke palette)
List each violation found with specific recommendations for improvement."
Pattern 4: Comparative Analysis
Compare these two images:
- Image 1: Design reference
- Image 2: Implementation
**Validate**:
1. Layout accuracy
2. Color fidelity
3. Typography matching
4. Spacing precision
5. Component rendering
**Output**: Match score (1-10) and deviation list.
Usage:
npx claudish --model "$GEMINI_MODEL" \
--image "$REFERENCE_PATH" \
--image "$IMPLEMENTATION_PATH" \
--quiet --auto-approve <<< "
Compare these two images:
- Image 1: Design reference (target)
- Image 2: Current implementation
Validate:
1. Layout accuracy
2. Color fidelity
3. Typography matching
4. Spacing precision
5. Component rendering
Output: Match score (1-10) and list of specific deviations."
Severity Guidelines
| Severity | Impact | Examples | Action |
|---|---|---|---|
| CRITICAL | Blocks task | Invisible button, broken flow | Fix immediately |
| HIGH | Major barrier | WCAG fail, confusing nav | Fix before release |
| MEDIUM | Friction | Inconsistent spacing | Next sprint |
| LOW | Polish | Minor alignment | Backlog |
Output Format
Analysis results should follow this structure:
## UI Analysis Results
**Target**: {image_path}
**Provider**: {gemini_model}
**Date**: {timestamp}
**Score**: {X}/10
### Issues by Severity
#### CRITICAL
{issues or "None found"}
#### HIGH
{issues or "None found"}
#### MEDIUM
{issues or "None found"}
#### LOW
{issues or "None found"}
### Strengths
{positive observations}
### Recommendations
{actionable improvements}
Integration with /dev:ui Command
The /dev:ui command uses this skill when:
- User requests analysis only ("review", "audit", "check")
- User provides image without implementation request
- As first step before
dev:ui-implement
Intent Triggers for Analysis
Primary triggers (route to ui-analyse):
- review, analyze, analyse, audit, check, evaluate, assess, score
- inspect, critique, rate, examine
Pattern triggers (route to ui-analyse):
- "what's wrong with", "problems with", "issues with"
- "accessibility", "usability", "wcag"
Workflow Integration
When used via /dev:ui:
- Command detects analysis intent
- Detects Gemini provider
- Runs visual analysis with Gemini
- Writes review to:
${SESSION_PATH}/reviews/design-review/gemini.md - Presents summary to user
Pattern 5: Fallback Mode (Text-Only)
If no Gemini provider is available:
- Note in output: "Visual verification unavailable - manual review recommended"
- Proceed with text-based analysis if component code is available
- Use code analysis to infer potential issues
- Recommend user provide API key for full visual analysis
Best Practices
DO
- Always validate image inputs exist before analysis
- Cite specific design principles for every issue
- Provide actionable, specific recommendations
- Prioritize by severity (CRITICAL first)
- Use Gemini for visual analysis (not guessing)
DON'T
- Make code changes (use dev:ui-implement for that)
- Give vague aesthetic opinions ("looks bad")
- Overwhelm with LOW severity items
- Forget accessibility considerations
- Skip the principle citation
- Assume implementation details without seeing
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
test-skill
A test skill for validation testing. Use when testing skill parsing and validation logic.
bad-skill
claudish-usage
CRITICAL - Guide for using Claudish CLI ONLY through sub-agents to run Claude Code with OpenRouter models (Grok, GPT-5, Gemini, MiniMax). NEVER run Claudish directly in main context unless user explicitly requests it. Use when user mentions external AI models, Claudish, OpenRouter, or alternative models. Includes mandatory sub-agent delegation patterns, agent selection guide, file-based instructions, and strict rules to prevent context window pollution.
release
Plugin release process for MAG Claude Plugins marketplace. Covers version bumping, marketplace.json updates, git tagging, and common mistakes. Use when releasing new plugin versions or troubleshooting update issues.
claudish-integration
openrouter-trending-models
Fetch trending programming models from OpenRouter rankings. Use when selecting models for multi-model review, updating model recommendations, or researching current AI coding trends. Provides model IDs, context windows, pricing, and usage statistics from the most recent week.
Didn't find tool you were looking for?