-
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
Try/plugin header toolbar #17198
Try/plugin header toolbar #17198
Conversation
Hi @ryanwelcher. Thanks for taking this on. What would be really useful for this PR and the associated issue is an explanation of what it would be used for. Screenshots or designs would also be great. I can think of a couple of issues.
This would also require some documentation. |
Some things to consider:
I guess this works this way to fit all items in the header. @jasmussen and @mtias should know more. While it seems like a great idea to give the freedom to add your own items to the header, it might be difficult to ensure it is visible on smaller screens. Another challenge here is that we wouldn't allow every possible item to be added to the toolbar to ensure everything is accessible like in this example: So this would need to be something which handles keyboard interactions. The example implementation in Reakit: |
@talldan @gziolo thank you for your insights on this! I think we have two areas to consider here:
Personally, I like the idea of using SlotFill here as it provides a pretty simple solution to extending the HeaderToolbar from anywhere in the editor. The larger issue is whether this needs to be exposed for use by plugin developers. In theory, I would say yes but it looks there are many combinations that need to be taken into account - especially around screen size and accessibility. If we're going to expose a SlotFill here, we'll need to either provide all of the props a component may need to render ( Perhaps, the PR can be changed to use the SlotFill but not expose it until we have a better solution? As GB matures and expands to other sections of the WP admin, there are going to be more and more requests for extension points. It would be great to be able to have some ideas for areas like this that we can apply to other areas while building them out. |
As I opened the issue and i'm an unbiased party here, i'd like to weigh in my two cents. Really appreciate you creating a PR on this @ryanwelcher. To understand the hesitations on this, i'm wondering where the line is between what WordPress provides out-of-the-box and where things are opened up for plugin and theme developers. In previous versions of WordPress, it definitely felt like there was an openness around the system and that content developers were encourage to implement their own solutions and it was the developers responsibility to ensure ARIA accessibility and mobile responsiveness etc. In Gutenberg's initial launch, it was pegged as extensible yet in terms of extensibility, the GB editor is actually pretty closed currently. I'm not sure if this is intentional or not, and i'm not complaining. Im trying to understand the strategy here and if there's anyway I can have some meaningful conversations to perhaps provide some more insight from a non-contributing developer. As @ryanwelcher states, if the desire is to refactor other parts of the admin to React, then there's going to have to be far more extensibility options otherwise there's going to be a large majority of developers feeling put out. |
Hey @ryanwelcher and others. It would be great with a status update on this PR. |
@paaljoachim I think the status is that folks are unclear what the Gutenberg team wants on this specific topic. Can you help summarize what's needed as I'd love to see a solution to the problem of the linked issue land in Gutenberg in time for WP 5.5? |
Personally, I feel that it is important that when we open up new slot fills for developers to populate, we think very carefully about the consequences. Gzregorz outlines some of the challenges with making the top toolbar extensible — it's already a crowded area, and we forcefully hide specific known items on mobile for it all to fit. The full site editing experience ponders putting the page title and other options at the top center (#20877), and then there's the top toolbar option. So I imagine the standstill on this one is not for a lack of appreciation of the work done, but rather that there isn't a clear path forward for the UI side, that accounts for all that needs to be accounted for when adding a new button to the toolbar. I do appreciate the need for shops and plugins to tailor and customize the editor for a particular flow, so the addition of slot fills to specific places is fundamentally good. For example, I'm excited for #20929, so that the top left button can be customized in both appearance and behavior. There's the existing sidebar API option, and both the pre-publish experience and the post-publish dialog should be extensible as well. |
I'm less excited about #20929 than you because it basically allows you to replace the W icon button with an indefinity number of fills that can contain anything you want. In contrast to other fills, the one you mentioned doesn't guide you towards the implementation that ensures a consistent experience for those who use the block editor. Just to give an example, while in the toolbar that is the point of this whole discussions, we have only toolbar items which ensure that they look similar and have the same behavior or semantics for accessibility purposes - arrow key navigation between them, one tab to move focus outside the toolbar, one shift+tab to move focus back to the last active item. The interesting conclusion is that you can prepend any number of fills in the Gutenberg plugin just before the block toolbar as of today, but technically they won't be part of the toolbar experience. |
a877b4d
to
3362a00
Compare
@gziolo I'd love any feedback you may have on this PR. As a side note, with this new approach, the slot might be better named something along the lines of |
Note that I left a comment in the linked issue to try and move the discussion on approach out of the PR and into the issue so that we can agree on approach there and worry about fine-tuning a solution in the PR. |
@jeffpaul – let's discuss in the parent issue as you suggested, I will copy comment from @ryanwelcher and respond there. |
Just to address the issue of "it's already a crowded area, and we forcefully hide specific known items on mobile for it all to fit": Many plugins are already using this area without a slot fill via various hacky methods. See Extendify and Google AMP as examples (more info: #16988 (comment)). Better that we provide a slot fill which gives the user a settings for which controls to show in this area. |
Now that the Editor is far more stabilized than it was back in 2019 when this PR was first created, I think it would be a good time to revisit this PR. As the last commenter notes, plugin authors have already been using very hacky methods to add buttons to this section of the UI. Having a formal way of doing this, with proper guardrails, would be a huge benefit to the project while providing the extensibility that the extender community is clearly looking for. |
@ryanwelcher, do you think this PR is actionable with so many changes in the Editor in these years? |
I'll update the PR and take a look @priethor. I still there is a need here. |
Closing in favor of #52261 |
Description
This PR implements SlotFill to render the
<BlockControls />
and additionally exposes a newPluginHeaderToolbar
SlotFill. This PR addresses #16988.How has this been tested?
npm run test
ran locally.Screenshots
Types of changes
This PR introduces a change in how the BlockControls are added and should have no other impact. As we are adding the BlockControls immediately after exposing the Slot, any new items added would appear after them.
Checklist: