nixos-configs/devices/wim/config/ags/js/notifications/base.js

274 lines
8.7 KiB
JavaScript
Raw Normal View History

import Applications from 'resource:///com/github/Aylur/ags/service/applications.js';
import Hyprland from 'resource:///com/github/Aylur/ags/service/hyprland.js';
import Notifications from 'resource:///com/github/Aylur/ags/service/notifications.js';
import Variable from 'resource:///com/github/Aylur/ags/variable.js';
import { Box, Icon, Label, Button } from 'resource:///com/github/Aylur/ags/widget.js';
import { lookUpIcon } from 'resource:///com/github/Aylur/ags/utils.js';
2023-12-20 03:45:05 -05:00
const { GLib } = imports.gi;
2023-12-20 17:14:07 -05:00
/** @typedef {import('types/service/notifications').Notification} Notification */
/** @param {number} time */
const setTime = (time) => {
return GLib.DateTime
.new_from_unix_local(time)
.format('%H:%M');
};
2023-12-20 17:14:07 -05:00
/** @param {import('types/widgets/eventbox').default} box */
const getDragState = (box) => box.get_parent()?.get_parent()
// @ts-expect-error
?.get_parent()?.get_parent()?.get_parent()?.attribute.dragging;
import Gesture from './gesture.js';
import CursorBox from '../misc/cursorbox.js';
2023-12-20 17:14:07 -05:00
/** @param {Notification} notif */
const NotificationIcon = (notif) => {
2023-12-20 17:14:07 -05:00
/** @type function(import('types/widgets/eventbox').default):void */
let iconCmd = () => {/**/};
2023-12-20 17:14:07 -05:00
if (notif._appEntry && Applications.query(notif._appEntry).length > 0) {
const app = Applications.query(notif._appEntry)[0];
let wmClass = app.app.get_string('StartupWMClass');
2023-12-20 17:14:07 -05:00
if (app.app?.get_filename()?.includes('discord')) {
wmClass = 'discord';
}
if (wmClass != null) {
iconCmd = (box) => {
if (!getDragState(box)) {
if (wmClass === 'thunderbird') {
Hyprland.sendMessage('dispatch ' +
'togglespecialworkspace thunder');
}
else if (wmClass === 'Spotify') {
Hyprland.sendMessage('dispatch ' +
'togglespecialworkspace spot');
}
else {
2023-12-20 17:14:07 -05:00
Hyprland.sendMessage('j/clients').then((msg) => {
/** @type {Array<import('types/service/hyprland').Client>} */
const clients = JSON.parse(msg);
const classes = [];
2023-12-20 17:14:07 -05:00
for (const key of clients) {
if (key.class) {
classes.push(key.class);
}
}
2023-12-20 17:14:07 -05:00
if (wmClass && classes.includes(wmClass)) {
Hyprland.sendMessage('dispatch ' +
`focuswindow ^(${wmClass})`);
}
else {
Hyprland.sendMessage('[[BATCH]] ' +
'dispatch workspace empty; ' +
`dispatch exec sh -c ${app.executable}
`);
}
});
}
globalThis.closeAll();
}
};
}
}
if (notif.image) {
return CursorBox({
on_primary_click_release: iconCmd,
child: Box({
vpack: 'start',
hexpand: false,
2023-12-20 17:14:07 -05:00
class_name: 'icon img',
css: `
background-image: url("${notif.image}");
background-size: contain;
background-repeat: no-repeat;
background-position: center;
min-width: 78px;
min-height: 78px;
`,
}),
});
}
let icon = 'dialog-information-symbolic';
2023-12-20 17:14:07 -05:00
if (lookUpIcon(notif._appIcon)) {
icon = notif._appIcon;
}
2023-12-20 17:14:07 -05:00
if (notif._appEntry && lookUpIcon(notif._appEntry)) {
icon = notif._appEntry;
}
return CursorBox({
on_primary_click_release: iconCmd,
child: Box({
vpack: 'start',
hexpand: false,
2023-12-20 17:14:07 -05:00
class_name: 'icon',
css: `
min-width: 78px;
min-height: 78px;
`,
children: [Icon({
icon, size: 58,
hpack: 'center',
hexpand: true,
vpack: 'center',
vexpand: true,
})],
}),
});
};
// Make a variable to connect to for Widgets
// to know when there are notifs or not
export const HasNotifs = Variable(false);
2023-12-20 17:14:07 -05:00
/**
* @param {{
* notif: Notification
* slideIn?: 'Left'|'Right'
* command?: () => void
* }} o
*/
export const Notification = ({
notif,
slideIn = 'Left',
command = () => { /**/ },
2023-12-20 17:14:07 -05:00
}) => {
if (!notif) {
return;
}
const BlockedApps = [
'Spotify',
];
2023-12-20 17:14:07 -05:00
if (BlockedApps.find((app) => app === notif._appName)) {
notif.close();
return;
}
HasNotifs.value = Notifications.notifications.length > 0;
// Init notif
const notifWidget = Gesture({
command,
slideIn,
id: notif.id,
});
// Add body to notif
2023-12-20 17:14:07 -05:00
// @ts-expect-error
notifWidget.child.add(Box({
2023-12-20 17:14:07 -05:00
class_name: `notification ${notif.urgency}`,
vexpand: false,
// Notification
child: Box({
vertical: true,
children: [
// Content
Box({
children: [
NotificationIcon(notif),
2023-12-20 17:14:07 -05:00
Box({
hexpand: true,
vertical: true,
children: [
// Top of Content
Box({
children: [
// Title
Label({
2023-12-20 17:14:07 -05:00
class_name: 'title',
xalign: 0,
justification: 'left',
hexpand: true,
2023-12-20 17:14:07 -05:00
max_width_chars: 24,
truncate: 'end',
wrap: true,
label: notif.summary,
2023-12-20 17:14:07 -05:00
use_markup: notif.summary
.startsWith('<'),
}),
// Time
Label({
2023-12-20 17:14:07 -05:00
class_name: 'time',
vpack: 'start',
label: setTime(notif.time),
}),
// Close button
CursorBox({
child: Button({
2023-12-20 17:14:07 -05:00
class_name: 'close-button',
vpack: 'start',
2023-12-20 17:14:07 -05:00
on_primary_click_release: () =>
notif.close(),
child: Icon('window-close' +
'-symbolic'),
}),
}),
],
}),
// Description
Label({
2023-12-20 17:14:07 -05:00
class_name: 'description',
hexpand: true,
2023-12-20 17:14:07 -05:00
use_markup: true,
xalign: 0,
justification: 'left',
label: notif.body,
wrap: true,
}),
],
}),
],
}),
// Actions
Box({
2023-12-20 17:14:07 -05:00
class_name: 'actions',
children: notif.actions.map((action) => Button({
2023-12-20 17:14:07 -05:00
class_name: 'action-button',
hexpand: true,
2023-12-20 17:14:07 -05:00
on_primary_click_release: () => notif.invoke(action.id),
child: Label(action.label),
})),
}),
],
}),
}));
return notifWidget;
};