lux-shell/modules/bar/components/Power.qml
2025-09-04 14:56:53 -04:00

59 lines
1.8 KiB
QML

import qs.components
import qs.config
import qs.constants
import QtQuick
import QtQuick.Layouts
import Quickshell.Services.UPower
StyledButton {
id: root
property UPowerDevice laptopBattery: UPower.devices.values.find(device => device.isLaptopBattery) ?? null
property bool isCritical: laptopBattery?.percentage < 0.10
contentItem: RowLayout {
spacing: 4
LucideIcon {
Layout.alignment: Qt.AlignVCenter
color: {
if (root.isCritical) {
return Theme.palette.error;
}
if (root.hovered) {
return Theme.palette.primarycontent;
}
return Theme.palette.basecontent;
}
font.pixelSize: 16
text: {
if (root.laptopBattery?.state == UPowerDeviceState.Charging) {
return Icons.batteryCharging;
}
if (root.isCritical) {
return Icons.batteryWarning;
}
if (root.laptopBattery?.percentage < 0.33) {
return Icons.batteryLow;
}
if (root.laptopBattery?.percentage < 0.66) {
return Icons.batteryMedium;
}
return Icons.batteryFull;
}
}
StyledText {
Layout.alignment: Qt.AlignVCenter
color: {
if (root.isCritical) {
return Theme.palette.error;
}
if (root.hovered) {
return Theme.palette.primarycontent;
}
return Theme.palette.basecontent;
}
text: `${(root.laptopBattery?.percentage.toFixed(2) * 100)}%`
}
}
visible: laptopBattery
}