Compare commits

..

2 commits

Author SHA1 Message Date
Benjamin Palko
618fc22e80 allow drawers to close on parent window focus lost 2025-11-10 11:54:25 -05:00
Benjamin Palko
3c3fe368bc simplify tray item 2025-10-28 20:57:58 -04:00
7 changed files with 94 additions and 57 deletions

View file

@ -1,11 +1,46 @@
import qs.config import qs.config
import QtQuick import QtQuick
import QtQuick.Controls import QtQuick.Controls
import Quickshell
import Quickshell.Hyprland
import Quickshell.Widgets
Drawer { Drawer {
id: control id: control
dim: false dim: false
background: Rectangle { property bool focused: false
onVisibleChanged: {
focused = visible;
}
HyprlandFocusGrab {
active: control.focused
windows: [QsWindow.window]
onCleared: {
control.focused = false;
}
}
background: ClippingWrapperRectangle {
margin: 4
Component.onCompleted: {
if (control.edge == Qt.TopEdge) {
radius = 8;
} else if (control.edge == Qt.LeftEdge) {
topRightRadius = 8;
bottomRightRadius = 8;
} else if (control.edge == Qt.RightEdge) {
topLeftRadius = 8;
bottomLeftRadius = 8;
} else if (control.edge == Qt.BottomEdge) {
topLeftRadius = 8;
topRightRadius = 8;
}
}
color: Styling.theme.base300
Rectangle {
Component.onCompleted: { Component.onCompleted: {
if (control.edge == Qt.TopEdge) { if (control.edge == Qt.TopEdge) {
radius = 8; radius = 8;
@ -23,3 +58,4 @@ Drawer {
color: Styling.theme.base100 color: Styling.theme.base100
} }
} }
}

View file

@ -10,7 +10,7 @@ RowLayout {
spacing: 4 spacing: 4
Repeater { Repeater {
model: SystemTray.items model: SystemTray.items.values
Loader { Loader {
id: loader id: loader

View file

@ -5,12 +5,11 @@ import QtQuick
import Quickshell import Quickshell
import Quickshell.Services.SystemTray import Quickshell.Services.SystemTray
import Quickshell.Widgets import Quickshell.Widgets
import "menu/"
StyledIconButton { StyledIconButton {
id: root id: root
property SystemTrayItem trayItem required property SystemTrayItem trayItem
onClicked: menu.toggle() onClicked: menu.toggle()
@ -28,7 +27,7 @@ StyledIconButton {
} }
} }
Menu { TrayMenu {
id: menu id: menu
anchor.item: root anchor.item: root

View file

@ -0,0 +1,49 @@
pragma ComponentBehavior: Bound
import qs.components
import qs.config
import QtQuick
import QtQuick.Layouts
import Quickshell
import Quickshell.Widgets
StyledPopupWindow {
id: window
required property QsMenuOpener menuOpener
content: ColumnLayout {
spacing: 4
Repeater {
model: window.menuOpener.children.values
delegate: Loader {
id: loader
required property QsMenuEntry modelData
active: true
Component.onCompleted: {
console.log(modelData.text);
}
Layout.fillWidth: true
Layout.minimumWidth: 160
sourceComponent: modelData.isSeparator ? menuSeperator : menuItem
property Component menuSeperator: WrapperItem {
margin: 4
Rectangle {
implicitHeight: 2
color: Styling.theme.base200
}
}
property Component menuItem: StyledButton {
text: loader.modelData.text
onClicked: loader.modelData.triggered()
}
}
}
}
}

View file

@ -1,39 +0,0 @@
pragma ComponentBehavior: Bound
import qs.components
import qs.config
import QtQuick
import QtQuick.Layouts
import Quickshell
StyledPopupWindow {
id: window
property QsMenuOpener menuOpener
content: ColumnLayout {
spacing: 8
Repeater {
model: window.menuOpener.children
delegate: Loader {
id: loader
required property QsMenuEntry modelData
active: true
Layout.fillWidth: true
Layout.minimumWidth: 160
sourceComponent: modelData.isSeparator ? menuSeperator : menuItem
property Component menuSeperator: Rectangle {
implicitHeight: 2
color: Styling.theme.base100
}
property Component menuItem: MenuItem {
menuEntry: loader.modelData
}
}
}
}
}

View file

@ -1,12 +0,0 @@
import qs.components
import Quickshell
StyledButton {
id: root
property QsMenuEntry menuEntry
text: root.menuEntry.text
onClicked: menuEntry.triggered()
}

View file

@ -12,6 +12,10 @@ StyledDrawer {
visible: Visibility.dashboard visible: Visibility.dashboard
onFocusedChanged: {
Visibility.dashboard = focused;
}
WrapperItem { WrapperItem {
margin: 32 margin: 32
ColumnLayout { ColumnLayout {