dialogs
— Easy-to-use UI Dialogs¶The dialogs
module provides easy-to-use GUI dialogs for simple data input on iOS. It is mostly built on top of the ui
module, and while less flexible than using ui
directly, it is a lot easier to use and requires very few lines of code in most cases.
Most functions in this module present a dialog and return the user’s input. The following kinds of dialogs are supported:
text_dialog()
)list_dialog()
)edit_list_dialog()
)date_dialog()
, time_dialog()
, datetime_dialog()
, duration_dialog()
)form_dialog()
)dialogs.
list_dialog
(title='', items=None, multiple=False)¶Present a list of items and return the one(s) that were selected. When the dialog is cancelled, None is returned. The items list can contain any kind of object that can be converted to a string. To get more control over how each item is displayed in the list, you can also use a list of dictionaries (see ui.ListDataSource.items
for details).
dialogs.
edit_list_dialog
(title='', items=None, move=True, delete=True)¶Present a list of items that can be edited by the user. By default, the user can both rearrange the list and remove items; this behavior can be controlled with the move and delete parameters.
The return value is the modified list of items, or None if the dialog was cancelled.
dialogs.
form_dialog
(title='', fields=None, sections=None)¶Present a form dialog, similar to many settings interfaces.
Each field in the dialog is configured by dictionary. If there is only a single section of fields, the list of these field dictionaries can be passed as the fields parameter. If there should be multiple sections, each section is represented by a tuple (usually a 2-tuple containing the title of the section and its list of fields; an optional third item can contain footer text for the section).
The return value of this function is a dictionary of values for each field (or None, if the dialog was cancelled).
A field dictionary should contain the following keys:
'type'
– (required) the type of the field, this can be 'switch'
, 'text'
, 'url'
, 'email'
, 'password'
, 'number'
, 'check'
, 'datetime'
, 'date'
, or 'time'
'key'
– the key of this field in the return value of the form'value'
– the initial value of the field (for text/url/email/password/number fields, this should be a string, for switch fields a boolean (True/False), for datetime fields a datetime object)'title'
– the human-readable title/label of the field'type'
is the only required key. If 'key'
is not present, the 'title'
is used instead. If both are missing, fields are numbered sequentially in the returned dictionary.
Optional keys for all field types:
'tint_color'
– the field’s tint color (the effect of this depends on the type of the field)'icon'
– the name of a built-in image or a ui.Image
objectOptional keys for text/url/email/password/number fields:
'placeholder'
– the text that is shown when the field is empty'autocorrection'
– whether auto-correction should be enabled for this field (True/False)'autocapitalization'
– auto-capitalization behavior for the text fields, for possible values, see ui.TextField.autocapitalization_type
dialogs.
text_dialog
(title='', text='', font=('<system>', 16), autocorrection=None, autocapitalization=ui.AUTOCAPITALIZE_SENTENCES, spellchecking=None)¶Show a multi-line text editor sheet.
The behavior of the editor can be customized with the autocorrection, autocapitalization, and spellchecking parameters. The text parameter controls the initial text in the editor.
The edited text is returned as a string (if the dialog is cancelled, None is returned instead).
dialogs.
date_dialog
(title='')¶Show a date picker dialog, the return value is a datetime.datetime
object.
dialogs.
time_dialog
(title='')¶Show a time picker dialog, the return value is a datetime.datetime
object.
dialogs.
datetime_dialog
(title='')¶Show a date/time picker dialog, the return value is a datetime.datetime
object.
dialogs.
duration_dialog
(title='')¶Show a duration picker dialog (e.g. for a countdown timer), the return value is the selected duration in seconds (e.g. 60.0 for 1 minute).
Show the system sharing dialog for a given image (can be either a ui.Image
or a PIL Image
).
Show the system sharing dialog for a given string.
Show the system sharing dialog for a given URL.
dialogs.
pick_document
(types=['public.data'])¶Show the system’s document picker for importing a file, and return the file’s path (or None if the dialog is canceled).
types specifies the Universal Type Identifiers (UTIs) that should be selectable in the document picker. The default (['public.data']
) makes all regular files selectable. A list of the system-defined UTIs are available in Apple’s Uniform Type Identifiers Reference.
The return value is a temporary file. You can read it directly, but to keep a permanent copy, you must move it somewhere else.