-
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
Navigation: Consider a different markup structure for submenus. #39392
Comments
I hope this proposal may also open up the possibility of using the submenu container for colors, instead of placing these styling classes (has-background etc.) on the links inside it. |
Currently the Submenu block contains its parent element, because that element is not always a link. Depending on the "open on click" and "show arrow" settings, it may display a button, a link or a link with a button. This is the main reason we're not using the Nav Link block for the parent; you can find more context in #33775.
If I understand correctly, the proposal is making the Submenu an inner block of a Nav Link block. That's not straightforward because, as mentioned above, the parent isn't always a Link. We'd have to either introduce some very hacky logic in the Link block to treat it as a button depending on whether it has children, or we'd need another Link-or-Button-depending type of block, which also doesn't feel ideal. In terms of styling, we may also want to target the parent element, which will be harder to do if it's not part of the submenu.
Current default targetting of the block wrapper for styles (whether they come from the editor or theme.json) doesn't work for all cases; we had similar problems with the Navigation block itself when implementing layout on it - see #37473. Table is another challenging block in this respect - see #30791. This is a problem that won't always be possible to solve by fiddling with the block markup; we need to have a way to target its inner elements. Part of the Style Engine work will be looking at ways of doing this (#38167) - contributions to those discussions very welcome! 🙂 |
You're proposing that we use something like |
If it's likely that themes will only want to style the items within the |
I understand this is why removing a submenu block, also removes the parent link. Which is intuitively unexpected behavior. Or is that another issue? |
That is the expected behaviour, yes. If you wish to remove the dropdown while preserving the parent link, you can remove the submenu items, and transform the submenu into a link. As I mentioned above, there's an open on click setting on the Navigation block whereby submenu top-level items become buttons. In that context, it doesn't make sense to preserve them once the submenu is removed. |
I understand why it works like this. Yet, from a user psychology perspective it is not intuitive because: Here it says "add submenu". Which implies a menu is added to a link (but it actually is a transform). A user would expect that when removing the submenu, the same revert action applies (the submenu is removed, but actually transformed to a link). But it does not. It simply removes. You have to have prerequisite knowledge about the transform but a new users doesn't 'intuitively know' we transformed in the first step so we assume we don't have to. See how this simple signalling of "add" instead of "transform" can be confusing for someone who has never used the menu? |
Good point! Let's change the copy to say "Transform to submenu". |
At the moment nested navigation items generate markup like this:
This structure outputs markup like this:
Now if I want to target the dropdown portions of the navigation block using theme.json I might define something like this:
This will generate CSS like this:
This problem is this CSS targets the navigation item above the drop down as well as the items within it, which is unexpected, and makes it impossible to target just the dropdown on its own.
To overcome this I am proposing we use this structure for the navigation:
Which would output markup like this:
This allows us to effectively target dropdown using theme.json.
Does this create other problems? Are there other ways to solve this?
Originally noticed in #39277
The text was updated successfully, but these errors were encountered: