lux-shell/modules/bar/components/Power.qml
2025-09-04 10:20:17 -04:00

60 lines
1.8 KiB
QML

import qs.components
import qs.config
import qs.constants
import qs.widgets
import QtQuick
import QtQuick.Layouts
import Quickshell.Services.UPower
StyledButton {
id: root
property UPowerDevice laptopBattery: UPower.devices.values.find(device => device.isLaptopBattery)
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
}