mirror of
https://github.com/AvengeMedia/DankMaterialShell.git
synced 2025-12-07 05:55:37 -05:00
208 lines
6.7 KiB
QML
208 lines
6.7 KiB
QML
import QtQuick
|
|
import Quickshell
|
|
import Quickshell.Io
|
|
pragma Singleton
|
|
pragma ComponentBehavior
|
|
|
|
Singleton {
|
|
id: root
|
|
|
|
property bool brightnessAvailable: devices.length > 0
|
|
property var devices: []
|
|
property string currentDevice: ""
|
|
property int brightnessLevel: 50
|
|
property int maxBrightness: 100
|
|
property bool brightnessInitialized: false
|
|
|
|
signal brightnessChanged()
|
|
|
|
function setBrightnessInternal(percentage, device) {
|
|
const clampedValue = Math.max(1, Math.min(100, percentage));
|
|
brightnessLevel = clampedValue;
|
|
if (device)
|
|
brightnessSetProcess.command = ["brightnessctl", "-d", device, "set", clampedValue + "%"];
|
|
else
|
|
brightnessSetProcess.command = ["brightnessctl", "set", clampedValue + "%"];
|
|
brightnessSetProcess.running = true;
|
|
}
|
|
|
|
function setBrightness(percentage, device) {
|
|
setBrightnessInternal(percentage, device);
|
|
brightnessChanged();
|
|
}
|
|
|
|
function setCurrentDevice(deviceName) {
|
|
if (currentDevice === deviceName)
|
|
return ;
|
|
|
|
currentDevice = deviceName;
|
|
brightnessGetProcess.command = ["brightnessctl", "-m", "-d", deviceName, "get"];
|
|
brightnessGetProcess.running = true;
|
|
}
|
|
|
|
function refreshDevices() {
|
|
deviceListProcess.running = true;
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
refreshDevices();
|
|
}
|
|
|
|
Process {
|
|
id: deviceListProcess
|
|
|
|
command: ["brightnessctl", "-m", "-l"]
|
|
onExited: function(exitCode) {
|
|
if (exitCode !== 0) {
|
|
console.warn("BrightnessService: Failed to list devices:", exitCode);
|
|
brightnessAvailable = false;
|
|
}
|
|
}
|
|
|
|
stdout: StdioCollector {
|
|
onStreamFinished: {
|
|
if (!text.trim()) {
|
|
console.warn("BrightnessService: No devices found");
|
|
return ;
|
|
}
|
|
const lines = text.trim().split("\n");
|
|
const newDevices = [];
|
|
for (const line of lines) {
|
|
const parts = line.split(",");
|
|
if (parts.length >= 5)
|
|
newDevices.push({
|
|
"name": parts[0],
|
|
"class": parts[1],
|
|
"current": parseInt(parts[2]),
|
|
"percentage": parseInt(parts[3]),
|
|
"max": parseInt(parts[4])
|
|
});
|
|
|
|
}
|
|
newDevices.sort((a, b) => {
|
|
if (a.class === "backlight" && b.class !== "backlight")
|
|
return -1;
|
|
|
|
if (a.class !== "backlight" && b.class === "backlight")
|
|
return 1;
|
|
|
|
return a.name.localeCompare(b.name);
|
|
});
|
|
devices = newDevices;
|
|
if (devices.length > 0 && !currentDevice)
|
|
setCurrentDevice(devices[0].name);
|
|
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
Process {
|
|
id: brightnessSetProcess
|
|
|
|
running: false
|
|
onExited: function(exitCode) {
|
|
if (exitCode !== 0)
|
|
console.warn("BrightnessService: Failed to set brightness:", exitCode);
|
|
|
|
}
|
|
}
|
|
|
|
Process {
|
|
id: brightnessGetProcess
|
|
|
|
running: false
|
|
onExited: function(exitCode) {
|
|
if (exitCode !== 0)
|
|
console.warn("BrightnessService: Failed to get brightness:", exitCode);
|
|
|
|
}
|
|
|
|
stdout: StdioCollector {
|
|
onStreamFinished: {
|
|
if (!text.trim())
|
|
return ;
|
|
|
|
const parts = text.trim().split(",");
|
|
if (parts.length >= 5) {
|
|
const current = parseInt(parts[2]);
|
|
const max = parseInt(parts[4]);
|
|
maxBrightness = max;
|
|
brightnessLevel = Math.round((current / max) * 100);
|
|
brightnessInitialized = true;
|
|
console.log("BrightnessService: Device", currentDevice, "brightness:", brightnessLevel + "%");
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
// IPC Handler for external control
|
|
IpcHandler {
|
|
function set(percentage: string, device: string) : string {
|
|
if (!root.brightnessAvailable)
|
|
return "Brightness control not available";
|
|
|
|
const value = parseInt(percentage);
|
|
const clampedValue = Math.max(1, Math.min(100, value));
|
|
const targetDevice = device || "";
|
|
root.setBrightness(clampedValue, targetDevice);
|
|
if (targetDevice)
|
|
return "Brightness set to " + clampedValue + "% on " + targetDevice;
|
|
else
|
|
return "Brightness set to " + clampedValue + "%";
|
|
}
|
|
|
|
function increment(step: string, device: string) : string {
|
|
if (!root.brightnessAvailable)
|
|
return "Brightness control not available";
|
|
|
|
const currentLevel = root.brightnessLevel;
|
|
const stepValue = parseInt(step || "10");
|
|
const newLevel = Math.max(1, Math.min(100, currentLevel + stepValue));
|
|
const targetDevice = device || "";
|
|
root.setBrightness(newLevel, targetDevice);
|
|
if (targetDevice)
|
|
return "Brightness increased to " + newLevel + "% on " + targetDevice;
|
|
else
|
|
return "Brightness increased to " + newLevel + "%";
|
|
}
|
|
|
|
function decrement(step: string, device: string) : string {
|
|
if (!root.brightnessAvailable)
|
|
return "Brightness control not available";
|
|
|
|
const currentLevel = root.brightnessLevel;
|
|
const stepValue = parseInt(step || "10");
|
|
const newLevel = Math.max(1, Math.min(100, currentLevel - stepValue));
|
|
const targetDevice = device || "";
|
|
root.setBrightness(newLevel, targetDevice);
|
|
if (targetDevice)
|
|
return "Brightness decreased to " + newLevel + "% on " + targetDevice;
|
|
else
|
|
return "Brightness decreased to " + newLevel + "%";
|
|
}
|
|
|
|
function status() : string {
|
|
if (!root.brightnessAvailable)
|
|
return "Brightness control not available";
|
|
|
|
return "Device: " + root.currentDevice + " - Brightness: " + root.brightnessLevel + "%";
|
|
}
|
|
|
|
function list() : string {
|
|
if (!root.brightnessAvailable)
|
|
return "No brightness devices available";
|
|
|
|
let result = "Available devices:\n";
|
|
for (const device of root.devices) {
|
|
result += device.name + " (" + device.class + ")\n";
|
|
}
|
|
return result;
|
|
}
|
|
|
|
target: "brightness"
|
|
}
|
|
|
|
}
|