weird bluetooth hover thing

This commit is contained in:
2026-06-29 18:57:03 +01:00
parent 8c7ecc1b14
commit 8abc848325
4 changed files with 37 additions and 7 deletions

View File

@@ -182,7 +182,6 @@ Container {
onTriggered: { onTriggered: {
if (!root.hover.hovered) { if (!root.hover.hovered) {
console.log("some");
root.state = ""; root.state = "";
} }
} }

View File

@@ -10,13 +10,16 @@ import "Bluetooth"
Container { Container {
id: root id: root
property bool hidden: true
animOffset: 200 animOffset: 200
boxColor: Colors.peach boxColor: Colors.peach
boxHeight: 25 boxHeight: 25
boxWidth: 30 boxWidth: 30
defaultItem: icon defaultItem: icon
exclusiveToScreen: true exclusiveToScreen: true
forceHidden: BluetoothManager.getConnected() forceHidden: (hidden == true || BluetoothManager.getConnected())
hoverableWhenHidden: true
state: "" state: ""
states: [ states: [
@@ -31,6 +34,9 @@ Container {
StateChangeScript { StateChangeScript {
script: { script: {
root.stack.replace(icon); root.stack.replace(icon);
if (BluetoothManager.getConnected() == false) {
root.hidden = false;
}
} }
} }
}, },
@@ -46,20 +52,43 @@ Container {
StateChangeScript { StateChangeScript {
script: { script: {
root.stack.replace(expanded); root.stack.replace(expanded);
root.hidden = false;
} }
} }
} }
] ]
hover.onHoveredChanged: hover.hovered == false ? state = "" : undefined hover.onHoveredChanged: {
if (hover.hovered == false) {
root.state = "";
hoverIntervalTimer.start();
} else {
root.hidden = false;
hoverIntervalTimer.start();
}
}
tap.onTapped: state = "expanded" tap.onTapped: state = "expanded"
Timer {
id: hoverIntervalTimer
interval: 1000
repeat: false
running: false
onTriggered: {
if (root.hover.hovered != true && root.state != "expanded") {
root.hidden = true;
}
}
}
Component { Component {
id: icon id: icon
Item { Item {
CenteredText { CenteredText {
text: "󰂱" text: BluetoothManager.getConnected() == true ? "󰂱" : "󰂲"
} }
} }
} }

View File

@@ -16,8 +16,9 @@ Item {
property double boxWidth: 100 property double boxWidth: 100
readonly property double calculatedTopMargin: { readonly property double calculatedTopMargin: {
if (root.exclusiveToScreen) { if (root.exclusiveToScreen) {
let baseMargin = hoverableWhenHidden == true ? 8 : -4;
if (Hyprland.focusedMonitor != root.exclusiveMonitor || forceHidden == true) { if (Hyprland.focusedMonitor != root.exclusiveMonitor || forceHidden == true) {
return -4 - root.boxHeight - 5; return baseMargin - root.boxHeight - 5;
} else { } else {
return visibleTopMargin; return visibleTopMargin;
} }
@@ -30,6 +31,7 @@ Item {
property bool exclusiveToScreen: false property bool exclusiveToScreen: false
property bool forceHidden: false property bool forceHidden: false
property alias hover: hoverHandler property alias hover: hoverHandler
property bool hoverableWhenHidden: false
property alias rect: container property alias rect: container
property alias stack: containerContent property alias stack: containerContent
property alias tap: tapHandler property alias tap: tapHandler

View File

@@ -14,10 +14,10 @@ Singleton {
for (let device in deviceList) { for (let device in deviceList) {
let currentDevice = deviceList[device]; let currentDevice = deviceList[device];
if (currentDevice.connected == true) { if (currentDevice.connected == true) {
return false; return true;
} }
} }
return true; return false;
} }
function getDevicesList() { function getDevicesList() {