import { Astal, Gdk, Gtk, Widget } from "astal/gtk3"; import { getDateTime } from "../scripts/time"; import { execAsync, GLib } from "astal"; const { TOP, LEFT, RIGHT, BOTTOM } = Astal.WindowAnchor; export const LogoutMenu: Widget.Window = new Widget.Window({ namespace: "logout-menu", anchor: TOP | LEFT | RIGHT | BOTTOM, layer: Astal.Layer.OVERLAY, exclusivity: Astal.Exclusivity.IGNORE, keymode: Astal.Keymode.EXCLUSIVE, monitor: 0, visible: false, onKeyPressEvent: (_, event: Gdk.Event) => { event.get_keyval()[1] === Gdk.KEY_Escape && execAsync("astal close logout-menu") }, child: new Widget.EventBox({ className: "logout-menu", onClick: () => execAsync("astal close logout-menu"), child: new Widget.Box({ expand: true, orientation: Gtk.Orientation.VERTICAL, children: [ new Widget.Box({ className: "top", expand: false, orientation: Gtk.Orientation.VERTICAL, valign: Gtk.Align.START, children: [ new Widget.Label({ className: "time", label: getDateTime().as((dateTime: GLib.DateTime) => dateTime.format("%H:%M")) } as Widget.LabelProps), new Widget.Label({ className: "date", label: getDateTime().as((dateTime: GLib.DateTime) => dateTime.format("%A, %B %d %Y")) } as Widget.LabelProps) ] } as Widget.BoxProps), new Widget.Box({ className: "button-row", homogeneous: true, expand: true, valign: Gtk.Align.CENTER, children: [ new Widget.Button({ className: "poweroff nf", label: "󰐥", onClick: () => execAsync("systemctl poweroff") } as Widget.ButtonProps), new Widget.Button({ className: "reboot nf", label: "󰜉", onClick: () => execAsync("systemctl reboot") } as Widget.ButtonProps), new Widget.Button({ className: "suspend nf", label: "󰤄", onClick: () => execAsync("systemctl suspend") } as Widget.ButtonProps), new Widget.Button({ className: "logout nf", label: "󰗽", onClick: () => execAsync("astal close logout-menu && bash -c 'loginctl terminate-user $USER'") } as Widget.ButtonProps), ] } as Widget.BoxProps) ] }) } as Widget.EventBoxProps) } as Widget.WindowProps);