Status Icons

Icons that appear in the system tray for representing app status while the app isn’t visible.

Usage

Although the usual user interface for an app is a window, some apps will augment - or even replace - a window-base interface with an icon in the system tray or status bar provided by the operating system. This is especially common for apps that primarily run in the background.

Toga supports two types of status icons - simple status icons, and menu status icons.

Simple status icons

A simple status icon is a bare icon in the status bar. You can set and change the icon as required to reflect changes in application state; by default, the status icon will use the app’s icon. The text associated with the icon will be used as a tooltip; again, the app’s formal name will be used as default text. The icon can respond to mouse clicks by defining an on_press handler.

To define a simple status icon, declare an instance of toga.SimpleStatusIcon, and add it to your app’s status_icons set:

import toga

# Define a status icon that uses default values for icon and tooltip,
# and doesn't respond to mouse clicks.
status_icon_1 = toga.SimpleStatusIcon()

# Define a second status icon that provides explicit values for the id, icon and
# tooltip, and responds to mouse clicks.
def my_handler(widget, **kwargs):
    print("Second status icon pressed!")

status_icon_2 = toga.SimpleStatusIcon(
    id="second",
    text="Hello!",
    icon="icons/red",
    on_press=my_handler
)

# Add both status icons to the app
app.status_icons.add(status_icon_1, status_icon_2)

Once a status icon has been added to the app, it can be retrieved by ID or by index; and it can be removed from the app:

# Change the icon of the first status icon, retrieved by index:
app.status_icons[0].icon = "icons/green"

# Change the icon of the second status icon, retrieved by id:
app.status_icons["second"].icon = "icons/blue"

# Remove the first status icon from the app:
app.status_icons.remove(status_icon_1)

Notes

  • Status icons on GTK are implemented using the XApp library. This requires that the user has installed the system packages for libxapp, plus the GObject Introspection bindings for that library. The name of the system package required is distribution dependent:

    • Ubuntu: gir1.2-xapp-1.0

    • Fedora: xapps

  • The GNOME desktop environment does not provide built-in support for status icons. This is an explicit design decision on their part, and they advise against using status icons as part of your app design. However, there are GNOME shell extensions that can add support for status icons. Other GTK-based desktop environments (such as Cinnamon) do support status icons.

Reference

class toga.statusicons.StatusIcon(icon=None)

An abstract base class for all status icons.

Parameters:

icon (IconContentT | None)

property icon: Icon | None

The Icon to display in the status bar.

When setting the icon, you can provide either an Icon instance, or a path that will be passed to the Icon constructor.

abstract property id: str

A unique identifier for the status icon.

abstract property text: str

A text label for the status icon.

class toga.SimpleStatusIcon(id=None, icon=None, text=None, on_press=None)

Bases: StatusIcon

An button in a status bar or system tray.

When pressed, the on_press handler will be activated.

Parameters:
  • id (str | None) – An identifier for the status icon.

  • icon (IconContentT | None) – The icon, or icon resource, that will be displayed in the status bar or system tray.

  • text (str | None) – A text label for the status icon. Defaults to the formal name of the app.

  • on_press (toga.widgets.button.OnPressHandler | None) – The handler to invoke when the status icon is pressed.

property id: str

A unique identifier for the status icon.

property on_press: toga.widgets.button.OnPressHandler

The handler to invoke when the status icon is pressed.

property text: str

A text label for the status icon.

class toga.MenuStatusIcon(id=None, icon=None, text=None)

Bases: Group, StatusIcon

An item in a status bar or system tray that displays a menu when pressed.

A MenuStatusIcon can be used as a Group when defining toga.Command instances.

Parameters:
  • id (str | None) – An identifier for the status icon.

  • icon (IconContentT | None) – The icon, or icon resource, that will be displayed in the status bar or system tray.

  • text (str | None) – A text label for the status icon. Defaults to the formal name of the app.

class toga.statusicons.StatusIconSet

Bases: Sequence[StatusIcon], Mapping[str, StatusIcon]

An ordered collection of status icons.

The items in the set can be retrieved by instance, or by ID. When iterated, the items are returned in the order they were added.

add(*status_icons)

Add one or more icons to the set.

Parameters:

status_icons (StatusIcon) – The icon (or icons) to add to the set.

clear()

Remove all the icons from the set.

Raises:

ValueError – If the status icon commands include any commands that reference an icon that has been removed.

remove(status_icon)

Remove a single icon from the set.

Parameters:

status_icon (StatusIcon) – The status icon instance to remove.

Raises:

ValueError – If the status icon commands include any commands that reference the icon that has been removed.