-
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
Allow tab to be active but not selected #60573
Conversation
If defaultSelectedId is undefined, it will automatically set the first tab as selected.
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. |
@mirka - Here's an attempt at what we discussed in #52997 (comment). I'm not sure about the name of the new prop or if this is the best way to go about it. Curious to hear your and the @WordPress/gutenberg-components team opinions! |
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.
Some new thoughts about our approach
I discussed this with @DaniGuardiola today, and he pointed out that the use case we have in the Patterns inserter is likely a better match with the Menu pattern rather than the Tabs pattern. Imagine a nested menu without the initial "Open menu" button, and that's basically the mechanics we want there. The visual styling is also much closer to a menu than a tabs pattern. The most persuasive point for me is that I don't think I've never seen a tabs UI without a default tab selected.
That said, I know that the original motiviation for you was to fix the keyboard navigation in the Patterns inserter. That can be done with Tabs, you already have a mostly working implementation, and it's not like the semantics are "wrong". So I'd be fine with shipping this Tabs approach as an incremental improvement. We can experiment with a Menu replacement later.
I'm not immediately sure if DropdownMenuV2 in its current state can be used for this use case, but ultimately it should, so this would be a good place to test the flexibility of our new composable components.
Thoughts on this PR
With that in mind, I don't think we'll have many cases of selectedTabId={ null }
, nor do we really want to encourage it. Given the niche use case, I'm thinking we could just keep it simple and make "when activeId
is undefined, fall it back to the first tab id" the baked-in behavior for our Tabs component. Thoughts?
I'm fine with this behavior. Fall it back to set an active id but not select it, right? |
Exactly 👍 |
More context in #52997 (comment)
What?
There is not a way to have the first tab be active (the one receiving focus) but not selected (have its tab pane visible). For the patterns inserter, I needed this behavior: #60257
Why?
Sometimes you don't want any tab pane selected by default. This was possible before, but the focus was set to the wrapping element, not the first tab.
How?
Adds a
selectedOnMount
prop that defaults totrue
to preserve the existing behavior. If you setselectedOnMount
to false, it will set the first tab as the active one (receives focus) but not select it until an enter keypress on that tab.Testing Instructions
Test the patterns inserter in #60257.
Testing Instructions for Keyboard
Screenshots or screencast