WCAG 2.1 Level AA Compliance in Softadmin®

This article provides key principles and best practices for aligning with WCAG 2.1 Level AA.

A browser window with the text "WCAG"

Accessibility Principles

Keep these principles in mind when developing for accessiblity.

Check the Documentation First

Check the documentation to identify which components and controls do not meet WCAG requirements and avoid using them. These are marked with A slashed universal acess icon.

Use Controls as Intended

Softadmin® provides built-in controls designed with accessibility in mind. Avoid repurposing controls for unintended use, as this can lead to WCAG violations.

For example:

  • Forcing styling to mimic a button using a <div> instead of a proper <button> makes it inaccessible to keyboard users.

  • Misusing labels to achieve a certain visual look may result in missing or incorrect screen reader information.

Stick to the platform’s intended functionality to support accessibility and maintain a consistent user experience.

Keyboard Navigation Only

Ensure that all interactive elements are accessible via the keyboard so users don’t need a mouse to navigate. Test the system using only keyboard navigation to verify this.

Proper HTML Structure

Use correct HTML semantics (e.g., <button>, <a>, <label>, etc.) for all interactive elements. This makes it easier for screen readers to interpret content and for users to interact with it.

Alt Text for Images

Always provide text alternatives for images using alt text so that visually impaired users can understand the content.

Don’t Rely on Audio

Ensure that all functions can be used without sound.

Screen Reader Compatibility

Regularly test with a screen reader, such as NVDA or Windows Narrator (Win + Ctrl + N), to verify system compatibility and ensure expected content is read aloud.

Readable Labels

Ensure that all form fields have clear and correctly associated labels for better accessibility. If a label is named "-", replace it with meaningful text such as "Start Date" and "End Date."

Sufficient Contrast - Avoid Custom Colors

Softadmin® generally provides WCAG-compliant colors by default. If using a custom color theme or Row_Color to change text color in grids, ensure sufficient contrast. Use tools like WebAIM Contrast Checker or your browser’s inspector to verify a minimum contrast ratio of 4.5:1 for text.

Don’t Use Color Alone

A green pill for "Active" with a checkmark icon and the text "Active" and a red pill for "Inactive" with a cross icon and the text "Inactive"
Communicate information, such as status, using more than just color. Use text and icons to make information accessible to all users, including those with color blindness. For example:

  • Green for "Active" with a checkmark icon and text "Active"
  • Red for "Inactive" with a cross icon and text "Inactive"

Color Choices for Colorblind Users

Use color schemes that are distinguishable for colorblind users. Avoid combinations that may be difficult to interpret.

Easy-to-Read Text

Use clear and simple language, avoiding complex words or abbreviations to ensure comprehension for all users.

Clear Input Instructions

Provide clear instructions for fields that require specific formats (e.g., phone numbers, dates) to help users avoid errors.

Consistent Navigation

Ensure the system has a clear and consistent navigation structure to improve the user experience. Use a logical and predictable layout.

Logical and Consistent Layout

Make sure the system is structured logically and consistently in both layout and functionality to support usability.

Help Section

Include a help section to explain advanced features and assist users in understanding complex aspects of the system.

Error Messages and Feedback

Provide clear, helpful error messages that explain what went wrong and how to fix it. Guide users in resolving issues effectively.

Explanations for Complex Fields

Offer explanations for complex fields or choices to ensure users understand what is expected and how to enter information correctly.

Settings

Here are the key settings and actions to ensure your system complies with WCAG.

Enable UseAccessibilityMode

A dropdown input with a label and a description
Activating UseAccessibilityMode provides several improvements:

  • Grid Adaptation: Grids adjust to minimize width. If a grid contains a lot of data and exceeds the screen width, horizontal scrolling is restricted to the grid container, preventing the entire page from being affected.
  • WCAG-Friendly Colors: The favorite star color is adjusted to meet WCAG contrast requirements.
  • Mandatory Field Notice: A message stating "Fields marked with a star are mandatory" is added at the beginning of each NewEdit page.

To enable this, go to:
Admin > System settings > Global/Local settings > Accessibility > UseAccessibilityMode > "Yes"

Remove Nowrap on Field Info

Avoid using nowrap where possible. Allowing text to wrap prevents grids from becoming unnecessarily wide.
A checkbox with both a label and a description

Prioritize Vertical Layouts Over Wide Content

Since Softadmin® has limited responsiveness, vertical stacking is usually the best approach. This prevents layout issues and unwanted horizontal scrolling, which violates WCAG.
Two browser windows with overflowing contents.

Multirow Settings

New rows in multirow should not be created using the Tab key. The Tab key is expected to move between fields. Using it to create new rows disrupts navigation for keyboard users. Instead, configure:
Multirow settings > New rows using > "UI Button and Ctrl+Enter"

Accessibility Information for Grids

Set AccessibilityTitle in the grid procedure to ensure checkboxes and similar elements provide relevant information for screen readers.

Autocomplete Types

Define the autocomplete type for each field to improve usability.
A text field with a description and a label

Disable Favorites for Most Users

Disable favorites for users who don’t need them via the user table CanUseFavorites. The favorite list uses a Treeview, which is not WCAG-compliant (as of February 2025).

User-Generated Content

Even user-generated content must follow accessibility principles. The system should enforce these rules:

  • Text Contrast: Ensure text has sufficient contrast (at least 4.5:1) against the background. Limit color choices or warn users of low contrast.
  • Structured HTML: Content should be properly formatted with headings and lists for semantic correctness.
  • Alt Text for Images: Require users to add alternative text when uploading images.