Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

XWIKI-19723: Navigation panel not accessible using a screen reader #3789

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

Sereza7
Copy link
Contributor

@Sereza7 Sereza7 commented Jan 3, 2025

Jira URL

https://jira.xwiki.org/browse/XWIKI-19723

Changes

Description

  • Added a sr-only description next to every tree AFAIK. This works for the navigation panel.
  • Added a default id for document trees
  • Added a translation key to contain the tree technical description.

Clarifications

  • The ids of the description objects are not always unique. It'd be great to have an access to the JSTree instance_counter to generate those, but unfortunately it's not possible easily, and afaics any solution would have to be a bit hacky. Setting up our own velocity templating counter does not work since we load this tree.vm script multiple times. It's technically bad to have multiple items with the same ID, however here it's for literally the same item/content, so it doesn't matter much (only the DOM position changes). Thanks to the resilience of web browsers and NVDA, we can see that everything still works correctly :)

Screenshots & Video

Here are some demos I took with Chrome 131, NVDA and some XWiki 17.0.0 snapshot run locally.
Before the changes
https://github.com/user-attachments/assets/8016dc85-289f-417f-95d9-ff9a4d9501c7
We can see that the state of the tree is properly conveyed. However when the user arrives on it, nothing is said about how to operate it.
https://github.com/user-attachments/assets/5afb6262-3a5d-4c8b-820e-5cf0b20b9e09
Now, right when the user tabs to the tree, info about how to handle it is read out. Note that this info is read again when the user clicks on a X more link that reloads the whole tree. It could be a small annoyance but the benefits far outweight this drawback.

Executed Tests

First, I successfully rebuilt all of the module affected by some changes: mvn clean install -f xwiki-platform-core/xwiki-platform-tree/xwiki-platform-tree-macro ;mvn clean install -f xwiki-platform-core/xwiki-platform-tree/xwiki-platform-tree-war; mvn clean install -f xwiki-platform-core/xwiki-platform-index/xwiki-platform-index-tree/xwiki-platform-index-tree-macro. I went through the TreeElement BaseElement for docker tests, and it seems like the changes brought do not impact any xpath or query used in there. I then ran the tests on the whole xwiki-platform-index module with mvn clean install -f xwiki-platform-core/xwiki-platform-index/xwiki-platform-index-test/xwiki-platform-index-test-docker -Dxwiki.test.ui.wcag=true. The tests passed properly and no WCAG failure was found. They extensively use the TreeElement and child classes.

Expected merging strategy

  • Prefers squash: Yes
  • Backport on branches:
    • 16.10.X (relatively safe changes, even though the scope of the UI changes is quite large)

* Added a `sr-only` description next to every tree AFAIK. This works for the navigation panel.
* Added a default id for document trees
* Added a translation key to contain the tree technical description.
@@ -37,6 +37,9 @@

#macro (tree $options)
<div #treeAttributes($options)></div>
<span id="xtree#if($!{macro.options.id})-$!{macro.options.id}#{end}-description" class="sr-only">
$services.localization.render('tree.macro.description')
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
$services.localization.render('tree.macro.description')
$escapetool.xml($services.localization.render('tree.macro.description'))

@@ -28,6 +28,7 @@
'filterByClass': '',
'filterHiddenDocuments': true,
'hierarchyMode': 'reference',
'id': 'document',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think this is the right place. The comment above says:

Configuration options for the Document Tree Source (that is used to retrieve the tree nodes).

We don't need the id to retrieve the tree nodes. The proper place is rather https://github.com/xwiki/xwiki-platform/blob/master/xwiki-platform-core/xwiki-platform-tree/xwiki-platform-tree-war/src/main/webapp/templates/tree_macros.vm#L20 (that's where we set the default CSS class for instance).

As for the default id value, since we can't easily have a counter, I think we can use a random value. Here's an example https://github.com/xwiki/xwiki-platform/blob/master/xwiki-platform-core/xwiki-platform-ckeditor/xwiki-platform-ckeditor-ui/src/main/resources/CKEditor/FileUploader.xml#L88 (timestamp + small random). I'd go with:

'id': "xtree-${datetool.date.time}-${mathtool.random(100, 1000)}",

@@ -37,6 +37,9 @@

#macro (tree $options)
<div #treeAttributes($options)></div>
<span id="xtree#if($!{macro.options.id})-$!{macro.options.id}#{end}-description" class="sr-only">
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think we should force an ID prefix. The default ID can have a prefix (see my other comment), but if the user specifies an ID, we should use it as is, i.e. we should only add the -description suffix.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants