Skip to content

Widget UI

rafael edited this page Feb 19, 2021 · 5 revisions

Following the merge and release of https://github.com/biolab/orange-widget-base/pull/130, widgets will look a bit different.

Style Guidelines

Up until now, when making a widget, you'd make a list of controls, slap a box on it, and put it in self.controlArea. We've now made some effort to establish visual consistency between widgets, adhering to the following guidelines as closely as possible. Herein, box refers to a group of controls, and frame refers to the use of the box=None kwarg in the orangewidget.gui library.

  • if a box of controls only has controls of one type (e.g., a list of checkboxes), don't put a frame on it (gui.button(..., box=None))
  • if a box of controls has mixed controls (e.g., four comboboxes and a checkbox), put a frame on it, and give it a descriptive name (gui.hBox(..., box='Good name'))
  • don't use frames without names (avoid gui.hBox(..., box=True)); these render weird on Mac and some Linux window managers
🟢 Correct
Screenshot 2021-02-19 at 01 12 31
🛑 Wrong

Screenshot 2021-02-19 at 01 13 22 Screenshot 2021-02-19 at 01 10 24

When making boxes of controls, if possible, don't mix control types. It makes margins/spacing on macOS not look as nice.

For a better understanding of macOS rendering, see https://doc.qt.io/archives/qq/qq23-layouts.html. TL;DR: macOS adjusts spacing and margin between elements depending on their type and positioning. A complex control (e.g., labeled combobox) is implemented as a horizontal box. Because its understanding of control types is opaque, it uses a large margin, even though a label or a combobox margin would be smaller.

Refactoring to self.buttonsArea

Widgets which don't show visualizations put all of their controls into self.controlArea. You might notice an increased bottom margin, like so:

Before release | After release

Screenshot 2021-02-18 at 22 30 04 Screenshot 2021-02-18 at 22 30 51

That's because, at the bottom, there's now a buttonsArea.

boxes

This separation of self.controlArea and self.buttonsArea allows us to implement scrolling in widgets with a main area, while always showing the tools:

Screenshot 2021-02-18 at 22 52 03

self.buttonsArea also has a some left and right margin, so the controls at the bottom are nicer aligned:

🟢 table in self.controlArea, buttons in self.buttonsArea
Screenshot 2021-02-18 at 22 57 52
🛑 all in self.controlArea
Screenshot 2021-02-18 at 22 57 47

To fix up Yahoo Finance, we have to move the Download button to self.buttonsArea.

Screenshot 2021-02-18 at 22 45 29
Before our change | After our change

Screenshot 2021-02-18 at 22 30 51 Screenshot 2021-02-18 at 22 42 41

Most of the changes needed to accommodate the new orange-widget-base will be as simple as this. For most widgets, you just move the auto_commit checkbox/button into the buttonsArea.

Clone this wiki locally