add tray items, no menu
This commit is contained in:
parent
f6eab13094
commit
0d9392b744
6 changed files with 131 additions and 0 deletions
|
|
@ -12,6 +12,7 @@ Singleton {
|
||||||
property Mpris mpris: Mpris {}
|
property Mpris mpris: Mpris {}
|
||||||
property Clock clock: Clock {}
|
property Clock clock: Clock {}
|
||||||
property Workspace workspace: Workspace {}
|
property Workspace workspace: Workspace {}
|
||||||
|
property Tray tray: Tray {}
|
||||||
|
|
||||||
component Bar: QtObject {
|
component Bar: QtObject {
|
||||||
id: bar
|
id: bar
|
||||||
|
|
@ -53,4 +54,15 @@ Singleton {
|
||||||
property int verticalPadding: 6
|
property int verticalPadding: 6
|
||||||
property int horizontalPadding: 7
|
property int horizontalPadding: 7
|
||||||
}
|
}
|
||||||
|
|
||||||
|
component Tray: QtObject {
|
||||||
|
id: tray
|
||||||
|
|
||||||
|
property int spacing: 5
|
||||||
|
property int iconSize: 18
|
||||||
|
property int width: 30
|
||||||
|
property int height: 30
|
||||||
|
property int verticalPadding: 6
|
||||||
|
property int horizontalPadding: 7
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@ import Quickshell
|
||||||
import "components"
|
import "components"
|
||||||
import "components/hyprland"
|
import "components/hyprland"
|
||||||
import "components/mpris"
|
import "components/mpris"
|
||||||
|
import "components/tray"
|
||||||
import "../../config/"
|
import "../../config/"
|
||||||
|
|
||||||
Scope {
|
Scope {
|
||||||
|
|
@ -57,6 +58,10 @@ Scope {
|
||||||
Workspaces {
|
Workspaces {
|
||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Tray {
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Row {
|
Row {
|
||||||
|
|
|
||||||
15
modules/bar/components/tray/Tray.qml
Normal file
15
modules/bar/components/tray/Tray.qml
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
import QtQuick
|
||||||
|
import Quickshell.Services.SystemTray
|
||||||
|
import "../../../../config/"
|
||||||
|
|
||||||
|
Row {
|
||||||
|
id: root
|
||||||
|
|
||||||
|
spacing: Dimensions.tray.spacing
|
||||||
|
|
||||||
|
Repeater {
|
||||||
|
model: SystemTray.items
|
||||||
|
|
||||||
|
TrayItem {}
|
||||||
|
}
|
||||||
|
}
|
||||||
57
modules/bar/components/tray/TrayItem.qml
Normal file
57
modules/bar/components/tray/TrayItem.qml
Normal file
|
|
@ -0,0 +1,57 @@
|
||||||
|
import QtQuick
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import Quickshell
|
||||||
|
import Quickshell.Services.SystemTray
|
||||||
|
import Quickshell.Widgets
|
||||||
|
import "../../../../config/"
|
||||||
|
import "../../../../styled/"
|
||||||
|
import "menu/"
|
||||||
|
|
||||||
|
Loader {
|
||||||
|
required property SystemTrayItem modelData
|
||||||
|
|
||||||
|
active: modelData.hasMenu
|
||||||
|
|
||||||
|
onLoaded: console.log(modelData.icon)
|
||||||
|
sourceComponent: item
|
||||||
|
property Component item: Clickable {
|
||||||
|
id: clickable
|
||||||
|
|
||||||
|
property bool menuOpen
|
||||||
|
|
||||||
|
width: Dimensions.tray.width
|
||||||
|
height: Dimensions.tray.height
|
||||||
|
|
||||||
|
onClicked: menuOpen = !menuOpen
|
||||||
|
|
||||||
|
IconImage {
|
||||||
|
id: icon
|
||||||
|
anchors.margins: 6
|
||||||
|
anchors.fill: parent
|
||||||
|
asynchronous: true
|
||||||
|
source: {
|
||||||
|
let icon = modelData.icon;
|
||||||
|
if (icon.includes("?path=")) {
|
||||||
|
const [name, path] = icon.split("?path=");
|
||||||
|
icon = `file://${path}/${name.slice(name.lastIndexOf("/") + 1)}`;
|
||||||
|
}
|
||||||
|
return icon;
|
||||||
|
}
|
||||||
|
anchors.centerIn: parent
|
||||||
|
}
|
||||||
|
|
||||||
|
// Loader {
|
||||||
|
// active: menuOpen && modelData.hasMenu
|
||||||
|
//
|
||||||
|
// property Component menu: Menu {
|
||||||
|
// menu: modelData.menu
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
PopupWindow {
|
||||||
|
|
||||||
|
Menu {
|
||||||
|
menu: modelData.menu
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
24
modules/bar/components/tray/menu/Menu.qml
Normal file
24
modules/bar/components/tray/menu/Menu.qml
Normal file
|
|
@ -0,0 +1,24 @@
|
||||||
|
import QtQuick
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import Quickshell
|
||||||
|
import "../../../../../styled/"
|
||||||
|
|
||||||
|
ColumnLayout {
|
||||||
|
property QsMenuOpener menu
|
||||||
|
|
||||||
|
Repeater {
|
||||||
|
model: modelData.children
|
||||||
|
|
||||||
|
Loader {
|
||||||
|
id: loader
|
||||||
|
required property QsMenuEntry modelData
|
||||||
|
|
||||||
|
active: modelData.enabled
|
||||||
|
|
||||||
|
sourceComponent: menuItem
|
||||||
|
property Component menuItem: MenuItem {
|
||||||
|
menuEntry: loader.modelData
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
18
modules/bar/components/tray/menu/MenuItem.qml
Normal file
18
modules/bar/components/tray/menu/MenuItem.qml
Normal file
|
|
@ -0,0 +1,18 @@
|
||||||
|
import QtQuick
|
||||||
|
import QtQuick.Layouts
|
||||||
|
import Quickshell
|
||||||
|
import "../../../../../styled/"
|
||||||
|
|
||||||
|
Clickable {
|
||||||
|
id: item
|
||||||
|
property QsMenuEntry menuEntry
|
||||||
|
|
||||||
|
implicitWidth: text.width
|
||||||
|
|
||||||
|
Text {
|
||||||
|
id: text
|
||||||
|
text: item.menuEntry.text
|
||||||
|
|
||||||
|
padding: 8
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Reference in a new issue