Compare commits

..

3 commits

Author SHA1 Message Date
Benjamin Palko
ad8df5e6a0 decouple clickable from styledlabel 2025-07-23 10:17:56 -04:00
Benjamin Palko
bf55feceb4 make mousearea root of clickable 2025-07-23 10:14:53 -04:00
Benjamin Palko
8ac31838d5 functional tray 2025-07-22 22:56:33 -04:00
8 changed files with 117 additions and 91 deletions

View file

@ -13,6 +13,7 @@ Singleton {
property Clock clock: Clock {} property Clock clock: Clock {}
property Workspace workspace: Workspace {} property Workspace workspace: Workspace {}
property Tray tray: Tray {} property Tray tray: Tray {}
property TrayMenu trayMenu: TrayMenu {}
component Bar: QtObject { component Bar: QtObject {
id: bar id: bar
@ -65,4 +66,14 @@ Singleton {
property int verticalPadding: 6 property int verticalPadding: 6
property int horizontalPadding: 7 property int horizontalPadding: 7
} }
component TrayMenu: QtObject {
id: trayItem
property int fontSize: 10
property int width: 30
property int height: 30
property int verticalPadding: 6
property int horizontalPadding: 7
}
} }

View file

@ -8,7 +8,7 @@ import "../../config/"
Scope { Scope {
PanelWindow { PanelWindow {
id: root id: parentWindow
anchors.top: true anchors.top: true
anchors.left: true anchors.left: true

View file

@ -27,8 +27,14 @@ Loader {
modelData.play(); modelData.play();
} }
} }
onScrolledUp: parent.nextPlayer()
onScrolledDown: parent.previousPlayer() onWheel: event => {
if (event.angleDelta.y > 0) {
parent.nextPlayer();
} else if (event.angleDelta.y < 0) {
parent.previousPlayer();
}
}
StyledText { StyledText {
id: text id: text
@ -44,7 +50,7 @@ Loader {
states: State { states: State {
name: "hovered" name: "hovered"
when: clickable.hovered when: clickable.containsMouse
PropertyChanges { PropertyChanges {
text { text {
color: Theme.palette.base300 color: Theme.palette.base300

View file

@ -10,6 +10,14 @@ Row {
Repeater { Repeater {
model: SystemTray.items model: SystemTray.items
TrayItem {} Loader {
required property SystemTrayItem modelData
active: true
sourceComponent: item
property Component item: TrayItem {
trayItem: modelData
}
}
} }
} }

View file

@ -7,50 +7,62 @@ import "../../../../config/"
import "../../../../styled/" import "../../../../styled/"
import "menu/" import "menu/"
Loader { Clickable {
required property SystemTrayItem modelData id: root
active: modelData.hasMenu property SystemTrayItem trayItem
property bool menuOpened: false
onLoaded: console.log(modelData.icon) implicitWidth: Dimensions.tray.width
sourceComponent: item implicitHeight: Dimensions.tray.height
property Component item: Clickable {
id: clickable
property bool menuOpen onClicked: toggleMenu()
width: Dimensions.tray.width function toggleMenu() {
height: Dimensions.tray.height menuOpened = !menuOpened;
}
onClicked: menuOpen = !menuOpen IconImage {
id: icon
IconImage { anchors.margins: 6
id: icon anchors.fill: parent
anchors.margins: 6 asynchronous: true
anchors.fill: parent source: {
asynchronous: true let icon = modelData.icon;
source: { if (icon.includes("?path=")) {
let icon = modelData.icon; const [name, path] = icon.split("?path=");
if (icon.includes("?path=")) { icon = `file://${path}/${name.slice(name.lastIndexOf("/") + 1)}`;
const [name, path] = icon.split("?path=");
icon = `file://${path}/${name.slice(name.lastIndexOf("/") + 1)}`;
}
return icon;
} }
anchors.centerIn: parent return icon;
}
anchors.centerIn: parent
}
PopupWindow {
id: popup
visible: root.menuOpened
color: 'transparent'
anchor.item: root
anchor.rect.x: root.width / 2 - width / 2
anchor.rect.y: root.height + 8
implicitWidth: menu.width
implicitHeight: menu.height
Rectangle {
anchors.fill: parent
color: Theme.palette.base300
radius: 8
} }
// Loader { Menu {
// active: menuOpen && modelData.hasMenu id: menu
//
// property Component menu: Menu {
// menu: modelData.menu
// }
// }
PopupWindow {
Menu { menuOpener: QsMenuOpener {
menu: modelData.menu menu: trayItem.menu
} }
} }
} }

View file

@ -1,23 +1,29 @@
import QtQuick import QtQuick
import QtQuick.Layouts import QtQuick.Layouts
import Quickshell import Quickshell
import "../../../../../config/"
import "../../../../../styled/" import "../../../../../styled/"
ColumnLayout { ColumnLayout {
property QsMenuOpener menu id: menu
property QsMenuOpener menuOpener
anchors.margins: 8
Repeater { Repeater {
model: modelData.children model: menuOpener.children
delegate: Loader {
Loader {
id: loader
required property QsMenuEntry modelData required property QsMenuEntry modelData
active: true
active: modelData.enabled sourceComponent: modelData.isSeparator ? menuSeperator : menuItem
property Component menuSeperator: Rectangle {
sourceComponent: menuItem implicitHeight: 1
implicitWidth: menu.width
color: Theme.palette.basecontent
}
property Component menuItem: MenuItem { property Component menuItem: MenuItem {
menuEntry: loader.modelData menuEntry: modelData
} }
} }
} }

View file

@ -1,6 +1,7 @@
import QtQuick import QtQuick
import QtQuick.Layouts import QtQuick.Layouts
import Quickshell import Quickshell
import "../../../../../config/"
import "../../../../../styled/" import "../../../../../styled/"
Clickable { Clickable {
@ -8,11 +9,20 @@ Clickable {
property QsMenuEntry menuEntry property QsMenuEntry menuEntry
implicitWidth: text.width implicitWidth: text.width
implicitHeight: 30
Text { onClicked: menuEntry.triggered()
StyledText {
id: text id: text
text: item.menuEntry.text
padding: 8 font.pixelSize: Dimensions.clock.fontSize
anchors.verticalCenter: parent.verticalCenter
topPadding: Dimensions.clock.verticalPadding
bottomPadding: Dimensions.clock.verticalPadding
leftPadding: Dimensions.clock.horizontalPadding
rightPadding: Dimensions.clock.horizontalPadding
text: item.menuEntry.text
} }
} }

View file

@ -1,30 +1,21 @@
import QtQuick import QtQuick
import "../config/" import "../config/"
Item { MouseArea {
id: root id: mouseArea
property bool disabled: false
property alias hovered: mouseArea.containsMouse
signal clicked
signal scrolledUp
signal scrolledDown
StyledLabel { property bool disabled: false
hoverEnabled: !disabled
cursorShape: Qt.PointingHandCursor
Rectangle {
id: background id: background
anchors.fill: parent anchors.fill: parent
states: State {
name: "hovered" radius: Dimensions.radius
when: mouseArea.containsMouse color: mouseArea.containsMouse ? Theme.palette.primary : Theme.palette.base300
PropertyChanges { Behavior on color {
background {
color: Theme.palette.primary
}
}
}
transitions: Transition {
from: ""
to: "hovered"
reversible: true
ColorAnimation { ColorAnimation {
properties: "color" properties: "color"
duration: 200 duration: 200
@ -32,22 +23,4 @@ Item {
} }
} }
} }
MouseArea {
id: mouseArea
anchors.fill: parent
hoverEnabled: !disabled
cursorShape: Qt.PointingHandCursor
onClicked: root.clicked()
onWheel: event => {
if (event.angleDelta.y > 0) {
root.scrolledUp();
} else if (event.angleDelta.y < 0) {
root.scrolledDown();
}
}
}
} }