-
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 G2: Mover interactions #20056
Try G2: Mover interactions #20056
Conversation
Interaction question! Should the mover show if you move your mouse to the spot where they will appear? Scenario:
I suspect yes. The interaction pattern is similar to improved Dropdown movement paths. P.S. I suspect this will be a bit tricky. Not impossible... but not super easy either, haha. |
Additional thoughts! This is for future, but I think we should support a way to "always show movers". From my initial prototyping, @diegohaz left a great bit of feedback re: mouse movements being tricky for some folks (from an a11y perspective) |
It'd be interesting to try showing it not when hovering the toolbar in general, but when hovering the block type button instead.
Yes, let's try it. We used to have a "left area" of the block that would trigger showing the movers. It was slightly convoluted if I remember correctly.
If the version that only shows it when hovering the block type works, then this wouldn't be a concern since interacting with the rest of thee toolbar would minimize it. |
Thank you for working on this! This feels like a promising effort to find the balance between showing the movers when you need them, yet not weighing down the interface when you don't. I would echo Matías comment about just hovring the block indicator. One more thing: can you work in the -48px offset so that the little triangle pointer now points correctly to the top left corner of the block footprint? Like so: The tricky bit here is that it needs to still work on fullwide blocks, i.e. the positioning magic that happens to the detached toolbar needs to work. Speaking of, the movers are cropped off there now: So the "reserving of space" needs to be a little stronger there. |
Putting the mover so far away from the block makes drag-and-drop feel weirder, because where you drag your mouse isn't where you're going to drop the block. |
I think that's a fair point, but one that touches on drag and drop beyond just where the handle is. Or to put it differently, the issue is the same as what's shipping in master, just slightly exacerbated due to the longer distance. I know various tickets have outlined grand dreams for a drag and drop refactor that makes drag and drop actually real time, and I see no reason those couldn't address that. More specifically, drag and drop right now isnt' very good... the block that's being moved is a semitransparent clone and it gets muddy — it might be interesting to actually pull the block out of the flow and puts it under the cursor. |
Thanks for feedback all! I'm gonna fix the conflicts between this and |
79b0327
to
82f6d5a
Compare
@mtias + @jasmussen 👋 Haiii!! I just pushed an update!
Here's a video demo: Considerations:
@jasmussen Yes, we'll need to apply some positioning magic there :). (Ignoring code implementation) If there's a mock for these various stages, that would be great~!! Update: Just noticed... that the Mover needs to be visible always if any of the Up/Down arrows are focused. I think outlining various scenarios when/how the mover shows/hides would be handy! It looks like there's several moving parts (🙃 ) |
Nice work! This is coming along. This is what I see. As far as I'm concerned, the mouse behavior is now solid, nice work!
Yes. Totally fine for them to be present when anything in the toolbar has focus.
Like so: The space on the left is reserved for the mover popping out. You may want to pair with @ellatrix if she has time, she's done some of the "undocking" of the toolbar which currently aligns it towards the left of the screen. But I imagine there might also be a simpler CSS trick for it. Imagine the collapsed toolbar is 100px wide, and offset -48px to the left on most blocks. If this toolbar was actually 148px wide, with the leftmost part just being an invisible slot available for the movers to slot into. The idea being that if the space is permanently reserved, then the JS positioning would be simpler — zero pixels when fullwide, -96px when there's space for the offset, and so on. Makes sense?
For this particular heuristic I'm imagining the following:
The only challenge here is the "resting focus" effect where maybe you selected some text, clicked "Bold", and now the bold button has focus and therefore has focus. Effectively this could result in the mover popping in, in a jarring fashion, just because you click bold. It might be even more jarring if you click a dropdown menu item, which briefly receives focus before focus moves into the popover, causing the mover control to pop in and then out. Two ways we can handle that: The mover control appearing when pressing "Bold" is either a non-issue, (which I think it is), and we'll want to make sure that even focus inside a popover keeps the mover control visible. Or it's an issue, in which case we could consider making it so the mover control pops out only when the block indicator is hovered, focused, or toggled. |
This would be weird if you interact with unrelated controls. I think they should show if the block type has focus, since these controls are an extension of it. |
I touched briefly on that with the "bold" example later, and suggested if it doesn't feel right, we can do this:
What do you think? |
Just tested with gutenberg.run/20056. Just cool. I can't wait to use it live... |
@mtias + @jasmussen Thanks for feedback! Will refine the focus x mouse interactions now. After that, I can look into the repositioning/docking handling 💪 |
@mtias + @jasmussen Oh boy! Have some updates for you all :) Demo Videos InteractionsMover show/hide rules are as follows: Show mover when...
Hide mover when...
(Note: All closing interactions are debounced, and are cancellable by any show interaction) There was quite a bit of sequencing/logic to get the above interaction right. CodeCode wise... I've refactored so that all of the interaction complexities are abstracted into this file: The main There are some adjustments made to the Let me know how it feels! |
@jasmussen Positioning update!! I experimented to see if I could get a feel of what we may want. I pushed it up for testing. Demo: Basically, the Toolbar will always have a space of This positioning logic fires on (browser) resize as well* (Currently not supported for mobile) This is a very VERY experimental (and hacky) implementation. I just did it for prototype/feels purposes. Overall, I think the logic/mechanisms for repositioning will follow similar principles.
The internal @ellatrix 👋 Haiii!! Maybe we can catch up on "undocking" things :). I'm unfamiliar with that one 😊 . If you're swamped, lemme know I'm on the right track with my thoughts above <3 |
GIF of what I'm seeing: Nice. This feels really right to me. It feels like it finds that balance of the movers being there and in a contextual way, while still not weighing down the UI the rest of the time. It works even for full-wide.
It did not seem to fire when applying the fullwide property: That's not world-endy, but would be nice if fixable.
Did you try making that 96px instead of 48? So 48px for the offset block indicator control, and another 48 for the mover control? I'm very possibly missing something, but I was hoping we could reserve that space, and use negative margins, so that no position outside of the usual JS positioning the toolbar does, is necessary.
Regarding the overall positioning that's already sort of working but buggy when on the right side, so long as we know it can and should be fixed, it's okay to not fix it urgently or in this branch. It needs fixing, but because it's so purely a bugfix, it shouldn't block the other G2 efforts. |
@jasmussen Haii! Thanks for the feedback :)
Great!
The positioning mechanism isn't that smart yet. For the next round, I can make adjustments to make it more responsive to changes, be it block width changes, browser resize, etc...
😱Do you have an example if it rendering on the right side? Is that rendered via RTL?
I'm not too sure what you mean 😊. I created a diagram (below) of the current measurements for offsets (block type, mover, and buffer). Does that feel okay? ❤️ |
That does feel okay, and by 96px I meant what it looks like you're showing above, 48px for the block type, 48px for the mover. My idea being that if the space for that was permanently reserved inside the popover, like a left padding, then the toolbar plus padding would be positioned, so you wouldn't have to do any extra positioning math than what's already there.
It's this, and it's not unique to this branch nor even the G2 branch: The benefit of an "undocked toolbar" is exactly that in a situation like the above, the right-most side of the toolbar can dock itself to the sidebar instead of being cropped by it. |
I'll give it a shot!
Gotcha!! I'll factor that into the repositioning calculations :) Stay tuned! |
@jasmussen Haiii! I just pushed up some changes to improve the positioning mechanism. It should feel "smarter" now. It accounts for any positional/overflow changes, and adjusts (horizontally) to match. Example: Align type change from center -> full The code needs to be refined, but I wanted to get your feedback first :).
I tried leaning more on CSS... it didn't work (I wish). Will still need positioning MATH 😂 |
This is what I see: Fullwidth: The particular interaction: The behavior here feels correct, still. Nice work. Notice that the positioning of the toolbar jumps a little bit when switching alignments. Is it possible to avoid this jumpiness? Alternately, I wonder if it would feel less jarring if the toolbar itself received a small
Totally fine, I trust you and defer to you. This works well. I honestly think, outside of any refinements you might have, this is worth an accessibility sanity check. If you'll forgive the direct ping, @MarcoZehe, if you have bandwidth to look at this I would very much appreciate it. Specifically, does the positioning and the tab order behavior of the mover control feel correct? Thank you. |
Oh, so I don't have an issue in 2020 theme but I have it with 2019. The weird thing is that I don't have with any theme in the G2 branch only. |
btw, I noticed an issue when hovering the switcher in posts with just one block (so no movers), a border appears floating on the left. |
I didn't find a fix yet for the height thing but I noticed that if we remove the "block-editor-block-toolbar__block-switcher-wrapper" wrapper, it's fixed. |
@youknowriad Thanks for investigating! I'm checking it out now :) You're the best 🏆 |
@youknowriad I fixed the issue. Cause: There's something in the 2019 theme modifies |
@youknowriad Good idea. I'm going to remove it now |
@@ -424,6 +424,9 @@ | |||
/** | |||
* Block Toolbar when contextual. | |||
*/ | |||
.block-editor-block-contextual-toolbar-wrapper { | |||
padding-left: 48px; |
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.
Is this the toolbar width, I think we have a variable for that.
This was done on purpose because ensuring there's enough room on the left is no easy task and something that should be handled in Popover instead. I was hoping we could do this later with some help from @ellatrix maybe. |
Understood, thanks for the clarification. I think this particular offset is important for the intitial G2 launch, so the block switcher can remain the anchor point. In that vein, I would think we should go with a hacky solution, even if that breaks down in some edgecases, and track that edgecase to be followed up on. I'll take a quick look to see if I can find a good trick. |
I'm looking a a quick fix for the mover position, and at random (I think I was messing with a paragraph inside a column), I got this:
|
This improves the situation for the 90% of the time.
I pushed a little fix.
The bigger fix is adding back the offset, which works well in most cases: The edgecase we still have to fix, presumably in the popover itself, is to allow the positioning to have a "minimun left absolute position". Right now it positions perfectly, we "simply" need to have a buffer there, so that the left most position of the toolbar can never be less than 96px. I feel we can do that in a followup, since this is already better than what's shipping, where the toolbar is cropped left and rigth, and at the same time it allows us to ship with the intentional toolbar behavior. This is a left paragraph in a full wide columns block: |
@@ -424,6 +424,9 @@ | |||
/** | |||
* Block Toolbar when contextual. | |||
*/ | |||
.block-editor-block-contextual-toolbar-wrapper { | |||
padding-left: $grid-unit-60; // Provide space for the mover control on full-wide items. |
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.
A better variable name here is $block-toolbar-height
as that's the width the icon buttons are assigned. It's not the only place where this is used directly in G2 but I believe we should change all of these sizes (that related to the toolbar height) with the $block-toolbar-height
variable instead. Because that way, if we change the toolbar height, it changes all the related sizes accordingly.
Thinking we should merge this branch into G2 now to have one less branch to work on. It's in a solid state and we can continue our last fixes on the G2 branch before landing it. Thoughts? |
Go for it. Should we do the same with g3? |
@youknowriad + @jasmussen Sounds good to me! Just pushed a change to fix the |
@jasmussen I'm considering it but still pondering and waiting for some feedback on my last comments there. |
Co-authored-by: Joen Asmussen <joen@automattic.com> Co-authored-by: Riad Benguella <benguella@gmail.com>
Co-authored-by: Joen Asmussen <joen@automattic.com> Co-authored-by: Riad Benguella <benguella@gmail.com>
This (draft) PR aims to improve the interactions of the Mover for the G2 redesigned Toolbar.
Demo of initial attempt:
https://d.pr/v/gqcVs7
(Note: This update does not change how the drag/reorder UX works. It only focuses on the Toolbar Mover bit)
Interactions
The current implementation works like the following:
Show mover when:
Hide mover when:
300ms
)(Current) Gotchas:
Feedback
@youknowriad / @jasmussen Let me know how this feels! The code is definitely not final. I coded enough to test out this interaction, with as little mess as possible.