Catalog
affaan-m/accessibility

affaan-m

accessibility

Design, implement, and audit inclusive digital products using WCAG 2.2 Level AA standards. Use this skill to generate semantic ARIA for Web and accessibility traits for Web and Native platforms (iOS/Android).

global
0installs0uses~1.6k
v1.1Saved Apr 20, 2026

Accessibility (WCAG 2.2)

This skill ensures that digital interfaces are Perceivable, Operable, Understandable, and Robust (POUR) for all users, including those using screen readers, switch controls, or keyboard navigation. It focuses on the technical implementation of WCAG 2.2 success criteria.

When to Use

  • Defining UI component specifications for Web, iOS, or Android.
  • Auditing existing code for accessibility barriers or compliance gaps.
  • Implementing new WCAG 2.2 standards like Target Size (Minimum) and Focus Appearance.
  • Mapping high-level design requirements to technical attributes (ARIA roles, traits, hints).

Core Concepts

  • POUR Principles: The foundation of WCAG (Perceivable, Operable, Understandable, Robust).
  • Semantic Mapping: Using native elements over generic containers to provide built-in accessibility.
  • Accessibility Tree: The representation of the UI that assistive technologies actually "read."
  • Focus Management: Controlling the order and visibility of the keyboard/screen reader cursor.
  • Labeling & Hints: Providing context through aria-label, accessibilityLabel, and contentDescription.

How It Works

Step 1: Identify the Component Role

Determine the functional purpose (e.g., Is this a button, a link, or a tab?). Use the most semantic native element available before resorting to custom roles.

Step 2: Define Perceivable Attributes

  • Ensure text contrast meets 4.5:1 (normal) or 3:1 (large/UI).
  • Add text alternatives for non-text content (images, icons).
  • Implement responsive reflow (up to 400% zoom without loss of function).

Step 3: Implement Operable Controls

  • Ensure a minimum 24x24 CSS pixel target size (WCAG 2.2 SC 2.5.8).
  • Verify all interactive elements are reachable via keyboard and have a visible focus indicator (SC 2.4.11).
  • Provide single-pointer alternatives for dragging movements.

Step 4: Ensure Understandable Logic

  • Use consistent navigation patterns.
  • Provide descriptive error messages and suggestions for correction (SC 3.3.3).
  • Implement "Redundant Entry" (SC 3.3.7) to prevent asking for the same data twice.

Step 5: Verify Robust Compatibility

  • Use correct Name, Role, Value patterns.
  • Implement aria-live or live regions for dynamic status updates.

Accessibility Architecture Diagram

flowchart TD
  UI["UI Component"] --> Platform{Platform?}
  Platform -->|Web| ARIA["WAI-ARIA + HTML5"]
  Platform -->|iOS| SwiftUI["Accessibility Traits + Labels"]
  Platform -->|Android| Compose["Semantics + ContentDesc"]

  ARIA --> AT["Assistive Technology (Screen Readers, Switches)"]
  SwiftUI --> AT
  Compose --> AT

Cross-Platform Mapping

Feature Web (HTML/ARIA) iOS (SwiftUI) Android (Compose)
Primary Label aria-label / <label> .accessibilityLabel() contentDescription
Secondary Hint aria-describedby .accessibilityHint() Modifier.semantics { stateDescription = ... }
Action Role role="button" .accessibilityAddTraits(.isButton) Modifier.semantics { role = Role.Button }
Live Updates aria-live="polite" .accessibilityLiveRegion(.polite) Modifier.semantics { liveRegion = LiveRegionMode.Polite }

Examples

<form role="search">
  <label for="search-input" class="sr-only">Search products</label>
  <input type="search" id="search-input" placeholder="Search..." />
  <button type="submit" aria-label="Submit Search">
    <svg aria-hidden="true">...</svg>
  </button>
</form>

iOS: Accessible Action Button

Button(action: deleteItem) {
    Image(systemName: "trash")
}
.accessibilityLabel("Delete item")
.accessibilityHint("Permanently removes this item from your list")
.accessibilityAddTraits(.isButton)

Android: Accessible Toggle

Switch(
    checked = isEnabled,
    onCheckedChange = { onToggle() },
    modifier = Modifier.semantics {
        contentDescription = "Enable notifications"
    }
)

Anti-Patterns to Avoid

  • Div-Buttons: Using a <div> or <span> for a click event without adding a role and keyboard support.
  • Color-Only Meaning: Indicating an error or status only with a color change (e.g., turning a border red).
  • Uncontained Modal Focus: Modals that don't trap focus, allowing keyboard users to navigate background content while the modal is open. Focus must be contained and escapable via the Escape key or an explicit close button (WCAG SC 2.1.2).
  • Redundant Alt Text: Using "Image of..." or "Picture of..." in alt text (screen readers already announce the role "Image").

Best Practices Checklist

  • Interactive elements meet the 24x24px (Web) or 44x44pt (Native) target size.
  • Focus indicators are clearly visible and high-contrast.
  • Modals contain focus while open, and release it cleanly on close (Escape key or close button).
  • Dropdowns and menus restore focus to the trigger element on close.
  • Forms provide text-based error suggestions.
  • All icon-only buttons have a descriptive text label.
  • Content reflows properly when text is scaled.

References

  • frontend-patterns
  • frontend-design
  • liquid-glass-design
  • swiftui-patterns
Files1
1 files · 1.0 KB

Select a file to preview

Overall Score

88/100

Grade

A

Excellent

Safety

98

Quality

85

Clarity

88

Completeness

83

Summary

This skill guides agents to design, implement, and audit accessible digital products compliant with WCAG 2.2 Level AA standards. It provides cross-platform mappings for Web (HTML/ARIA), iOS (SwiftUI), and Android (Compose) to ensure interfaces are perceivable, operable, understandable, and robust for all users, including those using assistive technologies.

Detected Capabilities

WCAG 2.2 Level AA compliance guidanceCross-platform accessibility mapping (Web, iOS, Android)ARIA role and attribute specificationFocus management and keyboard navigationSemantic HTML and native component recommendationsAccessibility audit pattern recognitionAnti-pattern identification and remediation

Trigger Keywords

Phrases that MCP clients use to match this skill to user intent.

wcag complianceaccessibility auditaria implementationaccessible componentskeyboard navigationinclusive designfocus management

Risk Signals

INFO

No executable code or shell commands present

SKILL.md (entire file)
INFO

No file write operations requested

SKILL.md (entire file)
INFO

No credential or secret access patterns

SKILL.md (entire file)
INFO

External references are to established accessibility standards (W3C, Apple, Google)

References section

Referenced Domains

External domains referenced in skill content, detected by static analysis.

developer.android.comdeveloper.apple.comwww.w3.org

Use Cases

  • Define semantic ARIA and accessibility attributes for new Web components
  • Audit existing UI code for WCAG 2.2 compliance gaps and barriers
  • Map design requirements to platform-specific accessibility traits (iOS/Android)
  • Implement focus management and keyboard navigation for Web applications
  • Add descriptive labels and hints for icon-only buttons and dynamic content
  • Ensure touch target sizes and contrast ratios meet accessibility standards

Quality Notes

  • Excellent structure with clear POUR principles framework that guides both teaching and implementation
  • Strong cross-platform mapping table makes it easy to translate concepts across Web, iOS, and Android
  • Comprehensive examples for each platform (HTML, Swift, Kotlin) demonstrate practical application
  • Well-organized anti-patterns section provides guidance on what NOT to do, which is equally valuable
  • References link to authoritative sources (W3C WCAG, Apple, Google accessibility guides)
  • Includes a visual flowchart showing platform-agnostic component architecture
  • Best practices checklist is actionable and testable
  • Clear section hierarchy makes it easy for agents to navigate based on task type
  • Could be enhanced with specific success criteria SC codes referenced more consistently throughout body (only used in a few places)
  • No explicit guidance on testing tools or validation methods (e.g., axe, WAVE, Accessibility Inspector)
Model: claude-haiku-4-5-20251001Analyzed: Apr 20, 2026

Reviews

Add this skill to your library to leave a review.

No reviews yet

Be the first to share your experience.

Version History

v1.1

Content updated

2026-04-20

Latest
v1.0

No changelog

2026-04-13

Add affaan-m/accessibility to your library

Command Palette

Search for a command to run...