-
Notifications
You must be signed in to change notification settings - Fork 70
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
[NEW RULES] - Define author's responsibility when presentational roles conflict arises #2195
base: develop
Are you sure you want to change the base?
[NEW RULES] - Define author's responsibility when presentational roles conflict arises #2195
Conversation
allowed child element of another element with presentational role does not cause presentational roles conflicts
elements with ARIA presentational role do not have global states or properties
…a-presentational-role-no-global-states-properties-p8g918.md
_rules/aria-allowed-child-element-with-presentational-parent-1g88p9.md
Outdated
Show resolved
Hide resolved
description: | | ||
This rule checks that allowed child element of another element with presentational role does not cause presentational roles conflicts |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This rule seems like a subset of our ARIA required context role
rule. It requires that elements that can't exist without a parent have that parent. The rule you propose is more focused, but it doesn't seem to cover anything that isn't also covered by the required context
rule. Or at least, I can't find anything that isn't.
Would a better solution be to add the one or both of the failed examples to required context
instead?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see the point.
The intent was to cover a specific ARIA requirement in detail and comprehensively (Presentational Roles Conflict Resolution) to guarantee authors are clear on what to do in these scenarios.
I'm uncertain about the next steps.
The other two existing ARIA requirements are rather more vague but do cover the necessary aspects. If we decide to revert these new rules, we'll still need to add examples to the existing rules.
@@ -0,0 +1,175 @@ | |||
--- |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think you should have more than one new rule in a PR.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I apologize for this. I based my work on this pattern: #2167. These three rules are intended to fulfil the "Presentational Roles Conflict Resolution" topic from an author's perspective.
@@ -0,0 +1,175 @@ | |||
--- | |||
id: p8g918 | |||
name: ARIA presentational role does not have global states or properties |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm very sorry to do this a second time. I can tell you've put a lot of work into these, but this rule also seems like a duplicate to me. This time of Element marked as decorative is not exposed . Your version makes slightly different trade-offs about explicitly stating which props cause this problem, whereas the existing rule is vaguer about that. But then in being vaguer and just saying "not in the accessibility tree" its means it can handle changes to the ARIA spec like how aria-label is not a global attr if on role=none, but still fails for creating presentation conflict.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see the point.
The intent was to cover a specific ARIA requirement in detail and comprehensively (Presentational Roles Conflict Resolution) to guarantee authors are clear on what to do in these scenarios.
I'm uncertain about the next steps.
The other two existing ARIA requirements are rather more vague but do cover the necessary aspects. If we decide to revert these new rules, we'll still need to add examples to the existing rules.
@@ -0,0 +1,139 @@ | |||
--- | |||
id: 18pg11 | |||
name: ARIA presentational role not focusable |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See above, the Element marked as decorative is not exposed rule covers this.
I think we can debate splitting the rule up into the two rules you propose. I'd personally lean towards leaving this as is, since the "not exposed" rule is already approved by AG, but if others feel there are good reasons to deprecate it in favor of this I'm open to that conversation.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see the point.
The intent was to cover a specific ARIA requirement in detail and comprehensively (Presentational Roles Conflict Resolution) to guarantee authors are clear on what to do in these scenarios.
I'm uncertain about the next steps.
The other two existing ARIA requirements are rather more vague but do cover the necessary aspects. If we decide to revert these new rules, we'll still need to add examples to the existing rules.
_rules/aria-allowed-child-element-with-presentational-parent-1g88p9.md
Outdated
Show resolved
Hide resolved
After our conversation with @carlosapaduarte and @dan-tripp-siteimprove during the office hours meeting, I took another look at this item (since it was on me and I forgot about it 🫤). Although there is certainly overlap with Element marked as decorative is not exposed as mentioned by @WilcoFiers, I still see value in this PR. While it doesn't fully cover the same scope as Element marked as decorative is not exposed - the applicability here is limited to elements that trigger the "presentational role conflict resolution", so examples like are not within the scope of my PR - it does get rid of the ambiguous "marked as decorative" definition. Additionally, it covers scenarios not currently within the scope of the test, such as:
In this case, the button element is not marked as decorative by the author, so it falls outside the Element marked as decorative is not exposed rule's applicability, but it is still an author error. and:
In Element marked as decorative is not exposed rule, the Furthermore, while I agree there is repetition, the rule's focus is very clear and well-defined, since it specifically addresses all items that fall under the "presentational role conflict" definition. Is it really a problem if something is duplicated, as long as the scope of the check is clear and unambiguous? |
New Rules:
Closes: #2193
Need for Call for Review:
This will require a 2 weeks Call for Review
Pull Request Etiquette
When creating PR:
develop
branch (left side).After creating PR:
Rule
,Definition
orChore
.When merging a PR:
How to Review And Approve