-
-
Notifications
You must be signed in to change notification settings - Fork 48
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
Improve RPC dialog windows usability: Window header, text, icon semiotics #5840
Comments
This is a hard one. By design, the part that enforces isolation, which includes qrexec policy prompts, is as simple as possible. This means it intentionally knows only very simple information: "operation A, from source B, to destination C". Everything else stays isolated from the isolation-enforcing engine. Having filenames there maybe sounds simple, but in fact it opens multiple avenues for attacks (non-exhaustive list):
But actually the mockup of multiple file copy could kind of works: having information just about number of files and their size (like 12 files, 7.3 MB) is something that doesn't require arbitrary characters in the prompt, while still gives some info about what is copied; and is also enforceable (at least as an upper limit). |
@marmarek Thank you for the detailed response! Actually, the filename part of my proposal, is one of the least important components to it. Per my prioritization of all the elements of the proposal above, it's listed as item number 8 of 11. Apologies that I was not clear in my grouping and numbering of things. Everything you explain above, makes total sense. What stands-out to me as the most confusing part of today's presentation, are as follows:
Then lots of little things... like eliminating the white background-box on the Source VM, because that's not editable. I also just personally dislike icons on buttons, and prefer simpler "Primary, Secondary" paradigm—but that's probably the most unimportant change, of all the particulars I'm offering in this proposal. See updated mockups, that also factor-in a 3rd specific-window design for GPG Key imports, and a 4th design for "Everything Else." In theory, simply the 4th design could be implemented for everything... but my concern with that, is that common tasks non-technical users are accustomed to doing on our macs and PCs (like copying and moving files) being framed as a "RPC Operation" will likely be confusing. But, that framing to advanced users who'll actually customize their policies, meets their expectations and would totally make sense to them. Thoughts? |
Also, some transparency behind my motivations for having filed this: we're currently exploring an "Export to VM" option for the SecureDrop Workstation client app. For my current proposal, the user would select "Export to VM" on a file or message, and the qvm.Copy dialog would be prompted from within Qubes. Today's presentation of that dialog, then presents a cryptic-appearing window to our users—who will mostly be restricting their exposure to Qubes, to the client we've designed and maybe to a few other apps in other VMs. Seeking to improve the usability of Qubes for all Qubes users on file-management tasks, felt like a natural extension of a more limited "Just pls do this for |
Generally I agree with most of the above points. The confirmation prompt should be clear about key three things: what action, from where, to where (which user actually selects there). Besides filenames, other points are very reasonable. One minor detail I'd modify, is to emphasize (with bold) action name ("copy file" or "move file") even in custom dialog. I see two steps here:
|
@marmarek Awesome! Yes, I like your suggestion to bold the action in copy/move/gpg specific dialogs. Will create updated mockups and create 2 new issues—one for global QVM ops dialog changes, and a second to create task-specific dialogs (dependent on the API)—while closing this one, later this eve. Thx for the rapid feedback to iterate towards a nice set of next steps. :) |
Window Header on https://user-images.githubusercontent.com/8262612/82740323-a0b30580-9cfc-11ea-80b3-aa7d3422c6ca.png above should indicate Move, not Copy... <minor point, but just in case it becomes part of the requirement...> |
@brendanhoar Thank you for pointing out that silly oversight on my part! Will update later tonite in this issue, as well. :) |
Little side-note (maybe not so important in the first iteration): When the RPC dialog pops up to allow a USB keyboard or mouse ("input proxy") it would be extremely helpful to see the name of the USB devices this is prompted for (e.g. many webcams present themselves as HID and consequently trigger this dialog). It can be quite confusing if one sees this dialog multiple times without knowing what one is allowing. |
@marmarek Actually, I had this thought last night... could the option at right be possible? If I were to get a list of all RPC files that ship with Still unsure about what to use as a global Title Bar line of plain-language text, and entirely open to suggestions! |
Technically very similar thing is already tracked in #3604. And I believe there was some discussion about it too, but I can't find it now.
Yes. This is also the reason why the above mentioned issue isn't implemented yet. But indeed for practical reasons, such extra information, even if not enforceable, would be very useful... |
@ninavizz you can easily get the list in dom0 by simply listing files in |
A few thoughts (as a slightly-more-technical but still design-minded user):
|
@ideologysec Thank you for the feedback! A few thoughts...
|
As for the icons on buttons - this isn't just about color, but also about their shape. And actually, those OK/Cancel buttons are sourced from the theme you set, to be consistent with other applications. Removing icons from them would actually reduce consistency. |
@ninavizz thanks for the insights! Some responses in no particular order/coherence: Per the XFCE HIG (which basically says, "use the GNOME 2 HIG, so, per the GNOME2 HIG): "Label all buttons with imperative verbs, using header capitalization. For example, Save, Sort or Update Now. Provide an access key in the label that allows the user to directly activate the button from the keyboard." So, the OK/Cancel buttons are important to preserve for minimum-level functionality/cognitive coherence with the upstream XFCE/GNOME2 HIGs, and with the rest of QubesOS - but when we can get those API-driven button labels all over the place, then we're really cooking with gas as the metaphor goes (that's a very stretch goal - I personally don't much like the GNOME interface choices, but I'm here for consistency and coherence and additional information to help users not violate security boundaries or do something destructive without prior intent). Regarding colors/icons causing cognitive overhead or not, and again from a consistency perspective - (and doing my best to avoid bikeshedding even if we're literally talking about the color and shape of buttons...) keeping the icons on "OK" and "Cancel" are again more in-line and consistent with, the rest of the Qubes interface. Until we're ready to abandon all upstream linux-isms and/or transition all buttons systemwide to a different paradigm, is it possible to keep them as-is and focus on the modal window text/header/dialog presentation? Heck, even shading the active/ideal button sounds fine! (and definitely what I'm used to) Would also love to see that pushed upstream to all TemplateVMs/Qubes as a whole. speaking of "decently-designed Linux distros/sane HIGs", have we considered elementaryOS as a possible Qubes template? :) |
@ideologysec The GNOME HIG guidelines are mostly known best-practices for UX stuff. The guidelines are published to help developers make decisions when direct UX support is not available. The guideline you cite is a known pattern, and at the heart of why I want some kind of a change to happen. However, more specific button texts cannot be implemented, until the API Mark cites several comments above, can be created—with a unique window for each policy command. Which is, in effect, the richer 2nd phase of this—which I'll be creating a child ticket for, today, but won't publish any solutions against as I don't have the bandwidth at this time for that. Community contrib suggestions, of course welcome, for what appropriate primary button action text for each policy wd be. Until then, a simple system needs to be shaped with mostly generic, human verbiage, a place for the RPC blab, and probably one space for a plain-language summation of what that action will do. Regarding the icons on buttons: as noted on my earlier comment, and to your point—that's a thing with global impact, and as they're used elsewhere in the Qubes UI it'd be best to do that one later. |
@marmarek The point with the color schpeel, is that the way XFCE/Gnome currently does icons on buttons in Qubes, actually does make it harder for everyone when the two buttons are the same color but then have differently colored icons on them with gradients, etc. One, per the longstanding "Tray icons" discussion... all of the Tango icons smaller than maaaybe 64x64, are too small to meaningfully register to users w/o cognitive strain. Especially users new to Gnome, Linux, or any non-modern UI. I know these icons were the norm in the 1990s. The point of UI aesthetics, is to guide users; and the quickest, most friction-free method to do that, is by expressing clear hierarchies first, more detailed semiotics, second. The Tango icons have all sorts of stylistic information packed into them, atop the basic form: the check-mark itself appears to be italicized, in a brush-stroke of some sort, it has a shadow, and a glossy gradient of some kind. Users unfamiliar with that style need to cognitively "get past" those distractions to ascertain "Oh, this is a checkmark," while users familiar with the style may find it delivers an aesthetic value that is pleasing. On the other side of things... GitHub, as an example (If you are reading this in the web UI, begin a comment to see the buttons I'm speaking to) has the deep green with white text as the primary-action button, and a flat grey button w/ black text on it as the secondary-action button. The latter happens to have a small, gradient-free red icon on it. The icon is very "plain" and clean, so the user can cognitively process what they're looking at while parsing its semiotic, more quickly and easily than a similar icon presented in a more stylized fashion. If a screenshot were made of this UI and it were to be plopped into GIMP and made grayscale, the "Comment" button still is the clearly darker button. That paradigm, of one button always appearing heavier/darker and the other button always lighter, is the preferred modern "Primary/Secondary" pattern. If icons can be added w/o being a distraction, great! Icons alone, though, create more cognitive friction than I feel is worth it, when that clear primary/secondary hierarchy is otherwise absent. The way buttons are done today in Qubes, there is rarely a clear primary and secondary button; the only visual distinction, being an icon on the button—and that icon's semiotic requires parsing, after it's been visually parsed. The file box atop a button I saw in Nautilus, is a great example that would likely throw non-Linux users... as it's so out of left field from what Windows, Mac, and Webapp users are accustomed to seeing everyday. |
Per Marek's comment above, I'm closing this issue and opening 2 new ones: basic no-API-required changes to the dialog, and richer "API Required" changes. #3604 I'll also tag onto the latter, as something—even handwavey and vague—would be nice. |
The problem you're addressing (if any)
When invoking the qvm copy to VM dialog, a very generic appearing window is prompted. This likely feels ok to developers, however to non-developer users a more friendly and contextually appropriate window would be nice.
When I seek to move a file to another VM, however, the window is identical; and the
qvm.Filecopy
operation is still shown. I filed #5841 to indicate what seems like a proper bug on the latter, however the two very different actions should be more clearly reflected to users.Describe the solution you'd like
This is a mockup of what I'm thinking:
Per the MoSCoW method of prioritization, it illustrates the below:
MUST:
Do you want to allow...
text to instruct user appropriately.SHOULD:
6. Update window icon to reflect action (move or copy)
7. Create 2 more distinct windows to reflect single or multiple files (see move example)
8. Add filename
9. If 8, then also change field labels
COULD
10. For all RPC operations, create 1:1 friendly window titles to more clearly reflect back to a user what theyre chosing to do... without having to do the additional mental hops. So,
qubes.GpgImport
would get the window title of Import GPG key, as an example.11. Larger ux audit of all RPC dialog window tasks, and how all could potentially be made a bit more friendly.
The text was updated successfully, but these errors were encountered: