Widget¶
The abstract base class of all widgets.
Availability (Key)
| macOS | Linux (GTK) | Linux (Qt) | Windows | iOS | Android | Web | Terminal |
|---|---|---|---|---|---|---|---|
| ● | ● | ● | ● | ● | ● | ○ | ○ |
Usage¶
This class exists only for actual widgets to inherit from; it should not be be instantiated directly.
Reference¶
toga.Widget
¶
Bases: Node, PackMixin, ABC
Create a base Toga widget.
This is an abstract base class; it cannot be instantiated.
| PARAMETER | DESCRIPTION |
|---|---|
id
|
The ID for the widget.
TYPE:
|
style
|
A style object. If no style is provided, a default style will be applied to the widget.
TYPE:
|
kwargs
|
Initial style properties.
DEFAULT:
|
DEBUG_LAYOUT_ENABLED
class-attribute
instance-attribute
¶
DEBUG_LAYOUT_ENABLED
Determines whether debug layout mode is enabled.
When enabled, container widgets use distinct background colors to make the layout more visible and help identify issues during development.
See the Debugging Your App guide for more information.
app
property
writable
¶
app: App | None
The App to which this widget belongs.
When setting the app for a widget, all children of this widget will be recursively assigned to the same app.
| RAISES | DESCRIPTION |
|---|---|
ValueError
|
If this widget is already associated with another app. |
enabled
property
writable
¶
enabled: bool
Is the widget currently enabled? i.e., can the user interact with the widget?
tab_index
property
writable
¶
tab_index: int | None
The position of the widget in the focus chain for the window.
Note
This is a beta feature. The tab_index API may change in the future.
add
¶
add(*children: Widget) -> None
Add the provided widgets as children of this widget.
If a child widget already has a parent, it will be re-parented as a child of this widget. If the child widget is already a child of this widget, there is no change.
| PARAMETER | DESCRIPTION |
|---|---|
children
|
The widgets to add as children of this widget.
TYPE:
|
| RAISES | DESCRIPTION |
|---|---|
ValueError
|
If this widget cannot have children. |
clear
¶
clear() -> None
Remove all child widgets of this node.
Refreshes the widget after removal if any children were removed.
| RAISES | DESCRIPTION |
|---|---|
ValueError
|
If this widget cannot have children. |
focus
¶
focus() -> None
Give this widget the input focus.
This method is a no-op if the widget can't accept focus. The ability of a widget to accept focus is platform-dependent. In general, on desktop platforms you can focus any widget that can accept user input, while on mobile platforms focus is limited to widgets that accept text input (i.e., widgets that cause the virtual keyboard to appear).
index
¶
Get the index of a widget in the list of children of this widget.
| PARAMETER | DESCRIPTION |
|---|---|
child
|
The child widget of interest.
TYPE:
|
| RETURNS | DESCRIPTION |
|---|---|
int
|
Index of specified child widget in children list. |
| RAISES | DESCRIPTION |
|---|---|
ValueError
|
If the specified child widget is not found in the list of children. |
insert
¶
Insert a widget as a child of this widget.
If a child widget already has a parent, it will be re-parented as a child of this widget. If the child widget is already a child of this widget, there is no change.
| PARAMETER | DESCRIPTION |
|---|---|
index
|
The position in the list of children where the new widget should be added.
TYPE:
|
child
|
The child to insert as a child of this node.
TYPE:
|
| RAISES | DESCRIPTION |
|---|---|
ValueError
|
If this widget cannot have children. |
remove
¶
remove(*children: Widget) -> None
Remove the provided widgets as children of this node.
Any nominated child widget that is not a child of this widget will not have any change in parentage.
Refreshes the widget after removal if any children were removed.
| PARAMETER | DESCRIPTION |
|---|---|
children
|
The child nodes to remove.
TYPE:
|
| RAISES | DESCRIPTION |
|---|---|
ValueError
|
If this widget cannot have children. |