-
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
Improve Navigation block color controls #44712
Comments
@aaronrobertshaw As you've been working on Block Supports a lot I wonder if you'd have any insight here particularly around whether we can pass color values set via block supports down to child blocks via block context? You'll note that the Nav block currently passes the color values down to the various child blocks which allows them to use the colors set on the parent. Would you recommend continuing with this approach or instead should we rely on the CSS cascade to propagate the colors? |
Thanks for the ping @getdave 👍
If I understand the question correctly, we should be able to pass block support set colors down via block context. The values set via the color block supports get saved into normal block attributes. So I'd imagine that it would be a matter of updating the block context configuration to match those and handle any block deprecation requirements. Named colors are generally saved in top-level block attributes e.g.
The Social Links block and its inner Social Link children, use block context as well to allow uniform application of colors from the parent block.
As you note, relying on the CSS cascade might get us into a little trouble. If we can avoid that, I would. Going back to the Social Links block example, in an earlier iteration, it employed CSS custom properties to both avoid using block context and have more explicit control over the application of colors. This was changed to the current block context approach due to some concerns at the time around setting CSS vars within inline styles. From memory, there might have been some issues with KSES in certain environments (e.g. core) stripping those styles out. I believe that has changed since though. If you find it has, leveraging CSS vars here might be a nice clean option.
The Navigation block uses the In this regard, the main differences I see here in the Navigation block's controls are;
My point here is I might be missing how these controls will miss any future enhancements.
I've commented on that draft PR as all these color-related controls can in fact be rendered within the same panel. The color block support controls are rendered via SlotFill into their "Color" panel. This can be achieved for the Nav block's controls by wrapping them in an 🤞 That helps and I haven't gone off the rails too far in my reply. Let me know if I can clarify or help out any further. |
I'm actually currently working on moving the navigation block's color controls under the color block support panel. This will act as a small first step to addressing this issue. It has been driven by the experiment introducing tabs to the block inspector sidebar. Without moving these controls they'll appear under the settings tab instead of the styles tab. Once I have a draft PR up for this, I'll drop a link to it here. |
PR moving the color controls into the block support panel can be found here: #46049 |
What problem does this address?
Currently the Navigation block implements custom controls for all aspects of color including:
However these are used in a non-standard way which causes confusion and holds the potential for bugs.
The key problems are:
color: inherit
). However this is vulnerable to being overriden byLink
styles coming from ancestor blocks using global styles.What is your proposed solution?
As the block has been around for some time, these problems are not trivial to solve. Some suggestions include:
Text
andBackground
.Text
,Background
andLink
via Block Supports. This will involve separating the Submenu and Overlay menu color controls from the other controls.The text was updated successfully, but these errors were encountered: