-
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
Performances: Avoid UI shifting when selecting blocks #47177
Conversation
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.
Hey @corentin-gautier , thank you for working on this one!
I left some technical feedback, but I'll @jasmussen and @youknowriad give more feedback on this one
packages/edit-post/src/style.scss
Outdated
@@ -99,6 +99,10 @@ body.block-editor-page { | |||
|
|||
@include wordpress-admin-schemes(); | |||
|
|||
.interface-interface-skeleton__content { |
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.
Instead of adding this override, could we see if we can rework the original overscroll: auto
prop in the interface
package?
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.
If I'm not mistaken the site editor now uses an iframe, meaning the overflow auto here isn't particularly useful since it's the iframe that now handles the scroll
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.
Which also means we can't set it to scroll (it would result in a double scrollbar)
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.
Got it!
What I'm trying to say is, we couldn't set those styles for .interface-interface-skeleton__content
and .interface-interface-skeleton__header
(at the moment scrollbar-gutten
and overflow
) directly at the source (in the @wordpress/interface
package), instead of overriding them specifically for the @wordpress/edit-post
package.
Thank you for the PR! This particular issue bugs me a ton as well and I really wish there was a better way to handle it. The main problem is the inspector, which shifts so often when opening/closing panels, or selecting different blocks, it can really become quite jumpy. But at the same time, forcing the scrollbar track to be visible always, it provides a somewhat more clunky interface for the default case. Here's the before state, with or without auto-hiding MacOS scrollbars: Here's the after-state with auto-hiding scrollbars: More to the point, here's the after-state with permanently visible scrollbars: While I understand that Windows 11 also defaults to auto-hiding scrollbars, I suspect that for the majority of Windows users on Windows 10, this will be quite a shift. Mainly what bugs me about this is that it makes the icons no longer align: if you visually track a vertical line from the top toolbar ellipsis icon and downwards, things don't line up. While it does come down to choosing a tradeoff, I wonder if there are some more modern scrollbar CSS properties we can explore first, in a progressive-enhancing way. For example, there's a scrollbar-gutter property here that could be interesting. If we combine that with a
The site editor is additionall exploring a scrollbar behavior that's codepenned out here: https://codepen.io/joen/pen/rNKRWdx?editors=1100 — I wonder if there's something we could leverage just for the inspector. What do you think? |
@jasmussen Here's an exemple with :
This would only happen when the user explicitly chooses to always show the scrollbars Screen.Recording.2023-01-27.at.14.06.33.mov |
0ab7645
to
20b372c
Compare
Thanks for your responsiveness and demo videos, very helpful in reviewing 🙏 To be clear: some of this we've been through in the past and ended up back on what's shipping in trunk. So wherever we go, it would be good to boost the confidence. CC: @WordPress/gutenberg-design Personally it does bug me that there's a jump when I have scrollbars showing always. But to be clear, this bugs me only in the inspector, not in the editing canvas. So I think to keep things focused, we should probably not touch the editor canvas at this point and focus only on the inspector, and that's where I think the scrollbar gutter could be interesting. |
I think it would be nice to eliminate the jump, and this seems like a low-risk tweak that is easy to revert. 👍 from me! |
I too would like to test this out! I agree with James. |
ac23b3e
to
4f67e47
Compare
This PR only changes the behaviour of the post editor 👍 |
4f67e47
to
4d67ca7
Compare
Just to be sure I understand you correctly, this changes the scrollbar behavior both for the editor canvas and the block inspector, in the post editor, correct? If yes, then I'd still split that into two PRs, one PR for just the inspector, one PR for just the editor canvas. The former can land quickly, the latter actually needs a little thought, because it can be argued that the editor canvas should be WYSIWYG, including the behavior of the scrollbar. That is, a particular theme might have a curious scrollbar behavior on the frontend, and this should probably be reflected in the editor as well. An extreme example that comes to mind is an older theme called "Shelf", which scrolled horizontally. |
791ae0a
to
7d7e1c9
Compare
@jasmussen I reverted the change on the editor canvas so this PR only changes the behaviour of the sidebar. Still It would be nice to quickly land the change on the editor canvas since it avoids a lot of browser repaint and it's a very small change |
Thank you! Let's get some reviews on this. @WordPress/gutenberg-design |
Testing. I have been exploring and it seems sometimes the shift occurs and sometimes not. I made sure to make the page very small so that I could see the page scrollbar and the sidebar scrollbar. 1- A shift occurs in the beginning when opening panels and then suddenly the shift stops. In Brave. In Safari. No.shift.in.Safari.mp4What am I missing? Is this problem in Windows but not on the Mac? |
@paaljoachim in the second half of the brave video the sidebar content is high enough to always overflow (you left some panels open), that's why you're not getting a shifting UI anymore (the scrollbar doesn't hide), in the safari video the content is always overflowing because the content it too big so the scrollbar is always needed as well. The problem only appears when you don't have overflow because the sidebar content is too small to trigger overflow and then opening a panel triggers it. |
Thanks for all the energy. I took it for a spin and have a lot of GIFs and screenshots to go through. First off, here's how it looks on a Mac if you have auto hiding scrollbars. This GIF shows both the before and after, because they are the same: One note I realized as I was testing this is that we would probably need the scrollbar code to be present also in the site editor. Currently it's just the default overflow behavior: Then I proceeded to test how this new behavior exists with always visible scrollbars. Here's a screenshot: Note in the above screenshot how in the top right corner, the top toolbar is suddenly vertically scrolling. This appears to be a bug worth looking into. Latest mac/chrome. Here's a GIF showing how the scrollbar-gutter reserves space for the scrollbar, even when there's no content to scroll: It's easiest to see the behavior when you compare with trunk. Here's how it looks today, notice how the scrollbar pushes the inspector leftwards when scrollable content appears: So that's the main review. But as I tested this, I realized that for people who have always visible scrollbars, this extra space that's reserved for the scrollbar will essentially be misaligning the layout, optimizing for long inspectors. Note here how the top toolbar ellipsis menu, and the X icon are misaligned: This isn't ideal for most cases, where we are actively cleaning up and simplifying inspectors to be shorter and simpler. So this opens a few questions:
Alternately, are there other progressively enhancing CSS properties we can use to make sure the inspector doesn't move leftward, but things still line up? It appears that Thanks for all your energy on this one. What do you think? |
@jasmussen Thanks for your feedback as you can see in the video here #47177 (comment) their shouldn't be misaligned icons and the top toolbar shouldn't have a scrollbar, so I'm not sure what's happening (I'm also using chrome on a mac) Here's how it look in my current test env : |
7d7e1c9
to
ade977d
Compare
Took this for another fresh spin. Before, or with auto hiding scrollbars: After, with always visible scrollbars: As you can see, I'm still seeing the scrollbar in the header. This appears to be the responsinble code: If you change that overflow to hidden, it looks right. With scrollbar in the inspector: With no content to scroll, but space still reserved for the scrollbar: The Furthermore, if you use the auto-hiding macos scrollbars, in both places the reserved space collapses and looks as it does today: To me, this threads the needle!
I still think we should eventually look into something like https://codepen.io/joen/pen/rNKRWdx?editors=1100 as a customized scrollbar for compact spaces, but in the mean time, this feels like a good step forward, with minimal downsides. It's also a PR I think @ellatrix will appreciate. So as next steps, can you please apply |
Force the use off overflow scroll on scrollable areas to avoid UI shifting/resizing when getting a scrollbar
ade977d
to
e3a9e63
Compare
@jasmussen done ;) |
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 think we should try this.
Can you add a small CSS comment in context of the new values, to explain what they do? Something like
// The scrollbar-gutter property ensures space is reserved for the scrollbar to appear,
// when scrollbars are set to be always visible.
@jasmussen comment added ;) |
Are you able to press the green button and merge? Or do you need me to do that? |
@jasmussen I do not have that kind of power :) |
Merged for you :) Thank you again @corentin-gautier for your help and patience in tweaking your proposed solution! |
Nice one, thanks @corentin-gautier 🙌 |
Noting that a wp.org plugin added a dropdown menu to the header and since the |
What?
Force the use of overflow scroll on scrollable areas to avoid UI shifting/resizing when getting a scrollbar
Why?
When the content of a scrollable area changes and overflow, the whole page resizes triggering massive repaint of the page
How
Force overflow: scroll on both .interface-interface-skeleton__content and .interface-interface-skeleton__sidebar
Fixes: #45386
Fixes: #23427
Testing Instructions
Before
Screen.Recording.2023-01-16.at.10.35.32.mov
After
Screen.Recording.2023-01-16.at.10.36.13.mov