-
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
Supporting future block types in the navigation editor. #30006
Comments
I've been exploring some of these options:
This still seems feasible and relatively easy to implement.
I had a look at this idea, but I feel it will end up being a little bit of a stretch for block transforms.
This is also feasible, it generally places the onus on the block to provide backwards compatibility by maintaining a mode where only a few block types are supported. |
I shared some concerns in #30430 (comment) about adding yet another nesting level to the navigation editing experience. Keeping in mind blocks and nesting do not have to match HTML, how much of this stuff can we do server-side just for the rendered output? CC: @youknowriad as I recall you have looked at serverside tweaks lately. |
I tinkered a bit in #23745 (comment), and found that allowing the Paragraph block inside dropdowns would be an excellent win, and that there might be a way for us to avoid additional wrapping containers (such as rendering the links list serverside only on the frontend, and avoiding a columns block for mega menus by showing a slider, a la the gallery). |
In my head:
To the point of this issue, the easiest way forward I can think of is to only allow link as child of navigation and always map to that. The structural updates that change how the link block is available - say, only inside a links list block - should be something that is worth updating the navigation screen for once. For the addition of a submenu block nothing will change in the navigation editor as we discard this option, unless the theme opts in case in which we use the full block without any configuration. A navigation block that only allows link and link list as inner blocks + required parent (adding a link automatically adds a link list) = a classic menu block :) |
How about if it becomes the only way to create a submenu? That seems to be what the issue proposes. |
When backed by a
This is possible, but we'd need to be careful to make sure folks adding new functionality get tests ❌ to understand how all this behavior fits together. It potentially might be a lot of work. Do folks know if we've outlined some basic user stories for how people will interact with building navigation menus? I'm finding it a little difficult to reason about some of the tradeoffs without this. For example we have:
|
Updated commentHaving reviewed the way the Nav Editor works some of my original comment is incorrect. I have updated the Nav Editor documentation to account for this. Essentially it's already possible for block types other than See the README for full technical information on this process. Original comment - some info may be incorrect
This will only ever be the case in the Navigation Editor screen right?
This seems completely reasonable. If the Navigation Editor screen is designed to be a replacement for the existing Menus screen (just with the addition of a Block based UI) then there will be no expectations that additional block types (eg: social...etc) should be able to be inserted. Trying to support these blocks and mapping to `nav_menu_item's feels like an unwinnable task. Only allowing link blocks to be inserted in the Navigation editor screen may act as a great way to prompt folks towards using a fully block based Theme.
Let's say we have a Menu created using the existing Menus screen. There's no way to know what block types this should map to other than the standard For example, when parsing As a result, any attempt to serialize (on save) more complex block types such as |
I created #33278 to suggest an expansion of allowed blocks in the navigation block, which seems relevant to this conversation. |
Closing this issue due to the Navigation Screen project being moved to an inactive status on the feature projects page in coordination with the project leads. (The developer documentation in the initial post are no longer accessible) If this work is picked back up, issues can be revisited and reopened as needed. Thanks for pitching in on this early feature so the wider WordPress project could benefit from the lessons learned! |
What problem does this address?
At the moment the Navigation editor is designed to work with a very specific structure of the Navigation Block.
The expected structure is a navigation block with mostly nested Navigation Link blocks. When saving in the editor, those links are mapped directly to
nav_menu_item
post types—the same storage format used by the existing menu editor in WordPress. For backwards compatibility these menu items are rendered using the same walker system as present. Which ensures theme styles still work even with the new block editor interface.It does support other block types when a theme opts in to this feature—Search, Social Links are a couple. These blocks are saved as html in a custom type of
nav_menu_item
.But there are proposals to change the structure of the navigation block significantly. The potential future blocks that are relevant are:
These blocks are more challenging because they contain Navigation Link blocks. Some ad-hoc code would need to be written to be able to convert these blocks back and forth from
nav_menu_item
s.What is the goal
To make the navigation editor less susceptible to bugs that can occur from changes to blocks, while at the same time providing the navigation block with some scope for iteration.
What is your proposed solution?
My first thought is that we could drop the use of the navigation block in the editor, and build a separate classic menu block for the editor when a theme hasn't opted in. This would make it much easier to manage backwards compatibility.
A second option could be to consider using the transform system for converting from/to menu items, which could allow blocks to define declaratively how they should be converted from block data to menu items. It would be a way to transition from a system that's largely hard-coded and limited to one that's more dynamic, and could support a few different block types (possibly even third-party block types). But I don't think it'd be completely straightforward, the data structures are quite different!
And a third option could lie in the block itself, potentially in a basic mode of the block where it only supports links.
The text was updated successfully, but these errors were encountered: