1
0
mirror of https://github.com/AvengeMedia/DankMaterialShell.git synced 2025-12-07 05:55:37 -05:00

Add RunningApps tooltip

This commit is contained in:
bbedward
2025-08-18 14:05:27 -04:00
parent be9bd388c2
commit d638e54ed7
3 changed files with 101 additions and 1 deletions

View File

@@ -11,6 +11,11 @@ Rectangle {
property string section: "left" property string section: "left"
property var parentScreen property var parentScreen
property var hoveredItem: null
property var topBar: null
// The visual root for this window
property Item windowRoot: (Window.window ? Window.window.contentItem : null)
readonly property int windowCount: NiriService.windows.length readonly property int windowCount: NiriService.windows.length
readonly property int calculatedWidth: windowCount > 0 ? windowCount * 24 + (windowCount - 1) * Theme.spacingXS + Theme.spacingS * 2 : 0 readonly property int calculatedWidth: windowCount > 0 ? windowCount * 24 + (windowCount - 1) * Theme.spacingXS + Theme.spacingS * 2 : 0
@@ -19,6 +24,7 @@ Rectangle {
height: 30 height: 30
radius: Theme.cornerRadius radius: Theme.cornerRadius
visible: windowCount > 0 visible: windowCount > 0
clip: false
color: { color: {
if (windowCount === 0) if (windowCount === 0)
return "transparent" return "transparent"
@@ -38,6 +44,7 @@ Rectangle {
model: NiriService.windows model: NiriService.windows
delegate: Item { delegate: Item {
id: delegateItem
property bool isFocused: String(modelData.id) === String(FocusedWindowService.focusedWindowId) property bool isFocused: String(modelData.id) === String(FocusedWindowService.focusedWindowId)
property string appId: modelData.app_id || "" property string appId: modelData.app_id || ""
property string windowTitle: modelData.title || "(Unnamed)" property string windowTitle: modelData.title || "(Unnamed)"
@@ -122,8 +129,33 @@ Rectangle {
onClicked: { onClicked: {
NiriService.focusWindow(windowId) NiriService.focusWindow(windowId)
} }
onEntered: {
root.hoveredItem = delegateItem
var globalPos = delegateItem.mapToGlobal(delegateItem.width / 2, delegateItem.height)
tooltipLoader.active = true
if (tooltipLoader.item) {
var tooltipY = Theme.barHeight + SettingsData.topBarSpacing + Theme.spacingXS
tooltipLoader.item.showTooltip(delegateItem.tooltipText, globalPos.x, tooltipY, root.parentScreen)
}
}
onExited: {
if (root.hoveredItem === delegateItem) {
root.hoveredItem = null
if (tooltipLoader.item) {
tooltipLoader.item.hideTooltip()
}
tooltipLoader.active = false
}
}
} }
} }
} }
} }
}
Loader {
id: tooltipLoader
active: false
sourceComponent: RunningAppsTooltip {
}
}
}

View File

@@ -0,0 +1,67 @@
import QtQuick
import Quickshell
import Quickshell.Wayland
import qs.Common
PanelWindow {
id: root
property string tooltipText: ""
property real targetX: 0
property real targetY: 0
property var targetScreen: null
function showTooltip(text, x, y, screen) {
tooltipText = text
targetScreen = screen
var screenX = screen ? screen.x : 0
targetX = x - screenX
targetY = y
visible = true
}
function hideTooltip() {
visible = false
}
screen: targetScreen
implicitWidth: Math.min(300, Math.max(120, textContent.implicitWidth + Theme.spacingM * 2))
implicitHeight: textContent.implicitHeight + Theme.spacingS * 2
color: "transparent"
visible: false
WlrLayershell.layer: WlrLayershell.Overlay
WlrLayershell.exclusiveZone: -1
anchors {
top: true
left: true
}
margins {
left: Math.round(targetX - implicitWidth / 2)
top: Math.round(targetY)
}
Rectangle {
anchors.fill: parent
color: Theme.surfaceContainer
radius: Theme.cornerRadius
border.width: 1
border.color: Theme.outlineMedium
Text {
id: textContent
anchors.centerIn: parent
text: root.tooltipText
font.pixelSize: Theme.fontSizeSmall
color: Theme.surfaceText
wrapMode: Text.NoWrap
maximumLineCount: 1
elide: Text.ElideRight
width: parent.width - Theme.spacingM * 2
}
}
}

View File

@@ -670,6 +670,7 @@ PanelWindow {
return "left" return "left"
} }
parentScreen: root.screen parentScreen: root.screen
topBar: topBarContent
} }
} }