From majestic-engineer
Audits UI source code for accessibility violations (WCAG), performance anti-patterns, and quality issues via static analysis. Provides file:line findings with severity levels and fix suggestions for React and Rails projects.
npx claudepluginhub majesticlabs-dev/majestic-marketplace --plugin majestic-engineerThis skill is limited to using the following tools:
Static code analysis for UI quality and accessibility. Complements screenshot-based tools (`visual-validator`, `ui-ux-designer`).
Audits web UI code for accessibility, performance, responsive design, and best practices using A11Y/PERF/RD guidelines. Outputs file:line — [RULE_ID] findings.
Audits web UI for accessibility, interactions, forms, typography, navigation, layout, performance, motion, and microcopy with concrete fixes. Use for frontend reviews, 'check my UI', accessibility checks, or pre-release polish.
Audits code for accessibility (WCAG contrast, ARIA, keyboard nav), performance (layout thrashing, animations, memoization), theming (tokens, dark mode), responsive design, anti-patterns. Generates 0-4 scores, P0-P3 report, action plan.
Share bugs, ideas, or general feedback.
Static code analysis for UI quality and accessibility. Complements screenshot-based tools (visual-validator, ui-ux-designer).
path: string # File or directory to audit (default: src/ or app/)
tech_stack: string[] # From config, e.g., ["react", "rails"]
focus: string # Optional: "accessibility", "performance", "all"
/majestic:config tech_stack generic
Load rules from resources folder:
Read(resources/generic-rules.md) # Always
If tech_stack contains "react":
Read(resources/react-rules.md)
If tech_stack contains "rails":
Read(resources/rails-rules.md)
# React/JS projects
find . -name "*.tsx" -o -name "*.jsx" | head -100
# Rails projects
find . -name "*.erb" -o -name "*.html.erb" | head -100
# CSS/Tailwind
find . -name "*.css" -name "*.scss" | head -50
For each UI file:
## UI Code Audit Summary
**Verdict: PASS | FAIL**
- **Files Reviewed**: [count]
- **Critical Issues**: [count] → FAIL if > 0
- **Serious Issues**: [count]
- **Moderate Issues**: [count]
- **Minor Issues**: [count]
### Critical Findings
| File:Line | Issue | WCAG | Fix |
|-----------|-------|------|-----|
| `src/Button.tsx:45` | DIV with onClick, not keyboard accessible | 2.1.1 | Use `<button>` element |
| `src/Card.tsx:23` | Image missing alt text | 1.1.1 | Add `alt="description"` |
### Serious Findings
| File:Line | Issue | WCAG | Fix |
|-----------|-------|------|-----|
| `src/Modal.tsx:89` | Focus not trapped in modal | 2.4.3 | Implement focus trap |
### Moderate Findings
| File:Line | Issue | WCAG | Fix |
|-----------|-------|------|-----|
| `src/List.tsx:12` | Touch target 24px (< 44px) | 2.5.5 | Use `min-w-11 min-h-11` |
### Recommendations
- Consider using Radix UI for accessible dropdown implementation
- 3 animations found without `prefers-reduced-motion` support
| Severity | Definition | Verdict Impact |
|---|---|---|
| Critical | Blocks accessibility (can't use with keyboard/screen reader) | FAIL |
| Serious | Significantly degrades UX for assistive tech users | Warning |
| Moderate | Best practice violation, minor UX impact | Warning |
| Minor | Polish opportunity, no functional impact | Info |
| Code | Name | Common Violations |
|---|---|---|
| 1.1.1 | Non-text Content | Missing alt text |
| 1.3.1 | Info and Relationships | Missing form labels |
| 2.1.1 | Keyboard | Click-only handlers |
| 2.1.2 | No Keyboard Trap | Modal without escape |
| 2.4.3 | Focus Order | tabindex > 0 |
| 2.4.7 | Focus Visible | outline: none |
| 2.5.5 | Target Size | Touch target < 44px |
| 4.1.2 | Name, Role, Value | Missing ARIA |
When invoked from quality-gate:
Verdict: PASS or Verdict: FAIL| Scenario | Handling |
|---|---|
| No UI files found | Return PASS with "No UI files to audit" |
| tech_stack not configured | Use generic rules only |
| Stack rules fail to load | Log warning, continue with generic |
| File cannot be parsed | Skip file, note in report |
| Multiple tech_stacks | Load rules for each, merge findings, deduplicate |