aerothemeplasma/plasma/plasmoids/org.kde.plasma.private.systemtray/contents/ui/CurrentItemHighLight.qml

181 lines
5.2 KiB
QML
Raw Permalink Normal View History

/*
SPDX-FileCopyrightText: 2011 Marco Martin <mart@kde.org>
SPDX-License-Identifier: LGPL-2.0-or-later
*/
2024-08-09 01:20:25 +00:00
import QtQuick 2.15
import org.kde.plasma.core as PlasmaCore
import org.kde.kirigami 2.20 as Kirigami
import org.kde.ksvg 1.0 as KSvg
import org.kde.plasma.plasmoid 2.0
2024-08-09 01:20:25 +00:00
KSvg.FrameSvgItem {
id: currentItemHighLight
property int location
property bool animationEnabled: true
property var highlightedItem: null
property var containerMargins: {
2024-08-09 01:20:25 +00:00
return 0;
let item = currentItemHighLight;
while (item.parent) {
item = item.parent;
if (item.isAppletContainer) {
return item.getMargins;
}
}
return undefined;
}
z: -1 // always draw behind icons
2024-08-09 01:20:25 +00:00
opacity: systemTrayState.expanded ? 0.8 : 0
2024-08-09 01:20:25 +00:00
imagePath: Qt.resolvedUrl("svgs/tabbar.svgz")
prefix: {
2024-08-09 01:20:25 +00:00
let prefix;
switch (location) {
2024-08-09 01:20:25 +00:00
case PlasmaCore.Types.LeftEdge:
prefix = "west-active-tab";
break;
case PlasmaCore.Types.TopEdge:
prefix = "north-active-tab";
break;
case PlasmaCore.Types.RightEdge:
prefix = "east-active-tab";
break;
default:
prefix = "south-active-tab";
}
if (!hasElementPrefix(prefix)) {
prefix = "active-tab";
}
return prefix;
}
// update when System Tray is expanded - applet activated or hidden icons shown
Connections {
target: systemTrayState
function onActiveAppletChanged() {
Qt.callLater(updateHighlightedItem);
}
function onExpandedChanged() {
Qt.callLater(updateHighlightedItem);
}
}
// update when applet changes parent (e.g. moves from active to hidden icons)
Connections {
target: systemTrayState.activeApplet
function onParentChanged() {
Qt.callLater(updateHighlightedItem);
}
}
// update when System Tray size changes
Connections {
target: parent
2024-08-09 01:20:25 +00:00
function onWidthChanged() {
Qt.callLater(updateHighlightedItem);
}
function onHeightChanged() {
Qt.callLater(updateHighlightedItem);
}
}
// update when scale of newly added tray item changes (check 'add' animation in GridView in main.qml)
Connections {
target: !!highlightedItem && highlightedItem.parent ? highlightedItem.parent : null
function onScaleChanged() {
Qt.callLater(updateHighlightedItem);
}
}
function updateHighlightedItem() {
if (systemTrayState.expanded) {
if (systemTrayState.activeApplet && systemTrayState.activeApplet.parent && systemTrayState.activeApplet.parent.inVisibleLayout) {
2024-08-09 01:20:25 +00:00
changeHighlightedItem(systemTrayState.activeApplet.parent.container, /*forceEdgeHighlight*/false);
} else { // 'Show hidden items' popup
changeHighlightedItem(parent, /*forceEdgeHighlight*/true);
width = 0;
height = 0;
}
} else {
highlightedItem = null;
}
}
function changeHighlightedItem(nextItem, forceEdgeHighlight) {
// do not animate the first appearance
// or when the property value of a highlighted item changes
if (!highlightedItem || (highlightedItem === nextItem)) {
animationEnabled = false;
}
const p = parent.mapFromItem(nextItem, 0, 0);
if (containerMargins && (parent.oneRowOrColumn || forceEdgeHighlight)) {
2024-08-09 01:20:25 +00:00
x = p.x - containerMargins('left', /*returnAllMargins*/true);
y = p.y - containerMargins('top', /*returnAllMargins*/true);
width = nextItem.width + containerMargins('left', /*returnAllMargins*/true) + containerMargins('right', /*returnAllMargins*/true);
height = nextItem.height + containerMargins('bottom', /*returnAllMargins*/true) + containerMargins('top', /*returnAllMargins*/true);
} else {
x = p.x;
y = p.y;
width = nextItem.width
height = nextItem.height
}
highlightedItem = nextItem;
animationEnabled = true;
}
Behavior on opacity {
NumberAnimation {
2024-08-09 01:20:25 +00:00
duration: Kirigami.Units.longDuration
easing.type: Easing.Linear
}
}
2024-08-09 01:20:25 +00:00
/*Behavior on x {
id: xAnim
enabled: animationEnabled
NumberAnimation {
2024-08-09 01:20:25 +00:00
duration: Kirigami.Units.longDuration
easing.type: Easing.InOutCubic
}
}
Behavior on y {
id: yAnim
enabled: animationEnabled
NumberAnimation {
2024-08-09 01:20:25 +00:00
duration: Kirigami.Units.longDuration
easing.type: Easing.InOutCubic
}
}
Behavior on width {
id: widthAnim
enabled: animationEnabled
NumberAnimation {
2024-08-09 01:20:25 +00:00
duration: Kirigami.Units.longDuration
easing.type: Easing.InOutCubic
}
}
Behavior on height {
id: heightAnim
enabled: animationEnabled
NumberAnimation {
2024-08-09 01:20:25 +00:00
duration: Kirigami.Units.longDuration
easing.type: Easing.InOutCubic
}
2024-08-09 01:20:25 +00:00
}*/
}