This article provides key principles and best practices for aligning with WCAG 2.1 Level AA.
Keep these principles in mind when developing for accessiblity.
Check the documentation to identify which components and controls do not meet WCAG requirements and avoid using them. These are marked with .
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.
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.
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.
Always provide text alternatives for images using alt text so that visually impaired users can understand the content.
Ensure that all functions can be used without sound.
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.
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."
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.
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:
Use color schemes that are distinguishable for colorblind users. Avoid combinations that may be difficult to interpret.
Use clear and simple language, avoiding complex words or abbreviations to ensure comprehension for all users.
Provide clear instructions for fields that require specific formats (e.g., phone numbers, dates) to help users avoid errors.
Ensure the system has a clear and consistent navigation structure to improve the user experience. Use a logical and predictable layout.
Make sure the system is structured logically and consistently in both layout and functionality to support usability.
Include a help section to explain advanced features and assist users in understanding complex aspects of the system.
Provide clear, helpful error messages that explain what went wrong and how to fix it. Guide users in resolving issues effectively.
Offer explanations for complex fields or choices to ensure users understand what is expected and how to enter information correctly.
Here are the key settings and actions to ensure your system complies with WCAG.
Activating UseAccessibilityMode provides several improvements:
To enable this, go to:
Admin > System settings > Global/Local settings > Accessibility > UseAccessibilityMode > "Yes"
Avoid using nowrap
where possible. Allowing text to wrap prevents grids from becoming unnecessarily wide.
Since Softadmin® has limited responsiveness, vertical stacking is usually the best approach. This prevents layout issues and unwanted horizontal scrolling, which violates WCAG.
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"
Set AccessibilityTitle in the grid procedure to ensure checkboxes and similar elements provide relevant information for screen readers.
Define the autocomplete type for each field to improve usability.
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).
Even user-generated content must follow accessibility principles. The system should enforce these rules: