-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Group: Make nav element selectable and add UI for ariaLabel #68611
base: trunk
Are you sure you want to change the base?
Conversation
Size Change: +111 B (+0.01%) Total Size: 1.84 MB
ℹ️ View Unchanged
|
The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.
To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook. |
{ tagName === 'nav' && ( | ||
<TextControl | ||
label={ __( 'Navigation label' ) } | ||
value={ ariaLabel || '' } | ||
__next40pxDefaultSize | ||
__nextHasNoMarginBottom | ||
onChange={ ( value ) => { | ||
setAttributes( { ariaLabel: value } ); | ||
} } | ||
help={ __( | ||
'Add a label to describe the purpose of this navigation element.' | ||
) } | ||
/> | ||
) } |
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 wonder if it's just time to add a full standardized UI for the aria label block support 🤔
In reality users can already set this attribute in code today. It just doesn't have a UI... I'm not sure only showing it for the nav
tag name makes it more clear 🤔
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 wonder if it's just time to add a full standardized UI for the aria label block support
That's certainly true, and maybe we should do so in the future.
Personally, I'm cautious about changing the block support spec right now. For now, I prefer to expose the UI only to the Group block. I'd like to hear other people's opinions on this.
onChange={ ( value ) => { | ||
setAttributes( { | ||
tagName: value, | ||
ariaLabel: value === 'nav' ? ariaLabel : undefined, |
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 is going to override already existing aria labels when the tag name is changed to and from nav
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 should work like this:
- When changed TO a
nav
element: existing aria-Label is maintained - When changed FROM a
nav
element: aria-Label is removed
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.
Is this expected though? I am torn, it would be good to have some user testing.
If I have a group block and I use the transform, either to another block like the details or to a row or stack, the label is kept.
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.
If the UI was always available, I don't think the removal would be expected.
Without the UI, it is more difficult to discover both that the label is removed, or that it is kept.
This comment was marked as resolved.
This comment was marked as resolved.
@t-hamano thanks for working on this ❤️
We could consider to add a 'Learn more' link pointing to the W3C example. On a side note, I'd consider to add the same help text to the Navigation block: |
Question: should the input field be labeled 'Navigation label' or 'Menu name' like in the Navigation block? I'd think these two input field should have the same label and description. However, 'Menu name' (though more user friendly) doesn't really clarify that the name is used also for the aria-label. |
Note: in #68708 I'm proposing to move all the help messages for the HTML element setting to a centralized place in the block-library utils. |
I don’t have a strong opinion on this, but I prefer to use “Navigation label”. The term “Menu name” is also used in classic navigation, so it might be better to include the word “label” here to avoid confusion with that.
I think this is something we'll need to consider separately from this PR. This issue needs to be considered separately from this PR. Even now, various information may be displayed in the list view. From the perspective of accessibility, I think it is necessary to seek a comprehensive solution. Related issue: #59409 |
setAttributes( { ariaLabel: value } ); | ||
} } | ||
help={ __( | ||
'Add a label to describe the purpose of this navigation element.' |
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'd like to provide a better help text to educate users about the recommended best practices and communicate the concept that If a page includes more than one navigation, each should have a unique label.
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.
Updated by 79d6d8f
Of the two suggestions "Menu label" and "Navigation label" I prefer the navigation label, because I don't want it to be confused with the type of menu that you insert inside a navigation block. What about "Aria label" ? |
@im3dabasia is updating the tag cloud and the categories blocks to use the |
Fixes #67407
What?
This PR makes it possible to operate the following two things from the Advanced panel in the Group block:
nav
element as an HTML element (tagName
attribute)ariaLabel
attribute)Why?
These two are already available as internal attributes. However, the only way to change them is to edit the HTML directly. (See TT5's example).
To help users create more accessible content, I propose adding a UI for these attributes to the Advanced panel.
How?
When an element other than a nav element is selected, the navigation label is removed. This is to prevent HTML like the one below from being saved:
This does not mean that the
aria-label
attribute cannot be used on elements other than thenav
element, but for now I will limit it to thenav
element.Additionally, we need some good help text to prevent users from misusing this UI. I also welcome your feedback on the help text.
Testing Instructions
nav
.aria-label
attribute is added.nav
.aria-label
attribute is NOT added.Screenshot