-
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
Fix: Popover positions on the widget screen #15949
Conversation
Ok, I think I found the reason for this breakage when you try to use this in the layout :) I think there's a conceptual issue somewhere here. It looks like Alternatively, we could decide to have a This also confirms my assumptions that having a global I wonder also if there's a way to remove the need of For now, the actionable items could be: 1- Maybe we should deprecate the fallback or fix it. cc @aduth as you know more about Slot/Fill |
For what it's worth, this is proposed in the draft pull request #14715, and was a necessary change for the work there in rendering Slots across distinct block editors: I was planning to refresh and extract some of this pull request into separate smaller tasks, in case this could be one of them. |
Thank you @aduth, that would be very helpful. I guess the best action item now is to just land that extraction. |
See #15988 |
6d6e8c7
to
bf38a0d
Compare
This PR was updated taking advantage of #15988. Now it is a very minor change and should be ready to merge. |
Description
This PR adds the Popover slot to the widget screen inside BlockEditorProvider as we do in the playground.
This allows the Popovers to appear in the correct position.
I'm not very convinced of this change. We are adding a Popover slot per BlockEditorProvider is it ok to do that and have the same slot multiple times on a page? I guess we will need something similar for slots like the block toolbar.
I tried another approach besides this one: Adding the PopOver slot in the layout of the widget screen as we do for edit-post. That did not work as the slot was not found. I think that the slot was not found because is only used inside the block editor. So the Slot usage is outside of SlotFillProvider descendants. In edit post that also seems to be the case, so why things work as expected there?
I also tried removing SlotFillProvider from the block editor and using it in the widget screen layout level with PopOver.slot as a direct child. That also fixed the popover position problem, but when I selected a paragraph from another widget area the paragraph that was previously selected gets double formatting controls. To test this we need to cherry pick #15948.
How has this been tested?
I went to the widget screen.
I added a paragraph, I opened block settings, I verified the popover with the menu appears on the right position.