ListItem#

class ListItem(**properties: Any)#

Superclasses: Object

Subclasses: ColumnViewCell

GtkListItem is used by list widgets to represent items in a ListModel.

GtkListItem objects are managed by the list widget (with its factory) and cannot be created by applications, but they need to be populated by application code. This is done by calling set_child.

GtkListItem objects exist in 2 stages:

  1. The unbound stage where the listitem is not currently connected to an item in the list. In that case, the item property is set to None.

  2. The bound stage where the listitem references an item from the list. The item property is not None.

Methods#

class ListItem
get_accessible_description() str#

Gets the accessible description of self.

Added in version 4.12.

get_accessible_label() str#

Gets the accessible label of self.

Added in version 4.12.

get_activatable() bool#

Checks if a list item has been set to be activatable via set_activatable().

get_child() Widget | None#

Gets the child previously set via set_child() or None if none was set.

get_focusable() bool#

Checks if a list item has been set to be focusable via set_focusable().

Added in version 4.12.

get_item() Object | None#

Gets the model item that associated with self.

If self is unbound, this function returns None.

get_position() int#

Gets the position in the model that self currently displays.

If self is unbound, INVALID_LIST_POSITION is returned.

get_selectable() bool#

Checks if a list item has been set to be selectable via set_selectable().

Do not confuse this function with get_selected.

get_selected() bool#

Checks if the item is displayed as selected.

The selected state is maintained by the list widget and its model and cannot be set otherwise.

set_accessible_description(description: str) None#

Sets the accessible description for the list item, which may be used by e.g. screen readers.

Added in version 4.12.

Parameters:

description – the description

set_accessible_label(label: str) None#

Sets the accessible label for the list item, which may be used by e.g. screen readers.

Added in version 4.12.

Parameters:

label – the label

set_activatable(activatable: bool) None#

Sets self to be activatable.

If an item is activatable, double-clicking on the item, using the Return key or calling activate() will activate the item. Activating instructs the containing view to handle activation. GtkListView for example will be emitting the activate signal.

By default, list items are activatable.

Parameters:

activatable – if the item should be activatable

set_child(child: Widget | None = None) None#

Sets the child to be used for this listitem.

This function is typically called by applications when setting up a listitem so that the widget can be reused when binding it multiple times.

Parameters:

child – The list item’s child or None to unset

set_focusable(focusable: bool) None#

Sets self to be focusable.

If an item is focusable, it can be focused using the keyboard. This works similar to set_focusable.

Note that if items are not focusable, the keyboard cannot be used to activate them and selecting only works if one of the listitem’s children is focusable.

By default, list items are focusable.

Added in version 4.12.

Parameters:

focusable – if the item should be focusable

set_selectable(selectable: bool) None#

Sets self to be selectable.

If an item is selectable, clicking on the item or using the keyboard will try to select or unselect the item. If this succeeds is up to the model to determine, as it is managing the selected state.

Note that this means that making an item non-selectable has no influence on the selected state at all. A non-selectable item may still be selected.

By default, list items are selectable. When rebinding them to a new item, they will also be reset to be selectable by GTK.

Parameters:

selectable – if the item should be selectable

Properties#

class ListItem
props.accessible_description: str#

The type of the None singleton.

Added in version 4.12.

props.accessible_label: str#

The type of the None singleton.

Added in version 4.12.

props.activatable: bool#

The type of the None singleton.

props.child: Widget#

The type of the None singleton.

props.focusable: bool#

The type of the None singleton.

Added in version 4.12.

props.item: Object#

The type of the None singleton.

props.position: int#

The type of the None singleton.

props.selectable: bool#

The type of the None singleton.

props.selected: bool#

The type of the None singleton.