-
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
[WP 6.7] Scrollable blocks affect the position of the block toolbar #66112
Comments
From #62711 (comment)
Thanks for the great testing instructions @t-hamano From what I can gather it's this while loop that gets the rect bounds of the child, including the I think @kevin940726 might have been right in this comment - we might need a better way to calculate overflow and also optimize the loop. I did a quick test of the following, and seems to fix it, but it's probably not a holistic solution: diff --git a/packages/block-editor/src/utils/dom.js b/packages/block-editor/src/utils/dom.js
index 9c2e813ef74..48157f6af2a 100644
--- a/packages/block-editor/src/utils/dom.js
+++ b/packages/block-editor/src/utils/dom.js
@@ -149,6 +149,12 @@ export function getVisibleElementBounds( element ) {
for ( const child of currentElement.children ) {
if ( isElementVisible( child ) ) {
const childBounds = child.getBoundingClientRect();
+ if ( childBounds.width > bounds.width ) {
+ childBounds.x = bounds.x;
+ }
+ if ( childBounds.height > bounds.height ) {
+ childBounds.y = bounds.y;
+ }
bounds = rectUnion( bounds, childBounds );
stack.push( child );
}
@@ -171,6 +177,6 @@ export function getVisibleElementBounds( element ) {
right - left,
bounds.height
);
-
+console.log( { bounds } );
return bounds;
} |
+1 great issue description @t-hamano, and good catch looking into overriding 2024-10-16.12.44.44.mp4If we set 2024-10-16.12.45.53.mp4Here's what I'm using locally (the same as Ramon's snippet, but with one line added): diff --git a/packages/block-editor/src/utils/dom.js b/packages/block-editor/src/utils/dom.js
index 9c2e813ef74..005472df6af 100644
--- a/packages/block-editor/src/utils/dom.js
+++ b/packages/block-editor/src/utils/dom.js
@@ -145,14 +145,21 @@ export function getVisibleElementBounds( element ) {
const stack = [ element ];
let currentElement;
while ( ( currentElement = stack.pop() ) ) {
for ( const child of currentElement.children ) {
if ( isElementVisible( child ) ) {
const childBounds = child.getBoundingClientRect();
+ if ( childBounds.width > bounds.width ) {
+ childBounds.x = bounds.x;
+ }
+ if ( childBounds.height > bounds.height ) {
+ childBounds.y = bounds.y;
+ childBounds.height = bounds.height;
+ }
bounds = rectUnion( bounds, childBounds );
stack.push( child );
}
}
}
/*
@@ -167,10 +174,10 @@ export function getVisibleElementBounds( element ) {
const right = Math.min( bounds.right, viewport.innerWidth );
bounds = new window.DOMRectReadOnly(
left,
bounds.top,
right - left,
bounds.height
);
-
+console.log( { bounds } );
return bounds;
} |
My comment in https://github.com/WordPress/gutenberg/pull/62711/files#r1727161279 mostly focused on the potential performance rather than correctness. I think it's a good opportunity though to also try out different options if possible. I was mostly concerned that traversing through every child might be slow for large blocks but that's not proven yet. Feel free to take it for a spin if you're feeling adventurous! |
Nice collaboration all around here 👍 So I didn't miss out on the party entirely, I took the latest snippet for a spin as well.
While I'm not sure I have the full history behind this code, the suggested fix does work well in my testing as well. At least following the test instructions on the old PR (#62711) and on this issue. Blocks with child elements outside the normal block bounds like a navigation's submenu still have the block toolbar appear below the submenu: The scrollable blocks detailed in this issue appear to have their toolbar behave correctly as Andrew noted in his reply above. Screen.Recording.2024-10-16.at.4.17.09.pm.mp4I think I'm missing the edge cases that the proposal is supposed to not work for. I couldn't find them. |
Thanks for confirming that approach, folks. I threw the above snippet into a PR #66188 to test. Seems to be okay 🤔 but yeah, haven't tested it many scenarios. |
Description
If elements within a block are vertically or horizontally scrollable, scrolling will also affect the position of the block toolbar.
This appears to be an issue that first appeared in WordPress 6.7.
There are no scrollable blocks in the core, but it may affect third-party blocks.
Step-by-step reproduction instructions
Run the following code in your browser console to register a horizontally scrollable block and a vertically scrollable block:
Screenshots, screen recording, code snippet
WordPress 6.7 or the latest Gutenberg
trunk.mp4
WordPress 6.6.2
This issue does not occur.
6.6.2.mp4
Environment info
No response
Please confirm that you have searched existing issues in the repo.
Please confirm that you have tested with all plugins deactivated except Gutenberg.
The text was updated successfully, but these errors were encountered: