An async implementation of the StatusNotifierItem
and DbusMenu
protocols for building system trays.
Requires Tokio.
Note
ZBus API changed a lot from 3.x to 5.x
This is one fork to help with that
idk if the origin needs it since it's still working pretty well under 3.x
but one of my personal projects already updated to zbus-5.x, and i want to try this crate with that project of mine, so here we are.
use system_tray::client::Client;
#[tokio::main]
async fn main() {
let client = Client::new().await.unwrap();
let mut tray_rx = client.subscribe();
let initial_items = client.items();
// do something with initial items...
while let Ok(ev) = tray_rx.recv().await {
println!("{ev:?}"); // do something with event...
}
}
Although the library provides a built-in Rust-native implementation of the DBusMenu
protocol,
this has a few issues:
- There are some known bugs. For example, opening a file in VLC will break its menu.
- If you are creating a menu UI, you need to parse the whole tree set up each element, and track all changes manually.
To circumvent this, bindings to the dbusmenu-gtk3
system library are included.
When the feature of the same name is enabled, you can listen for UpdateEvent::MenuConnect
and create the GTK element based on that:
fn on_update(update: system_tray::Event) {
match update {
Event::Update(address, UpdateEvent::MenuConnect(menu)) => {
let menu: gtk::auto::Menu = system_tray::gtk_menu::Menu::new(&address, &menu);
// do something with the menu element
}
}
}
Note
This feature is disabled by default to reduce compilation times.
Some of the code in this repository, namely the SNI host, is taken from eww under MIT. Many thanks to elkowar.