-
Notifications
You must be signed in to change notification settings - Fork 4.2k
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
Provide ways to extend/customize the Global Styles sidebar #48068
Comments
cc @mtias |
Same thing here, I would like to be able to extend the global styles panel (e.g. by adding the font-family) but I have not found any way to do this. |
There are multiple points of extensibility to consider here. New "navigator" items should probably use a registration based API, while pieces outside the navigator could use some UI slots if we make them semantic enough. cc @gziolo @oandregal Extending individual design features seems more granular. |
Thanks for providing specific examples of things to be extended/customized. That helps a lot in providing feedback.
Would the existing filters help with this? They can be used to provide specific color palette per block type. There's a new one landing in 6.2 to be able to filter per block instance https://make.wordpress.org/core/2023/02/28/custom-settings-wordpress-6-2/ The case for showing some tooltips is an interesting one. I don't know that we allow that in the post editor. cc @jorgefilipecosta as he has worked quite a bit on extending UIs.
Can we do this with the existing filters provided by the REST API? Perhaps
There's work to add this feature. I'm not sure how active it is or whether other people could pick it up #46667 In general, my understanding so far is that the UI reflects APIs registered elsewhere (block supports from the block API, theme.json API, etc.). The UI is still a moving target (see #49014 where it's being moved to the black shell sidebar, to the left), so I don't know how stable can we make those UI slots, if any is required. |
As far as I know we don't have any API to provide additional tooltips. |
They can definitely help with the specific example of ensuring that some style guidelines are respected. But the purpose of the example was to provide additional context about why some developers might want to modify the sidebar UI to inject additional content that could be helpful for users editing global styles, and that cannot be done with existing filters. I understand though how making the UI extensible makes harder to iterate on it because it needs to maintain backwards compatibility. |
Ok, since there's still uncertainties about the use cases and semantics and I think for the sake of moving forward here, we can start by adding a slot in the Gutenberg plugin, protect it using the isGutenbergPlugin check, request feedback from plugins developers. Once we reach the "core merge" window, we can make a more informed call about whether we're confident enough to include these slots on core or not. |
What problem does this address?
Gutenberg does not provide any way to extend/customize the Global Styles sidebar for things like:
Plugins developers interested in such extensions are forced to manipulate the DOM (e.g. injecting custom React components inside an element located with a CSS selector). But this is very fragile, since Gutenberg can change the DOM without further notice, breaking these extensions.
What is your proposed solution?
Add standard extension points to the Global Styles sidebar such as SlotFills, hooks, or a programmatic API, so plugin developers can customize it with a more robust mechanism.
Seems that the editor sidebar is currently extensible via SlotFills (#13357), so I guess the Global Styles sidebar can follow the same approach.
The text was updated successfully, but these errors were encountered: