Battery widget #7

Merged
Zacharias-Brohn merged 8 commits from battery-widget into main 2026-02-11 16:49:52 +01:00
7 changed files with 84 additions and 14 deletions
-13
View File
@@ -1,13 +0,0 @@
import QtQuick
import qs.Config
import qs.Modules
import qs.Components
CustomText {
text: Time.time
color: Config.useDynamicColors ? DynamicColors.palette.m3tertiary : "white"
Behavior on color {
CAnim {}
}
}
+4
View File
@@ -36,6 +36,10 @@ JsonObject {
id: "tray", id: "tray",
enabled: true enabled: true
}, },
{
id: "upower",
enabled: false
},
{ {
id: "clock", id: "clock",
enabled: true enabled: true
+13
View File
@@ -0,0 +1,13 @@
pragma Singleton
import Quickshell
import Quickshell.Services.UPower
Singleton {
id: root
readonly property list<UPowerDevice> devices: UPower.devices.values
readonly property bool onBattery: UPower.onBattery
readonly property UPowerDevice displayDevice: UPower.displayDevice
}
+7
View File
@@ -9,6 +9,7 @@ import qs.Config
import qs.Helpers import qs.Helpers
import qs.Daemons import qs.Daemons
import qs.Modules.Polkit import qs.Modules.Polkit
import qs.Modules.UPower
RowLayout { RowLayout {
id: root id: root
@@ -160,6 +161,12 @@ RowLayout {
} }
} }
} }
DelegateChoice {
roleValue: "upower"
delegate: WrappedLoader {
sourceComponent: UPowerWidget {}
}
}
} }
} }
+1 -1
View File
@@ -19,7 +19,7 @@ Item {
anchors.bottomMargin: 3 anchors.bottomMargin: 3
radius: 4 radius: 4
color: "transparent" color: "transparent"
Text { CustomText {
id: timeText id: timeText
anchors.centerIn: parent anchors.centerIn: parent
+51
View File
@@ -0,0 +1,51 @@
import Quickshell
import Quickshell.Services.UPower
import QtQuick
import QtQuick.Layouts
import qs.Components
import qs.Config
import qs.Helpers as Helpers
import qs.Modules
Item {
id: root
implicitWidth: layout.childrenRect.width
anchors.top: parent.top
anchors.bottom: parent.bottom
RowLayout {
id: layout
anchors.centerIn: parent
MaterialIcon {
animate: true
Layout.alignment: Qt.AlignVCenter
text: {
if (!Helpers.UPower.displayDevice.isLaptopBattery) {
if (PowerProfiles.profile === PowerProfile.PowerSaver)
return "energy_savings_leaf";
if (PowerProfiles.profile === PowerProfile.Performance)
return "rocket_launch";
return "balance";
}
const perc = Helpers.UPower.displayDevice.percentage;
const charging = [UPowerDeviceState.Charging, UPowerDeviceState.FullyCharged, UPowerDeviceState.PendingCharge].includes(Helpers.UPower.displayDevice.state);
if (perc === 1)
return charging ? "battery_charging_full" : "battery_full";
let level = Math.floor(perc * 7);
if (charging && (level === 4 || level === 1))
level--;
return charging ? `battery_charging_${(level + 3) * 10}` : `battery_${level}_bar`;
}
color: !Helpers.UPower.onBattery || UPower.displayDevice.percentage > 0.2 ? DynamicColors.palette.m3secondary : DynamicColors.palette.m3error
fill: 1
}
CustomText {
Layout.alignment: Qt.AlignVCenter
text: Helpers.UPower.displayDevice.isLaptopBattery ? qsTr("%1%").arg(Math.round(UPower.displayDevice.percentage * 100)) : qsTr("NaN")
}
}
}
+8
View File
@@ -0,0 +1,8 @@
#!/usr/bin/env bash
main() {
if [[ ]]
}
main "$@"