49 lines
1.3 KiB
JavaScript
49 lines
1.3 KiB
JavaScript
import GLib from "gi://GLib";
|
|
import { NotificationIcon } from "./icon.js";
|
|
import { notifHasImg } from "../../utils.js";
|
|
|
|
const time = (time, format = "%I:%M %p") =>
|
|
GLib.DateTime.new_from_unix_local(time).format(format);
|
|
|
|
export const Header = (notif) => {
|
|
return Widget.Box({
|
|
vertical: false,
|
|
hexpand: true,
|
|
children: [
|
|
Widget.Box({
|
|
class_name: "notification-card-header menu",
|
|
hpack: "start",
|
|
children: [NotificationIcon(notif)],
|
|
}),
|
|
Widget.Box({
|
|
class_name: "notification-card-header menu",
|
|
hexpand: true,
|
|
vpack: "start",
|
|
children: [
|
|
Widget.Label({
|
|
class_name: "notification-card-header-label menu",
|
|
hpack: "start",
|
|
hexpand: true,
|
|
vexpand: true,
|
|
max_width_chars: !notifHasImg(notif) ? 34 : 22,
|
|
truncate: "end",
|
|
wrap: true,
|
|
label: notif["summary"],
|
|
}),
|
|
],
|
|
}),
|
|
Widget.Box({
|
|
class_name: "notification-card-header menu",
|
|
hpack: "end",
|
|
vpack: "start",
|
|
hexpand: true,
|
|
child: Widget.Label({
|
|
vexpand: true,
|
|
class_name: "notification-time",
|
|
label: time(notif.time),
|
|
}),
|
|
}),
|
|
],
|
|
});
|
|
};
|