mirror of
https://github.com/Theaninova/TheaninovOS.git
synced 2025-12-12 19:46:20 +00:00
71 lines
1.7 KiB
JavaScript
71 lines
1.7 KiB
JavaScript
import Widget from "resource:///com/github/Aylur/ags/widget.js";
|
|
import icons from "../icons.js";
|
|
import Clock from "../misc/Clock.js";
|
|
import * as vars from "../variables.js";
|
|
import options from "../options.js";
|
|
|
|
/**
|
|
* @param {'cpu' | 'ram' | 'temp'} type
|
|
* @param {string} title
|
|
* @param {string} unit
|
|
*/
|
|
const SysProgress = (type, title, unit) =>
|
|
Widget.Box({
|
|
class_name: `circular-progress-box ${type}`,
|
|
hexpand: true,
|
|
binds: [
|
|
[
|
|
"tooltipText",
|
|
vars[type],
|
|
"value",
|
|
(v) => `${title}: ${Math.floor(v * 100)}${unit}`,
|
|
],
|
|
],
|
|
child: Widget.CircularProgress({
|
|
hexpand: true,
|
|
class_name: `circular-progress ${type}`,
|
|
child: Widget.Icon(icons.system[type]),
|
|
start_at: 0.75,
|
|
binds: [
|
|
["value", vars[type]],
|
|
["rounded", options.radii, "value", (v) => v > 0],
|
|
],
|
|
}),
|
|
});
|
|
|
|
export default () =>
|
|
Widget.Box({
|
|
vertical: true,
|
|
class_name: "datemenu vertical",
|
|
children: [
|
|
Widget.Box({
|
|
class_name: "clock-box",
|
|
vertical: true,
|
|
children: [
|
|
Clock({ format: "%H:%M" }),
|
|
Widget.Label({
|
|
class_name: "uptime",
|
|
binds: [["label", vars.uptime, "value", (t) => `uptime: ${t}`]],
|
|
}),
|
|
],
|
|
}),
|
|
Widget.Box({
|
|
class_name: "calendar",
|
|
children: [
|
|
Widget.Calendar({
|
|
hexpand: true,
|
|
hpack: "center",
|
|
}),
|
|
],
|
|
}),
|
|
Widget.Box({
|
|
class_name: "system-info horizontal",
|
|
children: [
|
|
SysProgress("cpu", "Cpu", "%"),
|
|
SysProgress("ram", "Ram", "%"),
|
|
SysProgress("temp", "Temperature", "°"),
|
|
],
|
|
}),
|
|
],
|
|
});
|