-
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
Editor: Make sure resetEditorBlocks
is synchronous.
#21839
Conversation
Size Change: +47 B (0%) Total Size: 845 kB
ℹ️ View Unchanged
|
Since it took me a while to figure out the testing instructions:
|
Do we want a new public API member † I believe this example isn't done this way on purpose, merely that it was implemented before the package was generalized. |
Do we risk any inaccurate value from |
Not sure if this was introduced here or in #21804, or if it's always been an issue, but I see a lot of duplicate toolbar and inspector controls for a freshly-inserted Template Part block. Plus, when trying to interact with the block, it locks up my editor. It doesn't seem to be an issue when saving and reloading. Edit: Testing it further, it might only be an issue when inserting a Template Part block when there are already Template Part blocks in the post for the same template part. In my case, I effectively had three of the same template part. |
On the topic, while I don't think it's inaccurate to name it as such, the specific use of "sync" leads me to think of it differently, in-fact more like how it actually behaves today. When I see the name, I consider it like Node's |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd probably prefer to hide syncSelect
from the public API in its current form, but otherwise it appears to fix the issue in my testing.
Separately, we should consider some automated testing coverage for this behavior, especially since it's fixing a regression.
No, it should be fine.
Yes, this is because they are the same template parts, so they share block instances/IDs. We need to fix this.
What would you call it?
Agreed, I'll make it unstable for now. But, we need to arrive at a long-term solution because this will also be a problem for third parties.
Yes, I want to start with e2e tests for template parts, which should indirectly test a lot of the new behaviors. |
I guess it doesn't really matter much if it's going to be internal / unstable. I don't really have great name alternatives in mind, maybe something reflecting the "immediacy" or "current state" aspects of the behavior. I also kinda wished it would be an option of the existing |
Yeah, but unless I'm mistaken, we don't want anything like this to be the end solution, which also makes it a perfect use-case for |
Yeah, I reached for that first as well.
Exactly, that's what I was referring too. |
Fixes #21804
Description
#21467 introduced a resolver for
getEditedEntityRecord
which maderesetEditorBlocks
asynchronous. This sometimes makes previous calls finish executing after newer ones, essentially undoing the editor to a stale block tree.I added comments to the relevant code to explain:
This PR fixes the issue by using a synchronous select data control like we used to have before.
But, I think that this problem could surface elsewhere, so the long-term solution should be more general. We should think about canceling stale action execution. That also raises the questions of how to define and continue with any cleanup operations, though.
How to test this?
Verify that #21804 is no longer an issue; that you can insert existing template parts on the full site editing experiment as expected.
Types of Changes
Bug Fix:
resetEditorBlocks
will now execute sequentially, avoiding an issue where older executions would overwrite newer ones.New Feature:
@wordpress/data-controls
now has a synchronous version ofselect
,syncSelect
, which does not wait for resolvers.Checklist: