ATAG
audits:
worth your while ๐
Practical tips and examples to get started
Thibaud Colas
@
FOSDEM
2025
Why weโre here
Standards, authoring tools, accessibility by default
95.9% of home pages have accessibility issues
data:image/s3,"s3://crabby-images/aabe1/aabe1c9822118e076c22b74640f1d7c960bf6632" alt="Line chart of WCAG non-conformance percentage from 2019 to 2024. The line goes starts slightly below 100% non-conformance in 2019, and barely goes down year to year."
We need accessibility standards
- WCAG: Web Content Accessibility Guidelines
- ATAG: Authoring Tool Accessibility Guidelines
- โ๏ธ Our focus today
- UAAG: User Agent Accessibility Guidelines
- WAI-ARIA: Web Accessibility Initiative โ Accessible Rich Internet Applications
- EN 301 549: Accessibility requirements for ICT products and services
We need authoring tools
We need support for social media posts. Blogging. Apps. Videos. Slides. Livestreams. Chat. Crafting HTML by hand is possible but error-prone.
Authors need:
- Assistance
- Documentation
- Templates
- Quality control
- Accessible defaults
Authoring Tool Accessibility Guidelines (ATAG) 2.0
Version 2.0 in 2015
A. Make the authoring tool user interface accessible
All Part A guidelines
A.1. Authoring tool user interfaces follow applicable accessibility guidelines
A.3. Editing-views are operable
- A.3.1. (For the authoring tool user interface) Provide keyboard access to authoring features
- A.3.2. (For the authoring tool user interface) Provide authors with enough time
- A.3.3. (For the authoring tool user interface) Help authors avoid flashing that could cause seizures
- A.3.4. (For the authoring tool user interface) Enhance navigation and editing via content structure
- A.3.5. (For the authoring tool user interface) Provide text search of the content
- A.3.6. (For the authoring tool user interface) Manage preference settings
- A.3.7. (For the authoring tool user interface) Ensure that previews are at least as accessible as in-market user agents
ATAG example: in a Content Management System (CMS)
data:image/s3,"s3://crabby-images/92bab/92bab4da186849d314c8969e7fc6fd2acb9ea772" alt="Screenshot of the Wagtail 6.3 page editor, with a sidebar to the left, an editing form, and to the right a preview panel with a dark theme web page"
ATAG in practice: Part A
My highlights โ things that go far beyond WCAG ๐
Part A: Make the authoring tool user interface accessible
- A.2.1. Make alternative content available to authors
- Alt text for all images, decorative or no!
- A.3.2.1 Auto-Save
- Either no session time limit, or auto-saving
- A.3.5. Provide text search of the content
- Browser built-in search and
hidden="until-found"
to the rescue?
- Browser built-in search and
- A.4.2. Document the user interface, including all accessibility features
- ๐ ๐๐
Documenting features: for developers and for users
data:image/s3,"s3://crabby-images/c0c61/c0c6150840450ec14b938cfa59704ecb9be70c4b" alt="Screenshot of the Wagtail user guide website homepage. Features a navigation sidebar to the left, and page content listing sections to the right: getting started, how-to, concepts"
Docs coverage for devs: 80%. For editors: 52 of 145 features (35%)
ATAG in practice: Part B
To infinityโฆ and beyond WCAG! ๐
B.1. Fully automatic processes produce accessible content
data:image/s3,"s3://crabby-images/aa98a/aa98abfdf7af4251ccb5d70ab94254da5b29f077" alt="Screenshot of the DSF membership nomination form, with a number of fields, including email and Your name"
B.2.3. Assist authors with managing alternative content for non-text content
(as in โ help people creating alt text (and captions))
data:image/s3,"s3://crabby-images/118a2/118a279dfe2f270ee64d10f3dbc10ed573e51db8" alt="Screenshot collage of Mastodon. To the left the post editor, with in-progress content including an image. There is a warning triangle with the word 'Alt' in yellow. To the right, the interface to edit images, with a multiline text field: 'Describe for people who are blind or low-vision'. There is also a 'Detect text from picture' button below"
B.2.4. Assist authors with accessible templates
data:image/s3,"s3://crabby-images/679b8/679b80124488a468f417e986c9d51741a2c161b2" alt="Screenshot of the WordPress theme, accessibility ready tag in the tag filter"
B.3.1. Assist authors in checking for accessibility problems
data:image/s3,"s3://crabby-images/62877/628776891a751179d04d18e2a8e9bfd64c171e24" alt="Sa11y accessibility checker widget, over a blog page. The widget spotted a heading error, and displays alt text for manual review"
B.3.2. Assist authors in repairing accessibility problems
Example: alt text
data:image/s3,"s3://crabby-images/9ffb8/9ffb8386664d54aa3a81cbc108cfe964016fe83b" alt="Bar chart comparing Wagtail AI vs. existing alt text quality, based on 441 homepages, scored by the accessibility team. Real-world alt text scores low. AI alt text scores higher, with 49% of AI alt texts scored 5/5 compared to 8% for real-world"
B.3.2. example implementation
data:image/s3,"s3://crabby-images/75c5c/75c5cc18768a4fd2d8e23b9ad31ba072ab50a975" alt="Screenshot of the Wagtail Upload images interface. It says 3 images were uploaded successfully, and offers three different options to fill the description field"
Get started
Prerequisites
(which you can arrive at iteratively)
- Good documentation of project features
- Good demo setup to test said features
- (Some) knowledge of ATAG
- Report format
And thatโs it! ๐ ๐
Report templates
Markdown: atag_wagtail_template.md
18ATAG Report Tool
data:image/s3,"s3://crabby-images/9334f/9334f1b2364e352633ab650387d724f8d0e214a4" alt="Screenshot of the WAI ATAG Report Tool interface, Overview page, with existing report under way in sidebar"
Authoring Tools List
data:image/s3,"s3://crabby-images/f0a41/f0a411f19d3a6cb178a3145351748d5971e811d5" alt="Screenshot of the WAI Authoring Tools list"
Beyond WCAG and ATAG
Thank you! โค๏ธ
Come say hi and ask questions?
- Mastodon: @thibaudcolas@fosstodon.org
- Bluesky: @thibaudcolas.bsky.social
- X: @thibaud_colas
- LinkedIn: Thibaud Colas
- GitHub: @thibaud_colas
Progress for Wagtail
Conformance Level | ATAG | Part A | Part B |
---|---|---|---|
Pass | 28 (+6 ๐) | 14 (+2 ๐ค) | 14 (+4 ๐) |
Fail | 24 (-6) | 15 (-2) | 9 (-4) |
Not applicable | 13 | 4 | 9 |
Per ATAG report tool
23