Editoria11y Accessibility Checker

Description

Editoria11y (“editorial accessibility ally”) is a quality assurance tool built for an author’s workflow:

  1. It provides instant feedback. Authors do not need to remember to press a button or visit a dashboard to check their work.
  2. It checks in context on pages, not just within the post editor, allowing it to test content edited in widgets or theme features.
  3. It focuses exclusively on content issues: assisting authors at improving the things that are their responsibility.

It is meant to supplement, not replace, testing your code and visual design with developer-focused tools and testing practices.

The authoring experience

Check out a demo of the checker itself.

  • When logged-in authors and editors are viewing published or in-preview pages, Editoria11y’s toggle discretely indicates if any issues are present on the current page.
  • Clicking the toggle opens the checker’s main panel. Alerts are placed on pieces of content with issues, with tooltips to explain each problem and what actions are needed to resolve it. If an issue is not critical or may be OK as written, buttons are available to dismiss the alert on this page, either for the current user (“Hide alert”) or for all users (“Mark as Checked and OK”).
  • When Editoria11y finds new issues on a page that was just edited, the panel pops open automatically.
  • The main panel also allows authors to jump to the next issue, restore previously dismissed alerts, visualize text alternatives for images on the page (“alts”), and view the document’s heading outline.
  • Optionally, the checker can also outline blocks with issues while the author is editing the content.

The admin experience

  • Filterable reports let you explore recent issues, which pages have the most issues, which issues are most common, and which issues have been dismissed. These populate and update as content is viewed and updated.
  • Various settings are available to constrain checks to specific parts of the page and tweak the sensitivity of several tests.

Note that all this runs locally within your site. This plugin is the WordPress adaptation of the free and open-source Editoria11y library. Tests run in the browser and findings are stored in your own database; nothing is sent to any third party.

The tests

  • Text alternatives for visual content
    • Images with no alt text
    • Images with a filename as alt text
    • Images with very long alt text
    • Alt text that contains redundant text like “image of” or “photo of”
    • Images in links with alt text that appears to be describing the image instead of the link destination
    • Embedded visualizations that usually require a text alternative
  • Meaningful links
    • Links with no text
    • Links titled with a filename
    • Links only titled with generic text: “click here,” “learn more,” “download,” etc.
    • Links that open in a new window without warning
  • Document outline and structure
    • Skipped heading levels
    • Empty headings
    • Very long headings
    • Suspiciously short blockquotes that may actually be headings
    • All-bold paragraphs with no punctuation that may actually be headings
    • Suspicious formatting that should probably be converted to a list (asterisks and incrementing numbers/letters prefixes)
    • Tables without headers
    • Empty table header cells
    • Tables with document headers (“Header 3”) instead of table headers
  • General quality assurance
    • LARGE QUANTITIES OF CAPS LOCK TEXT
    • Links to PDFs and other documents, reminding the user to test the download for accessibility or provide an alternate, accessible format
    • Video embeds, reminding the user to add closed captions
    • Audio embeds, reminding the user to provide a transcript
    • Social media embeds, reminding the user to provide alt attributes
  • Custom results provided by your JS

Credit

Editoria11y’s WordPress plugin is maintained by Princeton University’s Web Development Services team:

Editoria11y began as a fork of the Toronto Metropolitan University’s Sa11y Accessibility Checker, and our teams regularly pass new code and ideas back and forth.

Screenshots

  • Checker with an open “manual check” request
  • Optional feature: highlighting live in the block editor
  • Site-wide reporting dashboard
  • Checker set to dark theme, showing a table header alert

Installation

Editoria11y’s default settings will work great for most sites.

Your first task after installation should be clicking through a representative sampling of the main pages of your site. This will start to populate your dashboard report, and give you a chance to look for issues to fix or dismiss.

If you notice anything amiss, experiment with these settings:

  1. Pick a “Theme for tooltips” that looks nice with your site’s colors.
  2. If the checker is flagging issues that are not relevant to content editors, either use “Check content in these containers” to constrain checks to the parts of the page with editable content, or “Exclude these elements from checks” to skip over certain elements, regions or widgets.
  3. Editoria11y also provides a minimalist “as-you-type” issue highlighter that works inside the Block Editor/Gutenberg. If you find this feature annoying rather than helpful, change “Highlight issues while editing content” to “Only definite errors” or “None.”
  4. If you do not want PDF or other document types flagged for manual checks, provide a shorter selector list or set “Document types that need manual review” to false
  5. If your theme has done something very unusual with its layout, such as setting the height of the content container to 0px, you may see confusing alerts when opening Editoria11y tips saying that the highlighted element may be off-screen or invisible. If that happens, disable “Check if elements are visible when using panel navigation buttons.” This is disabled by defaults on any WordPress themes we have noticed this on, so if you find a theme

If you are a theme developer, note that the library dispatches JavaScript events at several key moments (scan finishes, panel opens, tooltip opens or shuts), allowing you to attach custom functionality. JavaScript on sites running Editoria11y can use these events to do things like automatically opening accordion widgets if they contain hidden alerts, disabling “sticky” site menus if the panel is open, inserting custom results, or syncing results to third-party dashboards.

And then…tell us how it went! This plugin and its base library are both under active development. Ideally send bug reports and feature requests through the GitHub issue queue.

FAQ

How is this different from other checkers?

Editoria11y is meant to supplement, not replace, these tools.

Editoria11y is…spellcheck: a seamless, automatic and intuitive integration for content authoring. It:

  • Does not require training before use.
  • Eschews obfuscation and techno-legal jargon. It explains what the issue is in plain language, with a simple explanation of how to fix it. “This image needs alternative text” with a short explanation of what alternative text is makes sense without prior technical knowledge; “Failure of WCAG 1.1.1 Level A: Non-text Content” does not.
  • Deliberately excludes tests for theme and plugin issues, like invalid HTML tags and ARIA attributes. Testing is critically important for themers and developers, but it is work for themers and developers, not content editors. For ongoing quality assurance, Editoria11y provides people with a tool that fits their role, so they only receive alerts for things they can fix.

How is this different from Sa11y?

Editoria11y’s test suite is quite similar to Sa11y. Editoria11y began as a Sa11y fork, and the maintainers collaborate on new tests and optimizations.

The look, feel and features outside of the core test suite are a bit different. At a high level:

  • Sa11y focuses on flexibility and extensibility:
    • The end-user can override appearance and test coverage settings from the results panel
    • A legibility scoring library is included
    • A contrast checking library is included
  • Editoria11y focuses on providing a shared experience for all editors:
    • An API is added, meaning findings are synchronized with your site’s database, populating a site-wide reporting dashboard
    • Manual-checks marked as “OK” are dismissed for all users, not just the current user
    • Issues can be highlighted within the Block Editor/Gutenberg as you edit, not just on the published page
    • All configuration is managed in the plugin settings

Is this an overlay?

Overlays are tools that modify your site’s public pages according to automated attempts to modify its code and design, claiming these machine-generated changes to your site will better meet the accessibility needs of your users.

Overlays may override your font sizes or colors, or modify its heading tags and buttons. You should familiarize yourself with the assistive technology compatibility problems overlays may introduce before assuming these changes will be helpful.

Editoria11y is not an overlay. It does not modify the site viewed by not-logged-in-users in any way. It is an editor-facing “spellchecker” that helps your site editors create accessible content.

Reviews

12 de junio, 2024
I have used other accessibility checkers that cannot function properly outside of core and are crazy complicated. This work wonderfully in core, Bricks Builder, and even Avada (live builder). The reporting is easy to understand and the plugin is so lightweight. Thank you for this!
7 de junio, 2024
We’ve been using this plugin for a while. It’s a great asset for composing posts. The checks show up in real time as content is added to the editor, which is a huge help and reminder to write accessible content the first time around, rather than having to go back and fix badly presented content later. I also appreciate that this checker focuses on the issues that an editor can actually control and excludes issues with navigation, headers, etc. While these other issues are important and deserve a look by an administrator or site designer, they would only be a distraction to someone editing a post.
28 de noviembre, 2023
I’ve experimented with installing similar tools like Tota11y, Sa11y, and the Equalize Digital Accessibility Checker, but this is the tool that has stuck for me because it feels the most approachable to less-experienced editors and it provides suggestions for fixing things. The errors are helpfully focused on issues that editors can actually do something about, and I think it mostly gets the right balance of making errors appear urgent but not overwhelming. Each error includes an explanation of why the issue is important and how to resolve it, so that editors can actually take action. And the ability to track issue resolutions overtime in the dashboard is fabulous!
17 de mayo, 2023
My agency has been installing the Editoria11y javascript as part of a custom theme on every client site for months. I was delighted to discover it’s now available as an official plugin in the repository. We build sites and train clients on how to enter and update content. Editoria11y Accessibility Checker is a fantastic training tool – it helps content editors see where accessibility problems exist in their content, and helps them figure out solutions and alternatives. Using the plugin is a no-brainer; editors see the alerts right in the web page next to the problem. Even if you’re not concerned about accessibility (you should be), you can use this plugin to highlight issues that affect SEO, since accessibility is closely related to SEO. We’re going to be using this plugin on every site for the foreseeable future. Thanks for building this!
Read all 4 reviews

Contributors & Developers

“Editoria11y Accessibility Checker” is open source software. The following people have contributed to this plugin.

Contributors

Changelog

1.0.19

1.0.18

1.0.17

1.0.16

1.0.15

1.0.14

1.0.13

  • Themes and plugins can now provide custom results.
  • Old results will clear from the dashboard when clicking through to a page with checking disabled.
  • More accurate accessible name calculation for complex situations involving CSS generated content, nested SVG or aria-labelledby references.
  • Headings are now clickable in the outline panel.
  • Experimental inline checker now highlights specific links with issues within a block.
  • Bugfix: Experimental inline checker was not appearing in some contexts.
  • Bugfix: two consecutive paragraphs starting with “A ” could throw a false positive on the possible link test.