import { bind, Variable } from 'astal'; import AstalApps from 'gi://AstalApps'; const Applications = AstalApps.Apps.new(); import AstalHyprland from 'gi://AstalHyprland'; const Hyprland = AstalHyprland.get_default(); import Separator from '../../misc/separator'; import { hyprMessage } from '../../../lib'; export default () => { const visibleIcon = Variable(false); const focusedIcon = Variable(''); const focusedTitle = Variable(''); let lastFocused: string | undefined; const updateVars = ( client: AstalHyprland.Client | null = Hyprland.get_focused_client(), ) => { lastFocused = client?.get_address(); const app = Applications.fuzzy_query( client?.get_class() ?? '', )[0]; const icon = app?.iconName; if (icon) { visibleIcon.set(true); focusedIcon.set(icon); } else { visibleIcon.set(false); } focusedTitle.set(client?.get_title() ?? ''); const id = client?.connect('notify::title', (c) => { if (c.get_address() !== lastFocused) { c.disconnect(id); } focusedTitle.set(c.get_title()); }); }; updateVars(); Hyprland.connect('notify::focused-client', () => updateVars()); Hyprland.connect('client-removed', () => updateVars()); Hyprland.connect('client-added', async() => { try { updateVars(Hyprland.get_client(JSON.parse(await hyprMessage('j/activewindow')).address)); } catch (e) { console.log(e); } }); return ( title !== '')} > ); };