nixos-configs/modules/ags/config/ts/bar/items/systray.ts

105 lines
2.7 KiB
TypeScript
Raw Normal View History

2024-07-08 21:15:11 -04:00
import Tray from 'gi://AstalTray?version=0.1';
const SystemTray = Tray.Tray.get_default();
const { timeout } = Utils;
const { Box, Icon, MenuItem, MenuBar, Revealer } = Widget;
2023-09-11 19:57:21 -04:00
import Separator from '../../misc/separator.ts';
const REVEAL_DURATION = 500;
const SPACING = 12;
2024-07-08 21:15:11 -04:00
/* Types */
// FIXME: get types from 'gi://AstalTray'
import type AstalTray from 'types/astal-tray/astaltray-0.1.d.ts';
2024-01-13 11:15:08 -05:00
2024-07-08 21:15:11 -04:00
const SysTrayItem = (item: AstalTray.TrayItem) => {
if (item.id === 'spotify-client') {
return;
}
return MenuItem({
2024-07-08 21:15:11 -04:00
submenu: item.create_menu(),
child: Revealer({
transition: 'slide_right',
2023-12-18 18:00:30 -05:00
transition_duration: REVEAL_DURATION,
2024-07-08 21:15:11 -04:00
child: Icon({
size: 24,
icon: Utils.watch(
item.iconPixbuf || item.iconName || 'image-missing',
item,
() => item.iconPixbuf || item.iconName || 'image-missing',
),
}),
}),
2024-07-08 21:15:11 -04:00
}).bind('tooltip_markup', item, 'tooltipMarkup');
};
2023-11-13 16:33:19 -05:00
const SysTray = () => MenuBar({
2024-01-13 11:15:08 -05:00
attribute: { items: new Map() },
2023-10-18 11:53:49 -04:00
2023-12-18 18:00:30 -05:00
setup: (self) => {
self
.hook(SystemTray, (_, id) => {
2024-07-08 21:15:11 -04:00
if (!id) {
return;
}
const item = SystemTray.get_item(id);
if (self.attribute.items.has(id) || !item) {
return;
}
const w = SysTrayItem(item);
// Early return if item is in blocklist
if (!w) {
return;
}
self.attribute.items.set(id, w);
2024-02-11 02:18:59 -05:00
self.add(w);
self.show_all();
2024-01-13 11:15:08 -05:00
w.child.reveal_child = true;
2024-07-08 21:15:11 -04:00
}, 'item_added')
.hook(SystemTray, (_, id) => {
2024-07-08 21:15:11 -04:00
if (!id || !self.attribute.items.has(id)) {
return;
}
self.attribute.items.get(id).child.reveal_child = false;
timeout(REVEAL_DURATION, () => {
self.attribute.items.get(id).destroy();
self.attribute.items.delete(id);
});
2024-07-08 21:15:11 -04:00
}, 'item_removed');
2023-11-13 16:33:19 -05:00
},
});
2023-10-18 11:53:49 -04:00
export default () => {
const systray = SysTray();
return Revealer({
transition: 'slide_right',
child: Box({
children: [
Box({
2023-12-18 18:00:30 -05:00
class_name: 'sys-tray',
children: [systray],
}),
Separator(SPACING),
],
}),
2023-12-18 18:00:30 -05:00
}).hook(SystemTray, (self) => {
self.reveal_child = systray.get_children().length > 0;
2024-07-08 21:15:11 -04:00
}, 'item_added');
};