Compare commits

...

2 commits

4 changed files with 67 additions and 86 deletions

View file

@ -63,14 +63,6 @@ M.BarSection {
onTriggered: proc.running = true onTriggered: proc.running = true
} }
Process {
id: toggle
property string cmd: ""
command: ["bluetoothctl", "power", cmd]
onRunningChanged: if (!running && cmd !== "")
proc.running = true
}
M.BarIcon { M.BarIcon {
icon: "\uF294" icon: "\uF294"
color: root.state === "off" ? M.Theme.base04 : root.accentColor color: root.state === "off" ? M.Theme.base04 : root.accentColor
@ -84,31 +76,13 @@ M.BarSection {
required property var bar required property var bar
TapHandler { readonly property bool _anyHover: root._hovered || bluetoothMenu.panelHovered
acceptedButtons: Qt.LeftButton
cursorShape: Qt.PointingHandCursor
onTapped: {
menuLoader.active = !menuLoader.active;
M.FlyoutState.visible = false;
}
}
TapHandler { M.BluetoothMenu {
acceptedButtons: Qt.RightButton id: bluetoothMenu
onTapped: { showPanel: root._anyHover
toggle.cmd = root.state === "off" ? "on" : "off"; screen: root.bar.screen
toggle.running = true; anchorItem: root
} accentColor: root.accentColor
}
LazyLoader {
id: menuLoader
active: false
M.BluetoothMenu {
accentColor: root.accentColor
screen: root.bar.screen
anchorX: root.mapToGlobal(root.width / 2, 0).x - (QsWindow.window?.screen?.x ?? 0)
onDismissed: menuLoader.active = false
}
} }
} }

View file

@ -6,15 +6,18 @@ import "." as M
M.HoverPanel { M.HoverPanel {
id: menuWindow id: menuWindow
popupMode: true
contentWidth: 250 contentWidth: 250
panelNamespace: "nova-bluetooth"
onVisibleChanged: if (visible)
scanner.running = true
property var _devices: [] property var _devices: []
property bool _btEnabled: true property bool _btEnabled: true
property Process _scanner: Process { property Process _scanner: Process {
id: scanner id: scanner
running: true running: false
command: ["sh", "-c", "bluetoothctl show 2>/dev/null | awk '/Powered:/{print $2; exit}';" + "echo '---DEVICES---';" + "bluetoothctl devices Paired 2>/dev/null | while read -r _ mac name; do " + "info=$(bluetoothctl info \"$mac\" 2>/dev/null); " + "conn=$(echo \"$info\" | grep -c 'Connected: yes'); " + "bat=$(echo \"$info\" | awk -F'[(): ]' '/Battery Percentage/{for(i=1;i<=NF;i++) if($i+0==$i && $i!=\"\") print $i}'); " + "echo \"$mac:$conn:${bat:-}:$name\"; " + "done"] command: ["sh", "-c", "bluetoothctl show 2>/dev/null | awk '/Powered:/{print $2; exit}';" + "echo '---DEVICES---';" + "bluetoothctl devices Paired 2>/dev/null | while read -r _ mac name; do " + "info=$(bluetoothctl info \"$mac\" 2>/dev/null); " + "conn=$(echo \"$info\" | grep -c 'Connected: yes'); " + "bat=$(echo \"$info\" | awk -F'[(): ]' '/Battery Percentage/{for(i=1;i<=NF;i++) if($i+0==$i && $i!=\"\") print $i}'); " + "echo \"$mac:$conn:${bat:-}:$name\"; " + "done"]
stdout: StdioCollector { stdout: StdioCollector {
onStreamFinished: { onStreamFinished: {

View file

@ -10,6 +10,5 @@ M.BarLabel {
font.pixelSize: M.Theme.fontSize + 1 font.pixelSize: M.Theme.fontSize + 1
label: Qt.formatDateTime(clock.date, "ddd, dd. MMM HH:mm") label: Qt.formatDateTime(clock.date, "ddd, dd. MMM HH:mm")
minText: "Mi., 00. Sep. 00:00"
tooltip: Qt.formatDateTime(clock.date, "dddd, dd. MMMM yyyy\nHH:mm:ss") tooltip: Qt.formatDateTime(clock.date, "dddd, dd. MMMM yyyy\nHH:mm:ss")
} }

View file

@ -195,65 +195,70 @@ M.BarSection {
id: deviceList id: deviceList
width: parent.width width: parent.width
// Output devices // Output devices only shown when more than one exists
Rectangle { Column {
width: parent.width - 16 visible: root._sinkList.length > 1
height: 1
anchors.horizontalCenter: parent.horizontalCenter
color: M.Theme.base03
}
Text {
width: parent.width width: parent.width
height: 24
verticalAlignment: Text.AlignVCenter
leftPadding: 12
text: "Output Devices"
color: M.Theme.base04
font.pixelSize: M.Theme.fontSize - 1
font.family: M.Theme.fontFamily
}
Repeater { Rectangle {
model: root._sinkList width: parent.width - 16
height: 1
anchors.horizontalCenter: parent.horizontalCenter
color: M.Theme.base03
}
delegate: Item { Text {
required property var modelData width: parent.width
height: 24
verticalAlignment: Text.AlignVCenter
leftPadding: 12
text: "Output Devices"
color: M.Theme.base04
font.pixelSize: M.Theme.fontSize - 1
font.family: M.Theme.fontFamily
}
width: deviceList.width Repeater {
height: 28 model: root._sinkList
readonly property bool _active: modelData === root.sink delegate: Item {
required property var modelData
Rectangle { width: deviceList.width
anchors.fill: parent height: 28
anchors.leftMargin: 4
anchors.rightMargin: 4
color: deviceHover.hovered ? M.Theme.base02 : "transparent"
radius: M.Theme.radius
}
Text { readonly property bool _active: modelData === root.sink
anchors.left: parent.left
anchors.leftMargin: 12
anchors.right: parent.right
anchors.rightMargin: 12
anchors.verticalCenter: parent.verticalCenter
text: modelData.description || modelData.name || "Unknown"
color: parent._active ? root.accentColor : M.Theme.base05
font.pixelSize: M.Theme.fontSize
font.family: M.Theme.fontFamily
font.bold: parent._active
elide: Text.ElideRight
}
HoverHandler { Rectangle {
id: deviceHover anchors.fill: parent
cursorShape: Qt.PointingHandCursor anchors.leftMargin: 4
} anchors.rightMargin: 4
color: deviceHover.hovered ? M.Theme.base02 : "transparent"
radius: M.Theme.radius
}
TapHandler { Text {
onTapped: Pipewire.preferredDefaultAudioSink = modelData anchors.left: parent.left
anchors.leftMargin: 12
anchors.right: parent.right
anchors.rightMargin: 12
anchors.verticalCenter: parent.verticalCenter
text: modelData.description || modelData.name || "Unknown"
color: parent._active ? root.accentColor : M.Theme.base05
font.pixelSize: M.Theme.fontSize
font.family: M.Theme.fontFamily
font.bold: parent._active
elide: Text.ElideRight
}
HoverHandler {
id: deviceHover
cursorShape: Qt.PointingHandCursor
}
TapHandler {
onTapped: Pipewire.preferredDefaultAudioSink = modelData
}
} }
} }
} }