-
Notifications
You must be signed in to change notification settings - Fork 8
2.0 UX Guidelines
Cohen Adair edited this page Jul 22, 2020
·
28 revisions
- Rectangular (or square) widgets, whether flat on the canvas or floating, have a border radius of
floatingCornerRadius
. - Floating widgets will the
FloatingBoxDecoration
.
- Detail disclosure indicator is
RightChevronIcon
widget, and is used to indicate that a tap action will show more detail about the tappedWidget
. -
AppBar
buttons use useIconButton
orActionButton
when an icon doesn't make sense. -
ActionButton
text colour is the app's theme when on a whiteAppBar
.
- An input form is presented as a fullscreen dialog and is initiated from a user action.
- Edit forms may be pushed when initiated from a detail disclosure indicator.
- A detail page is pushed, initiated from a detail disclosure indicator.
- Animations should be used when significant widget state changes occur, such as hiding or showing a button.
- All input forms utilize
FormPage
, or a derivative ofFormPage
. - When the first input widget is
TextInput
, it is focused when the page is shown.
- Input validation is done on load, so required fields are highlighted immediately.
- Input validation is done as input changes, so errors are caught immediately.
- Save button appears in the
AppBar
. - Save button is disabled until validation passes.
- App bar title starts with "Edit" for editing input forms, and "New" for new input forms. Or, if input is not for an
Entity
, the title clearly reflects the action of the page, such as "Send Feedback". - App bar title is centred, or left aligned only if action buttons take up too much space. This is normally done automatically by the
AppBar
widget.
- If there are only a few options, a
DropdownInput
widget is used. - If there are many options to choose from, a
ListPickerInput
widget is used. - Any customized pickers that can't utilize the above widgets, should make selection obvious, such as with a
Checkbox
,RadioButton
, or similar widget. - For multi-select pickers, or pickers that require more than just tapping an option, a "Done"
ActionButton
is used to indicate the user has finished picking. - To separate selectable items into sections, such as when selecting a date range, use the
Divider
widget.
- All
Entity
lists utilizeManageableListPage
to ensure consistent UX across the entire app. Components ofManageableListPage
, such as search functionality, may vary depending on theEntity
. - Sections in multi-section lists, such as
BaitListPage
, are separated by aMinDivider
widget followed by aHeadingLabel
withinsetsDefault
padding on all sides.
- When an
Entity
is deleted, a confirmation message is shown in the following formats:- If the
Entity
can be associated with other entities:Wooly Bugger (Black) is associated with 5 catches; are you sure you want to delete it? This cannot be undone.
- If the
Entity
cannot be associated with other entities:Are you sure you want to delete trip Alaska '19? This cannot be undone.
- If the
Entity
can be associated with multiple other entities, such as with aCustomEntity
:The custom field Size will no longer be associated with catches (5) or baits (3), are you sure you want to delete it? This cannot be undone.
- If the
- If an
Entity
is a required field of anotherEntity
and is associated with one or more of thatEntity
, it cannot be deleted, and the user is presented with the following error format:Blue Catfish is associated with 10 catches and cannot be deleted.
- Search results update as the user types.
- If no results are found, the following message format is shown:
No fishing spots found
-
CustomEntity
values rendered at the bottom of the page, separated by aHeadingDivider
widget.