I’m totally willing to fix any accessibility issues that come up, are you discovering these through the Lighthouse audit built-in to Chrome, something else?
Awesome!
Yes I am using the google lighthouse audit.
Split this into its own topic to dig into the issues a bit more. Starting with the…
Topic list
Outside of contrast, which for now is fixable with CSS… there are 2 issues:
- This first one with the list items seems to be a bug with the auditor, or maybe a quirk with how the auditor is seeing how our page renders? These list items are definitely contained.
-
The second issue is
[aria-*] attributes do not have valid values
. This is specifically calling out our category and tag dropdowns… the issue here seems to bearia-haspopup
. According to the example here Navigation Menu Button Example | WAI-ARIA Authoring Practices 1.1 we should havearia-haspopup="true"
instead of justaria-haspopup
Looks like we weren’t passing true as a string, I fixed that here: https://github.com/discourse/discourse/commit/b848bd4ddce37812d2ffc22f365188d9aa23637c
Topics
One issue (aside from contrast and the previously mentioned li
non-issue)
Links do not have a discernible name
Link text (and alternate text for images, when used as links) that is discernible, unique, and focusable improves the navigation experience for screen reader users. Learn more.
Two occurrences:
-
Each post gets an
a.tabLoc
element with no dimensions. These appear to be for navigating posts with the keyboard? Hidden witharia-hidden: true
because they’re useless to screen readers. Hide empty anchor tag from screen readers · discourse/discourse@bdaf07a · GitHub -
The envelope icon used to denote when a topic is a personal message also links to your PM inbox, and we were loading that link for all topics… even if they aren’t PMs. I made that link conditional to PMs, and also added a title attribute and aria-label. Don't load PM icon in title unless topic is a PM · discourse/discourse@1983f0d · GitHub and UX: Add title attribute and aria-label to PM icon link · discourse/discourse@aa71818 · GitHub