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:
@@ -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 {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
67
Modules/TopBar/RunningAppsTooltip.qml
Normal file
67
Modules/TopBar/RunningAppsTooltip.qml
Normal 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
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -670,6 +670,7 @@ PanelWindow {
|
|||||||
return "left"
|
return "left"
|
||||||
}
|
}
|
||||||
parentScreen: root.screen
|
parentScreen: root.screen
|
||||||
|
topBar: topBarContent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user