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

fix(nested-interactive/aria-text): allow "tabindex=-1" on elements with no role #3165

Merged
merged 43 commits into from
Dec 6, 2021

Conversation

dan-tripp
Copy link
Contributor

Closes issue: #2934

@dan-tripp dan-tripp requested a review from a team as a code owner September 24, 2021 01:24
@dan-tripp
Copy link
Contributor Author

"ci/circleci: test_win — Your tests failed on CircleCI" - I can't tell if that test failed because of my changes, or if it was going to fail anyway. code owners - let me know if I should do anything.

@bastilimbach
Copy link

@dan-tripp Thanks for fixing this!
I came across a different case where tabindex="-1" should be ignored: presentation-role-conflict

Fails:

<button>
  Test
  <svg class="icon" tabindex="-1" role="presentation">...</svg>
</button>

Works:

<button>
  Test
  <svg class="icon" role="presentation">...</svg>
</button>

Codepen:
https://codepen.io/bastilimbach/full/KKqEVGG

Is this something you are willing to include in this PR? I can also create a separate issue.

@dan-tripp
Copy link
Contributor Author

@bastilimbach I'd be happy to, and that change seems sensible to me. However, I'm new here, so I think that I had better leave it to the core team to decide what the desired behaviour ought to be. If it's not too much trouble, could you create a new issue and tag me? Then I'll try to make a separate PR for your new issue, if it gets some approval from the core team.

@straker
Copy link
Contributor

straker commented Sep 30, 2021

@bastilimbach so with presentation-role-conflict that result from axe-core is correct. The algorithm takes into account any value of tabindex, so testing a similar example all browsers and screen readers ignore the role=presentation on the element.

<ul>
  <li tabindex="-1" role="presentation">World</li>
</ul>

Chrome - Treats the li element as a listitem role
Firefox - Treats the li element as a listitem role
Safari / VO - Announces "group" (instead of no role)

The reason is that because of the tabindex the element can be focused programmatically which means that screen readers must announce a role for the element (it can't be presentational).

@straker
Copy link
Contributor

straker commented Sep 30, 2021

@dan-tripp Thanks for taking on this pr. I've been trying to figure out if there were any problems with allowing tabindex=-1 on the descendants of role=text. What I've decided is that we should hold off on doing this.

The reason for that is that this change directly affects the nested-interactive rule, allowing tabindex=-1 on descendants of interactive elements to pass the rule. It was pointed out that doing this would pose problems for screen readers and so we decided to create new messages to point that out. So before we do this we first need to resolve that issue.

If this change only affected the aria-text rule I would be fine with it, but since it also affects the nested-interactive rule we should hold off.

@dan-tripp
Copy link
Contributor Author

@straker Many thanks for your comments. I'll look into that new issue (#3163).

@straker
Copy link
Contributor

straker commented Nov 4, 2021

@dan-tripp I believe this pr is replaced by #3194, since we don't want tabindex=-1 to pass but now warn of the problem.

Copy link
Contributor

@straker straker left a comment

Choose a reason for hiding this comment

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

Alright. Discussed with @WilcoFiers after thoroughly testing things. Testing both role="text and interactive roles (.e.g role="button"), we've determined that a tabindex can be allowed under certain conditions. Basically if the element with the tabindex is not a widget role, then tabindex on the element is fine. Otherwise we should still flag it as we do now.

So something like this:

// no-focusable-content-evaluate.js
import { getRole, getRoleType } from '../../commons/aria';

function getFocusableDescendants(vNode) {
  if (!vNode.children) {
    if (vNode.props.nodeType === 1) {
      throw new Error('Cannot determine children');
    }

    return [];
  }

  const retVal = [];
  vNode.children.forEach(child => {
    const role = getRole(child);

    if(getRoleType(role) === 'widget' && isFocusable(child)) {
      retVal.push(child);
    } else {
      retVal.push(...getFocusableDescendants(child));
    }
  });
  return retVal;
}

@dan-tripp
Copy link
Contributor Author

dan-tripp commented Nov 28, 2021

My latest commits on this PR are ready for review. Let me know what you think. And thank you for your patience.

Copy link
Contributor

@WilcoFiers WilcoFiers left a comment

Choose a reason for hiding this comment

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

Close, couple more minor things

lib/checks/keyboard/no-focusable-content-evaluate.js Outdated Show resolved Hide resolved
test/checks/keyboard/no-focusable-content.js Show resolved Hide resolved
test/checks/keyboard/no-focusable-content.js Outdated Show resolved Hide resolved
@WilcoFiers WilcoFiers changed the title fix(rule): allow "tabindex=-1" for rules "aria-text" and "nested-interactive" fix(nested-interactive/aria-text): allow "tabindex=-1" on elements with no role Dec 1, 2021
@dan-tripp
Copy link
Contributor Author

Okay, I think this PR is ready for review again. Thank you for all your suggested changes, @WilcoFiers - I think that I'm getting the hang of this.

Copy link
Contributor

@WilcoFiers WilcoFiers left a comment

Choose a reason for hiding this comment

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

Reviewed for security

@WilcoFiers WilcoFiers requested a review from straker December 6, 2021 16:56
@WilcoFiers
Copy link
Contributor

@dan-tripp Thank you so much for this contribution! Great work, really appreciate it.

@WilcoFiers WilcoFiers merged commit 0ddc00b into dequelabs:develop Dec 6, 2021
@dan-tripp
Copy link
Contributor Author

Great! Glad I can help.

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

Successfully merging this pull request may close these issues.

4 participants