# Tray Library for managing the systemtray by implementing the [StatusNotifierItem](https://www.freedesktop.org/wiki/Specifications/StatusNotifierItem/) protocol. ## Installation 1. install dependencies :::code-group ```sh [ Arch] sudo pacman -Syu meson gtk3 gobject-introspection libdbusmenu-gtk3 ``` ```sh [ Fedora] sudo dnf install meson gcc gtk3-devel libdbusmenu-gtk3 gobject-introspection-devel ``` ```sh [ Ubuntu] sudo apt install meson libgtk-3-dev libdbusmenu-gtk3-dev gobject-introspection ``` ::: 2. clone repo ```sh git clone https://github.com/aylur/astal.git cd astal/lib/tray ``` 3. install ```sh meson setup build meson install -C build ``` :::tip Most distros recommend manual installs in `/usr/local`, which is what `meson` defaults to. If you want to install to `/usr` instead which most package managers do, set the `prefix` option: ```sh meson setup --prefix /usr build ``` ::: ## Usage You can browse the [Tray reference](https://aylur.github.io/libastal/tray). ### CLI ```sh astal-tray --help ``` ### Library :::code-group ```js [ JavaScript] import Tray from "gi://AstalTray"; const tray = Tray.get_default(); console.log(tray.get_items().map((i) => i.title)); ``` ```py [ Python] import gi gi.require_version("AstalTray", "0.1") from gi.repository import AstalTray tray = AstalTray.get_default() print("\n".join(i.title for i in tray.get_items())) ``` ```lua [ Lua] local lgi = require("lgi") local AstalTray = lgi.require("AstalTray", "0.1") local tray = AstalTray.get_default() for _, i in ipairs(tray.items) do print(i.title) end ``` ```vala [ Vala] // Not yet documented ``` :::