Document Tree
Document Properties
Kbid
31375X
Last Modified
01-Apr-2025
Added to KB
01-Apr-2025
Public Access
Everyone
Status
Online
Doc Type
References
Product
Intershop Progressive Web App
Reference - Accessibility Release Documentation

Introduction

This page documents the code changes related to accessibility improvements in the Intershop PWA release 6.0.

Glossary

Term

Description

ARIA

Accessible Rich Internet Applications (ARIA) is a set of roles and attributes that define ways to make web content and web applications (especially those developed with JavaScript) more accessible to people with disabilities.

Lighthouse

Lighthouse is an open source, automated tool that helps you improve the quality of web pages.

WCAG

Web Content Accessibility Guidelines (WCAG) are internationally recognized requirements that ensure web content is accessible to all users, including those with disabilities.

Detailed Description of Accessibility Commits

The following table provides more details about the commits of the following pull requests: Accessibility Improvement Pull Request, Add password reveal button, Set focus on the first invalid form field, Sticky header feature toggle.

Commit

Code changes

add ARIA, lang and title attributes

  • Add aria-labelaria-labelledby (WCAG 2.5.3 - Label in Name & WCAG 3.3.2 - Labels or Instructions) to:

    • Select boxes/switches that do not have a label, such as language switch toggle, mini-cart toggle, sorting select box, etc.

    • Input fields that do not have a label, such as search input, promotion code input, order history search filter input, etc.

    • Links that need more information (because they are images or the link is not meaningful enough), such as product comparison status link, recently viewed link, product brand link

    • Non-text content such as star rating on the product detail page (WCAG 1.1.1 - Non-text Content)

  • Add role="img" and an aria-label to the product rating stars to treat them as a single image instead of individual stars, for example: https://codepen.io/svinkle/pen/oYjoNE.

  • Add aria-haspopuparia-expanded and aria-controls to elements with collapsible content such as mini-cart or promo code entry (WCAG 4.1.2 - Name, Role, Value).

  • Add aria-requiredaria-invalid to form fields (WCAG 3.3.1 - Error Identification) and aria-describedby to form fields with related error test and / or descriptions (WCAG 3.3.2 - Labels or Instructions, based on changes to ngx-formly/bootstrap).

  • Add aria-hidden to prevent content from being read by screen readers, for example the "*" character at required fields and in the legend for the form (* Required field).

  • Add title attribute to buttons only when they are used as an icon: Buttons can be displayed as default buttons or icons. The title attribute is only used when the button is displayed as an icon. (WCAG 1.1.1 - Non-text Content).

  • Add the corresponding lang attribute to each language select option in the header language switch (WCAG 3.1.2 - Language of Parts).

  • Change language options to display the full name (e.g., "English") instead of the shortened version (e.g., "EN") in the header language switch (WCAG 2.5.3 - Label in Name).

  • Remove the invalid role="img" attribute from the logo, as its function as a link to the homepage is more important than its graphical meaning (WCAG 4.1.2 - Name, Role, Value).

  • Set a valid id attribute value for collapsible filter elements to fix the Lighthouse error “[aria-*] attributes do not have valid values“ for collapsible filter elements in the sub navigation.

  • Ensure that alert messages with role="alert" are read by screen readers, including those rendered dynamically after REST requests.

replace <div role="main"> with <main> element for better semantics

 (WCAG 2.4.1 - Bypass Blocks)

  • The <main> element conveys its purpose directly to browsers, screen readers, and other assistive technologies without requiring additional attributes like role="main". Screen readers and assistive technologies natively recognize the <main> element as the page's main content area.

  • Search engines and crawlers prefer semantic elements as they provide better context and meaning about the content of the page.

update tab-focus visibility to use browser's default focus styling

 (WCAG 2.4.7 - Focus Visible)

  • Fix styling of elements to be tab-focus visible and reset :focus-visible for form elements to use the browser's default tab-focus styling.

  • Enlarge and harmonize dimensions of header elements for uniform focus styling.

  • Fix tab-focus of elements in the sticky header.

  • Fix tabbable elements on product lists (product images and action icons).

reorder headings to follow a correct, sequentially-descending hierarchy

 (WCAG 1.3.1 - Info and Relationships)

  • Fix Chrome Lighthouse error "Heading elements are not in a sequentially-descending order".

  • Change headline markup (e.g., from <h3> to <h2>) to ensure the correct hierarchical order, and use special CSS classes, such as .h3, to apply the desired styling.

  • Update ICM Demo Data XML import: Change footer headlines.

  • Update ICM Demo Data XML import: Change CMS content pages.

adjust colors to meet sufficient contrast ratio requirements

 (WCAG 1.4.3 - Contrast (Minimum) & WCAG 1.4.11 - Non-text Contrast)

  • Fix Lighthouse error "Background and foreground colors do not have a sufficient contrast ratio."

  • Update primary color and gray colors, links on dark backgrounds, form elements and input placeholders.

  • Link :hover status does not change the color to prevent contrast issues.

  • Update colors in logo and home screen images, change file type from PNG to SVG for the logo file.

  • Update ICM Demo Data XML import: Changed red promo text inline styling (e.g., "3% off", "free shipping!") from #ff0000 to #cc0000.

enlarge touch targets for links

(WCAG 2.5.8 - Target Size (Minimum))

  • Fix Lighthouse error "Touch targets do not have sufficient size or spacing" for paging, footer and links in static content pages, review stars.

ensure links are distinguishable without relying on color alone, update underline behavior

(WCAG 2.4.4 - Link Purpose (In Context))

  • Fix Lighthouse error "Links rely on color to be distinguishable.”:

    • Underline common links.

    • Underline certain links, such as product links, on hover to ensure a visually appealing design.

add "Skip to main content" link

(WCAG 2.4.1 - Bypass Blocks)

  • Improve navigation for keyboard and screen reader users to bypass repetitive navigation links and jump directly to the core content and to meet the requirement for WCAG 2.2 Level A and AA compliance.

add missing <legend>-elements to form fieldsets

(WCAG 1.3.1 - Info and Relationships)

  • Add a <legend> tag to fieldset and add localization keys.

improve keyboard support

(WCAG 2.1.1 - Keyboard)

  • Make popover elements keyboard-accessible with TAB navigation:

    • Popover elements are focusable using the TAB key and can be shown or hidden with a mouse click or the ENTER/SPACE key.

    • A popover can be dismissed by clicking outside of its area.

    • Exception: For budget bars in My Account, the popover is triggered by hover only.

  • Improve TAB key navigation in mini cart by using ngbDropdown.

  • Fix the country select box to keep tab-focus after selecting a country and ensure operability via arrow keys (WCAG 2.4.7 - Focus Visible):

    • Previously, changing the country caused the entire address form, including the country select box, to be updated/replaced, removing tab focus from the select box.

    • This also removed focus when operating the select box with arrow keys.

    • Now, the form is modified to update every field except the country select box, ensuring tab focus remains even when changing the country.

add/enhances attributes for better screen reader support

  • Add missing aria-labels and titles.

  • More descriptive titles (e.g., infobox edit titles).

  • Remove unnecessary attribute binding (e.g., for titles, alt attributes etc.).

  • Refactor aria-describedBy for form field descriptions and form errors.

replace animated buttons by simple icon button

  • Remove animations and text label from button bars (e.g., on product detail and wishlist page) to simplify usability.

  • Change the share icon

add accessible names for dialogs

(WCAG 4.1.2 - Name, Role, Value)

  • Connect the open dialog link with the dialog title by an aria-describedBy attribute.

provide/improve meaningful h1 headings

  • Separate buttons (e.g., create buttons on list pages) from h1 headings to make them more readable.

  • Add h1 heading (for screen readers only) on homepage.

  • Make sure each page has a h1 heading to give users an overview of the page content.

add password reveal button

  • Add functionality to toggle password visibility for password fields for desktop and larger touch devices.

  • Replace TextInputFieldComponent with PasswordFieldComponent or PasswordNovalidateFieldComponent to provide password-specific functionality.

  • Update error field indicator from "x" to "!" for improved clarity and accessibility.

The implementation follows Microsoft Edge guidelines:

  • The password visibility toggle button remains disabled until the user enters text into the password field. If the focus moves away from the field, the button is disabled again to maintain security. To enable the button once more, the user must delete the contents of the password field. This behavior prevents someone from briefly changing focus to reveal the password if the user leaves the device unattended.

  • The button does not appear when the password field is autofilled.

set focus to first invalid form field

 (WCAG 3.3.1 - Error Identification)

  • A directive ishFormSubmit has been introduced for form HTML elements to set the focus automatically on the first invalid form field after form submit.

  • The form components have been refactored. After form submission, the markAsDirtyRecursive method is no longer called for Formly forms. The button is disabled using the submitted property from a corresponding FormGroupDirective, which defines a variable #form="ngForm" at the form HTML element.

sticky header feature toggle

  • Add a feature toggle stickyHeader to switch the sticky header display on or off.

Disclaimer
The information provided in the Knowledge Base may not be applicable to all systems and situations. Intershop Communications will not be liable to any party for any direct or indirect damages resulting from the use of the Customer Support section of the Intershop Corporate Web site, including, without limitation, any lost profits, business interruption, loss of programs or other data on your information handling system.
The Intershop Knowledge Portal uses only technically necessary cookies. We do not track visitors or have visitors tracked by 3rd parties. Please find further information on privacy in the Intershop Privacy Policy and Legal Notice.
Home
Knowledge Base
Product Releases
Log on to continue
This Knowledge Base document is reserved for registered customers.
Log on with your Intershop Entra ID to continue.
Write an email to supportadmin@intershop.de if you experience login issues,
or if you want to register as customer.