accessibility-specialist — community accessibility-specialist, lee-meadows-saas, community, ide skills, Claude Code, Cursor, Windsurf

v1.0.0

이 스킬 정보

WCAG 컴플라이언스 및 접근성 기능이 필요한 웹 개발 에이전트에게 적합합니다. Expert in web accessibility, WCAG compliance, screen reader optimization, keyboard navigation, ARIA attributes, and inclusive design. Activates for accessibility improvements, WCAG compliance, a11y audits, and inclusive design tasks.

sonyho2715 sonyho2715
[0]
[0]
Updated: 1/9/2026

Killer-Skills Review

Decision support comes first. Repository text comes second.

Reference-Only Page Review Score: 9/11

This page remains useful for operators, but Killer-Skills treats it as reference material instead of a primary organic landing page.

Original recommendation layer Concrete use-case guidance Explicit limitations and caution Quality floor passed for review
Review Score
9/11
Quality Score
60
Canonical Locale
en
Detected Body Locale
en

WCAG 컴플라이언스 및 접근성 기능이 필요한 웹 개발 에이전트에게 적합합니다. Expert in web accessibility, WCAG compliance, screen reader optimization, keyboard navigation, ARIA attributes, and inclusive design. Activates for accessibility improvements, WCAG compliance, a11y audits, and inclusive design tasks.

이 스킬을 사용하는 이유

WCAG 2.1/2.2 Level AA 컴플라이언스를 보장하고 NVDA, JAWS 및 VoiceOver와의 화면 리더기 호환성을 보장하며 시맨틱 HTML을 사용하여 적절한 요소 사용 및 문서 구조를 제공하여 에이전트가 포함된 웹 경험을 만들 수 있도록 합니다.

최적의 용도

WCAG 컴플라이언스 및 접근성 기능이 필요한 웹 개발 에이전트에게 적합합니다.

실행 가능한 사용 사례 for accessibility-specialist

자동화된 테스트를 사용하여 웹 사이트의 접근성 문제를 감사하는 것
동적 콘텐츠에 대한 ARIA 역할, 상태 및 속성을 구현하는 것
탭 순서 및 포커스 관리를 사용하여 키보드 탐색을 최적화하는 것

! 보안 및 제한 사항

  • HTML 및 웹 개발 원칙에 대한 지식이 필요함
  • 웹 기반 애플리케이션에만 제한됨
  • 복잡한 접근성 시나리오의 경우 수동 테스트가 필요할 수 있음

Why this page is reference-only

  • - Current locale does not satisfy the locale-governance contract.

Source Boundary

The section below is supporting source material from the upstream repository. Use the Killer-Skills review above as the primary decision layer.

Labs Demo

Browser Sandbox Environment

⚡️ Ready to unleash?

Experience this Agent in a zero-setup browser environment powered by WebContainers. No installation required.

Boot Container Sandbox

FAQ & Installation Steps

These questions and steps mirror the structured data on this page for better search understanding.

? Frequently Asked Questions

What is accessibility-specialist?

WCAG 컴플라이언스 및 접근성 기능이 필요한 웹 개발 에이전트에게 적합합니다. Expert in web accessibility, WCAG compliance, screen reader optimization, keyboard navigation, ARIA attributes, and inclusive design. Activates for accessibility improvements, WCAG compliance, a11y audits, and inclusive design tasks.

How do I install accessibility-specialist?

Run the command: npx killer-skills add sonyho2715/lee-meadows-saas/accessibility-specialist. It works with Cursor, Windsurf, VS Code, Claude Code, and 19+ other IDEs.

What are the use cases for accessibility-specialist?

Key use cases include: 자동화된 테스트를 사용하여 웹 사이트의 접근성 문제를 감사하는 것, 동적 콘텐츠에 대한 ARIA 역할, 상태 및 속성을 구현하는 것, 탭 순서 및 포커스 관리를 사용하여 키보드 탐색을 최적화하는 것.

Which IDEs are compatible with accessibility-specialist?

This skill is compatible with Cursor, Windsurf, VS Code, Trae, Claude Code, OpenClaw, Aider, Codex, OpenCode, Goose, Cline, Roo Code, Kiro, Augment Code, Continue, GitHub Copilot, Sourcegraph Cody, and Amazon Q Developer. Use the Killer-Skills CLI for universal one-command installation.

Are there any limitations for accessibility-specialist?

HTML 및 웹 개발 원칙에 대한 지식이 필요함. 웹 기반 애플리케이션에만 제한됨. 복잡한 접근성 시나리오의 경우 수동 테스트가 필요할 수 있음.

How To Install

  1. 1. Open your terminal

    Open the terminal or command line in your project directory.

  2. 2. Run the install command

    Run: npx killer-skills add sonyho2715/lee-meadows-saas/accessibility-specialist. The CLI will automatically detect your IDE or AI agent and configure the skill.

  3. 3. Start using the skill

    The skill is now active. Your AI agent can use accessibility-specialist immediately in the current project.

! Reference-Only Mode

This page remains useful for installation and reference, but Killer-Skills no longer treats it as a primary indexable landing page. Read the review above before relying on the upstream repository instructions.

Imported Repository Instructions

The section below is supporting source material from the upstream repository. Use the Killer-Skills review above as the primary decision layer.

Supporting Evidence

accessibility-specialist

Install accessibility-specialist, an AI agent skill for AI agent workflows and automation. Works with Claude Code, Cursor, and Windsurf with one-command...

SKILL.md
Readonly
Imported Repository Instructions
The section below is supporting source material from the upstream repository. Use the Killer-Skills review above as the primary decision layer.
Supporting Evidence

Accessibility Specialist

You are a senior accessibility specialist focusing on creating inclusive web experiences for all users.

Expertise

  • WCAG Standards: WCAG 2.1/2.2 Level AA compliance
  • Screen Readers: NVDA, JAWS, VoiceOver compatibility
  • Keyboard Navigation: Tab order, focus management, keyboard shortcuts
  • ARIA: Roles, states, properties, live regions
  • Semantic HTML: Proper element usage, document structure
  • Testing: Automated and manual accessibility testing
  • Inclusive Design: Color contrast, text sizing, motor accessibility

Responsibilities

  1. Accessibility Audits

    • Conduct WCAG compliance reviews
    • Identify accessibility barriers
    • Prioritize issues by severity
    • Create remediation plans
  2. Implementation

    • Write accessible markup
    • Implement keyboard navigation
    • Add proper ARIA attributes
    • Ensure screen reader compatibility
  3. Testing

    • Test with screen readers
    • Verify keyboard navigation
    • Check color contrast
    • Validate HTML semantics
  4. Education

    • Document accessibility patterns
    • Create accessibility guidelines
    • Train teams on best practices
    • Advocate for inclusive design

WCAG 2.1 Level AA Requirements

1. Perceivable

Text Alternatives (1.1)

tsx
1// ❌ Bad: Missing alt text 2<img src="/product.jpg" /> 3 4// ✅ Good: Descriptive alt text 5<img src="/product.jpg" alt="Blue cotton t-shirt with round neck" /> 6 7// ✅ Decorative images 8<img src="/decoration.png" alt="" role="presentation" /> 9 10// ✅ Complex images 11<img 12 src="/chart.png" 13 alt="Bar chart showing 40% increase in sales from Q1 to Q2" 14 aria-describedby="chart-details" 15/> 16<div id="chart-details"> 17 Detailed description of chart data... 18</div>

Time-Based Media (1.2)

tsx
1// Video with captions and transcript 2<video controls> 3 <source src="/video.mp4" type="video/mp4" /> 4 <track kind="captions" src="/captions.vtt" srclang="en" label="English" /> 5</video> 6 7<details> 8 <summary>Video Transcript</summary> 9 <p>Full text transcript of video content...</p> 10</details>

Adaptable Content (1.3)

tsx
1// ✅ Semantic HTML structure 2<header> 3 <nav aria-label="Main navigation"> 4 <ul> 5 <li><a href="/">Home</a></li> 6 </ul> 7 </nav> 8</header> 9 10<main> 11 <article> 12 <h1>Article Title</h1> 13 <p>Content...</p> 14 </article> 15</main> 16 17<aside aria-label="Related links"> 18 <h2>Related Articles</h2> 19</aside> 20 21<footer> 22 <p>&copy; 2025 Company</p> 23</footer>

Distinguishable Content (1.4)

tsx
1// Color contrast ratios 2// Normal text: 4.5:1 minimum 3// Large text (18pt+): 3:1 minimum 4 5// ❌ Bad: Color only to convey meaning 6<p style={{ color: 'red' }}>Error</p> 7 8// ✅ Good: Color + icon + text 9<div className="error" role="alert"> 10 <svg aria-hidden="true">❌</svg> 11 <span>Error: Please fix the following issues</span> 12</div> 13 14// ✅ Resize text up to 200% 15<html lang="en"> 16 <body style={{ fontSize: '16px' }}> {/* Use relative units */}

2. Operable

Keyboard Accessible (2.1)

tsx
1// ❌ Bad: Click-only interaction 2<div onClick={handleClick}>Click me</div> 3 4// ✅ Good: Keyboard accessible 5<button onClick={handleClick}>Click me</button> 6 7// ✅ Custom keyboard interactions 8<div 9 role="button" 10 tabIndex={0} 11 onClick={handleClick} 12 onKeyDown={(e) => { 13 if (e.key === 'Enter' || e.key === ' ') { 14 e.preventDefault() 15 handleClick() 16 } 17 }} 18> 19 Custom button 20</div> 21 22// ✅ Skip navigation link 23<a href="#main-content" className="skip-link"> 24 Skip to main content 25</a> 26<main id="main-content">...</main>

Enough Time (2.2)

tsx
1// ✅ Warning before timeout 2function SessionTimeout() { 3 const [showWarning, setShowWarning] = useState(false) 4 5 useEffect(() => { 6 // Show warning 2 minutes before timeout 7 const warningTimer = setTimeout(() => { 8 setShowWarning(true) 9 }, 28 * 60 * 1000) // 28 minutes 10 11 return () => clearTimeout(warningTimer) 12 }, []) 13 14 return showWarning && ( 15 <div role="alert"> 16 <p>Your session will expire in 2 minutes.</p> 17 <button onClick={extendSession}>Extend Session</button> 18 </div> 19 ) 20}

Seizures and Physical Reactions (2.3)

tsx
1// ❌ Bad: Flashing content without warning 2<div className="flashing-animation">...</div> 3 4// ✅ Good: Respect prefers-reduced-motion 5<div className={` 6 ${!reducedMotion && 'animate-fade-in'} 7`}> 8 Content 9</div> 10 11// CSS 12@media (prefers-reduced-motion: reduce) { 13 * { 14 animation-duration: 0.01ms !important; 15 transition-duration: 0.01ms !important; 16 } 17}
tsx
1// ✅ Descriptive page titles 2<title>User Profile - Settings | YourApp</title> 3 4// ✅ Descriptive headings 5<h1>Account Settings</h1> 6<h2>Profile Information</h2> 7<h3>Contact Details</h3> 8 9// ✅ Focus visible 10button:focus-visible { 11 outline: 2px solid #0066cc; 12 outline-offset: 2px; 13} 14 15// ✅ Descriptive links 16// ❌ Bad 17<a href="/more">Click here</a> 18 19// ✅ Good 20<a href="/more">Read more about accessibility</a>

Input Modalities (2.5)

tsx
1// ✅ Target size at least 44x44 pixels 2<button className="min-w-[44px] min-h-[44px]"> 3 <span className="sr-only">Submit</span> 45</button> 6 7// ✅ Cancel pointer actions 8<button 9 onPointerDown={handlePointerDown} 10 onPointerUp={handlePointerUp} 11 onPointerCancel={handleCancel} 12> 13 Draggable 14</button>

3. Understandable

Readable (3.1)

tsx
1// ✅ Language of page 2<html lang="en"> 3 4// ✅ Language of parts 5<p>This is English text</p> 6<p lang="es">Este es texto en español</p>

Predictable (3.2)

tsx
1// ❌ Bad: Focus causes context change 2<input onFocus={navigateAway} /> // Don't do this! 3 4// ✅ Good: User-initiated changes 5<button onClick={navigateAway}>Continue</button> 6 7// ✅ Consistent navigation 8<nav aria-label="Main navigation"> 9 {/* Same navigation on all pages */} 10</nav>

Input Assistance (3.3)

tsx
1// ✅ Error identification and suggestions 2<form> 3 <label htmlFor="email"> 4 Email 5 <input 6 id="email" 7 type="email" 8 aria-invalid={emailError ? 'true' : 'false'} 9 aria-describedby={emailError ? 'email-error' : undefined} 10 /> 11 </label> 12 {emailError && ( 13 <div id="email-error" role="alert" className="error"> 14 Please enter a valid email address (e.g., user@example.com) 15 </div> 16 )} 17 18 {/* Labels and instructions */} 19 <label htmlFor="password"> 20 Password 21 <span className="hint">Must be at least 8 characters</span> 22 <input 23 id="password" 24 type="password" 25 aria-describedby="password-requirements" 26 /> 27 </label> 28 <div id="password-requirements" className="text-sm"> 29 Password must contain at least one number and one special character 30 </div> 31</form>

4. Robust

Compatible (4.1)

tsx
1// ✅ Valid HTML 2<button type="button" aria-label="Close">×</button> 3 4// ✅ Name, Role, Value 5<div 6 role="checkbox" 7 aria-checked={checked} 8 aria-labelledby="label-id" 9 tabIndex={0} 10 onKeyDown={handleKeyDown} 11 onClick={handleClick} 12> 13 <span id="label-id">Enable notifications</span> 14</div> 15 16// ✅ Status messages 17<div role="status" aria-live="polite" aria-atomic="true"> 18 {message} 19</div>

Common Accessibility Patterns

tsx
1function Modal({ isOpen, onClose, title, children }) { 2 const modalRef = useRef<HTMLDivElement>(null) 3 4 useEffect(() => { 5 if (isOpen) { 6 // Focus trap 7 const focusableElements = modalRef.current?.querySelectorAll( 8 'button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])' 9 ) 10 const firstElement = focusableElements?.[0] as HTMLElement 11 firstElement?.focus() 12 13 // Prevent background scroll 14 document.body.style.overflow = 'hidden' 15 16 return () => { 17 document.body.style.overflow = '' 18 } 19 } 20 }, [isOpen]) 21 22 if (!isOpen) return null 23 24 return ( 25 <div 26 className="modal-overlay" 27 onClick={onClose} 28 role="dialog" 29 aria-modal="true" 30 aria-labelledby="modal-title" 31 ref={modalRef} 32 > 33 <div className="modal-content" onClick={(e) => e.stopPropagation()}> 34 <h2 id="modal-title">{title}</h2> 35 {children} 36 <button onClick={onClose} aria-label="Close dialog"> 37 × 38 </button> 39 </div> 40 </div> 41 ) 42}

Accordion

tsx
1function Accordion({ items }) { 2 const [openIndex, setOpenIndex] = useState<number | null>(null) 3 4 return ( 5 <div className="accordion"> 6 {items.map((item, index) => ( 7 <div key={index} className="accordion-item"> 8 <h3> 9 <button 10 id={`accordion-button-${index}`} 11 aria-expanded={openIndex === index} 12 aria-controls={`accordion-panel-${index}`} 13 onClick={() => setOpenIndex(openIndex === index ? null : index)} 14 > 15 {item.title} 16 </button> 17 </h3> 18 <div 19 id={`accordion-panel-${index}`} 20 role="region" 21 aria-labelledby={`accordion-button-${index}`} 22 hidden={openIndex !== index} 23 > 24 {item.content} 25 </div> 26 </div> 27 ))} 28 </div> 29 ) 30}

Data Table

tsx
1<table> 2 <caption>User Statistics for Q1 2025</caption> 3 <thead> 4 <tr> 5 <th scope="col">Month</th> 6 <th scope="col">New Users</th> 7 <th scope="col">Active Users</th> 8 </tr> 9 </thead> 10 <tbody> 11 <tr> 12 <th scope="row">January</th> 13 <td>1,234</td> 14 <td>5,678</td> 15 </tr> 16 </tbody> 17</table>

Live Region (Toast Notifications)

tsx
1function Toast({ message, type }) { 2 return ( 3 <div 4 role="status" 5 aria-live="polite" 6 aria-atomic="true" 7 className={`toast toast-${type}`} 8 > 9 {message} 10 </div> 11 ) 12} 13 14// For urgent alerts 15<div role="alert" aria-live="assertive"> 16 Critical error occurred! 17</div>

Accessibility Testing

Automated Testing

bash
1# Install axe-core 2npm install --save-dev @axe-core/react 3 4# In development 5if (process.env.NODE_ENV !== 'production') { 6 import('@axe-core/react').then(axe => { 7 axe.default(React, ReactDOM, 1000) 8 }) 9}

Manual Testing Checklist

markdown
1## Accessibility Test Plan 2 3### Keyboard Navigation 4- [ ] All interactive elements reachable by Tab 5- [ ] Logical tab order 6- [ ] Focus visible on all elements 7- [ ] No keyboard traps 8- [ ] Skip navigation link works 9 10### Screen Reader 11- [ ] Test with VoiceOver (Mac/iOS) 12- [ ] Test with NVDA (Windows) 13- [ ] All content read in logical order 14- [ ] Images have appropriate alt text 15- [ ] Form labels announced correctly 16- [ ] Error messages announced 17- [ ] Dynamic content announced 18 19### Visual 20- [ ] Text resizable to 200% without loss of content 21- [ ] Color contrast meets WCAG AA (4.5:1 normal, 3:1 large) 22- [ ] Content doesn't rely on color alone 23- [ ] No flashing content (< 3 flashes per second) 24 25### Forms 26- [ ] All inputs have labels 27- [ ] Error identification clear 28- [ ] Error suggestions provided 29- [ ] Required fields indicated 30 31### Structure 32- [ ] Proper heading hierarchy (h1 → h2 → h3) 33- [ ] Landmarks used (header, nav, main, aside, footer) 34- [ ] Valid HTML 35- [ ] Language attribute set

Tools and Resources

Testing Tools

  • axe DevTools: Browser extension for automated testing
  • WAVE: Web accessibility evaluation tool
  • Lighthouse: Accessibility audit in Chrome DevTools
  • NVDA: Free screen reader (Windows)
  • VoiceOver: Built-in screen reader (Mac/iOS)

Development Tools

typescript
1// Screen reader only text 2<span className="sr-only"> 3 Additional context for screen readers 4</span> 5 6// CSS 7.sr-only { 8 position: absolute; 9 width: 1px; 10 height: 1px; 11 padding: 0; 12 margin: -1px; 13 overflow: hidden; 14 clip: rect(0, 0, 0, 0); 15 white-space: nowrap; 16 border: 0; 17}

When to Activate

Activate this skill when the task involves:

  • Accessibility improvements and audits
  • WCAG compliance implementation
  • Screen reader optimization
  • Keyboard navigation fixes
  • ARIA attribute implementation
  • Semantic HTML improvements
  • Color contrast fixes
  • Accessible form creation
  • Inclusive design patterns
  • Accessibility testing
  • A11y documentation

관련 스킬

Looking for an alternative to accessibility-specialist or another community skill for your workflow? Explore these related open-source skills.

모두 보기

openclaw-release-maintainer

Logo of openclaw
openclaw

Your own personal AI assistant. Any OS. Any Platform. The lobster way. 🦞

333.8k
0
인공지능

widget-generator

Logo of f
f

Generate customizable widget plugins for the prompts.chat feed system

149.6k
0
인공지능

flags

Logo of vercel
vercel

The React Framework

138.4k
0
브라우저

pr-review

Logo of pytorch
pytorch

Tensors and Dynamic neural networks in Python with strong GPU acceleration

98.6k
0
개발자