2021-09-29 17:10:18 +00:00
|
|
|
/*
|
|
|
|
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
|
2021-09-29 17:10:18 +00:00
|
|
|
import org.kde.plasma.plasmoid 2.0
|
|
|
|
|
2024-08-09 01:20:25 +00:00
|
|
|
KSvg.FrameSvgItem {
|
2021-09-29 17:10:18 +00:00
|
|
|
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;
|
2021-09-29 17:10:18 +00:00
|
|
|
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
|
2021-09-29 17:10:18 +00:00
|
|
|
|
2024-08-09 01:20:25 +00:00
|
|
|
imagePath: Qt.resolvedUrl("svgs/tabbar.svgz")
|
2021-09-29 17:10:18 +00:00
|
|
|
prefix: {
|
2024-08-09 01:20:25 +00:00
|
|
|
let prefix;
|
2021-09-29 17:10:18 +00:00
|
|
|
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;
|
2021-09-29 17:10:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 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
|
|
|
|
2021-09-29 17:10:18 +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;
|
2021-09-29 17:10:18 +00:00
|
|
|
}
|
|
|
|
} 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);
|
2021-09-29 17:10:18 +00:00
|
|
|
} 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
|
2021-09-29 17:10:18 +00:00
|
|
|
}
|
|
|
|
}
|
2024-08-09 01:20:25 +00:00
|
|
|
/*Behavior on x {
|
2021-09-29 17:10:18 +00:00
|
|
|
id: xAnim
|
|
|
|
enabled: animationEnabled
|
|
|
|
NumberAnimation {
|
2024-08-09 01:20:25 +00:00
|
|
|
duration: Kirigami.Units.longDuration
|
2021-09-29 17:10:18 +00:00
|
|
|
easing.type: Easing.InOutCubic
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Behavior on y {
|
|
|
|
id: yAnim
|
|
|
|
enabled: animationEnabled
|
|
|
|
NumberAnimation {
|
2024-08-09 01:20:25 +00:00
|
|
|
duration: Kirigami.Units.longDuration
|
2021-09-29 17:10:18 +00:00
|
|
|
easing.type: Easing.InOutCubic
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Behavior on width {
|
|
|
|
id: widthAnim
|
|
|
|
enabled: animationEnabled
|
|
|
|
NumberAnimation {
|
2024-08-09 01:20:25 +00:00
|
|
|
duration: Kirigami.Units.longDuration
|
2021-09-29 17:10:18 +00:00
|
|
|
easing.type: Easing.InOutCubic
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Behavior on height {
|
|
|
|
id: heightAnim
|
|
|
|
enabled: animationEnabled
|
|
|
|
NumberAnimation {
|
2024-08-09 01:20:25 +00:00
|
|
|
duration: Kirigami.Units.longDuration
|
2021-09-29 17:10:18 +00:00
|
|
|
easing.type: Easing.InOutCubic
|
|
|
|
}
|
2024-08-09 01:20:25 +00:00
|
|
|
}*/
|
2021-09-29 17:10:18 +00:00
|
|
|
}
|