-
Notifications
You must be signed in to change notification settings - Fork 30k
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
Define and apply guidance for icon toggle states #162595
Comments
Looking around, I see a couple of common situations where we are using icon buttons to toggle a state. Some first impressions:
Thoughts? ExamplesPinningLockingcc @bpasero @mjbvz @sandy081 The "locked" state representing autoscroll being turned on took me a few moments to really understand. I would have expected locked to mean that the scroll was locked in the current position. I think that's what you had before? Perhaps a more scroll-specific icon would be useful here. This is a little different given that you click on the icon to toggle the state but it disappears instead of showing an unlocked icon. I think that's fine since it's still representing the current state. Switching View Stylescc @andreamah for feedback. This is in a branch if you're ok with this change and want me to make the changes: |
Yes I agree that having the icon reflect the current state is easier to understand in cases like these. I think the fix for #162263 already aligned the output lock icon with this |
@mjbvz based on what I saw in Insiders today, the locked icon meant that the scrolling was not locked. Looking at this, I would expect the output to scroll. Once the lock icon was shown, I'd expect it to stay in place. |
@daviddossett so just to clarify, the toggle icons for search would be opposite of what it is currently? (ie: showing the current state with the icon rather than the target state)? |
Basically:
This is to be consistent with other situations where we are toggling, e.g. locking, pinning, etc. We almost always show the current state and use the tooltip to indicate what will happen on click. |
@daviddossett For me, locked should mean auto scrolling is on. The way I think about it, autoscrolling locks the viewport in place Once you unlock it and turn auto scrolling off, you can scroll all over without VS Code trying to change the viewport This is why I updated the icons in #162263 |
I see it sort of like a play/pause button situation where the button shows the target state, but I also see where you're going with swapping them. Where else outside of our product is there a button that shows current rather than target state? I feel like I see target state more when I look around different products? |
I see. I was thinking about it like we are locking the content in place, not the viewport. In any case, it took me more than a few seconds to realize what was going on. I also wonder if using the lock metaphor isn't quite right for autoscrolling in general.
Play/pause is a valid example, but I feel like that's a special case compared to setting a view state. See the examples above for locking and pinning. It would be strange to have the "pinned" icon used for something that wasn't currently pinned. Or the same for locking. Some other examples: This is slightly different because there's >2 options, but the current view state is represented by the icon. Here's another example for locking and toggling visibility: More than anything, I think I'm just generally confused when toggling the list states today. It's always the opposite of what I think it will be. |
Ah, I see. Yeah, it looks pretty natural in those settings, so I can see how that could make things less confusing. I give my 👍 for swapping the icons to show current state rather than target state. |
👍 for showing the current state in the icon for as long as that is consistently applied. |
As a devil's advocate UX argument; If the source-control list/tree button shows the current state, what result is a user expected to discern from this button by sight alone? I believe this button in particular is a special case, it's not a toggle like a checkbox, it's a radio-button! It should really be presented as a choice of two icons with a selected state for the current, i.e.
The thumbnail button in the bottom right of Explorer is basically the same principle: It doesn't make sense in this context to show only one button regardless if you choose the current state or the resulting state as the icon because the current state does not convey what the button will do in a multiple-choice, non checkbox, context. |
I think I agree with having the icon show the current state and has generally been the model I've followed in GitLens. But I think it gets more complicated with what you show as the tooltip. Does the tooltip also reflect the current state, or does it tell you what clicking on the button will do? I haven't really "picked a lane" on the tooltips -- sometimes I have them reflect the "to be taken" action and other times they reflect the current state. I think it probably makes sense to be consistent and always show the action to be taken, so it follows the pattern of normal action buttons, but it can make it hard to understand what the icon you are looking at means. And I don't have a good solution to deal with both of those. |
The problem is that which icon should show depends on why one is looking at the icon at a given moment. The best option is to have other cues beside the simple icon:
Ideally, the VSCode UI should add similar cues if possible, e.g.:
|
Refs #162441
In some situations where a state is toggled (locking, pinning, hiding), we use a different approach for which icon is exposed. Sometimes we show the current state (e.g. locked) and sometimes we show the target state (currently unlocked, but the locked icon is displayed).
Ideally we can have reusable guidance to apply elsewhere.
The text was updated successfully, but these errors were encountered: