punktdateien/kde/plasma/plasmoids/AndromedaLauncher/contents/ui/FavoriteItem.qml

220 lines
6.6 KiB
QML
Raw Normal View History

2024-04-12 15:10:33 +02:00
/*****************************************************************************
* Copyright (C) 2022 by Friedrich Schriewer <friedrich.schriewer@gmx.net> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA . *
****************************************************************************/
import QtQuick 2.12
import QtQuick.Layouts 1.12
import Qt5Compat.GraphicalEffects
import QtQuick.Window 2.2
import org.kde.plasma.components 3.0 as PlasmaComponents
import org.kde.plasma.plasmoid 2.0
import org.kde.plasma.core 2.0 as PlasmaCore
import org.kde.coreaddons 1.0 as KCoreAddons
import org.kde.kirigami as Kirigami
import QtQuick.Controls 2.15
import "../code/tools.js" as Tools
Item {
id: favItem
property int iconSize: Kirigami.Units.gridUnit * 3.2
width: 125
height: iconSize + Kirigami.Units.smallSpacing + appname.implicitHeight + 10
signal itemActivated(int index, string actionId, string argument)
signal actionTriggered(string actionId, variant actionArgument)
signal aboutToShowActionMenu(variant actionMenu)
property bool highlighted: false
property bool isDraging: false
property bool hasActionList: ((model.favoriteId !== null)
|| (("hasActionList" in model) && (model.hasActionList !== null)))
property int itemIndex: model.index
function openActionMenu(visualParent, x, y) {
aboutToShowActionMenu(actionMenu);
actionMenu.visualParent = visualParent;
actionMenu.open(x, y);
}
onAboutToShowActionMenu: actionMenu => {
const actionList = (model.hasActionList !== null) ? model.actionList : [];
Tools.fillActionMenu(i18n, actionMenu, actionList, scrollView.pinnedModel[0], model.favoriteId);
}
onActionTriggered: (actionId, actionArgument) => {
if (Tools.triggerAction(scrollView.pinnedModel[0], model.index, actionId, actionArgument) === true) {
kicker.expanded = false;
}
}
Kirigami.Icon {
id: appicon
anchors {
top: parent.top
horizontalCenter: parent.horizontalCenter
}
width: iconSize
height: iconSize
source: model.decoration
}
PlasmaComponents.Label {
id: appname
text: ("name" in model ? model.name : model.display)
font.family: main.textFont
font.pointSize: main.textSize
color: main.textColor
anchors {
top: appicon.bottom
topMargin: Kirigami.Units.smallSpacing
left: parent.left
right: parent.right
}
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignTop
wrapMode: Text.WordWrap
}
Rectangle {
id: rect
z: -20
visible: !plasmoid.configuration.enableGlow
height: parent.height
width: parent.width
anchors.centerIn: parent
radius: 8
color: PlasmaCore.Theme.highlightColor
states: [
State {
name: "highlight"; when: (highlighted)
PropertyChanges { target: rect; opacity: 0.3}
},
State {
name: "default"; when: (!highlighted)
PropertyChanges { target: rect; opacity: 0}
}
]
transitions: highlight
}
DropShadow {
id:appIconGlow
visible: plasmoid.configuration.enableGlow
anchors.fill: appicon
cached: true
horizontalOffset: 0
verticalOffset: 0
radius: 15.0
samples: 16
color: main.glowColor1
source: appicon
states: [
State {
name: "highlight"; when: (highlighted)
PropertyChanges { target: appIconGlow; opacity: 1}
PropertyChanges { target: appNameGlow; opacity: 1}
},
State {
name: "default"; when: (!highlighted)
PropertyChanges { target: appIconGlow; opacity: 0}
PropertyChanges { target: appNameGlow; opacity: 0}
}
]
transitions: highlight
}
DropShadow {
id: appNameGlow
visible: plasmoid.configuration.enableGlow
anchors.fill: appname
cached: true
horizontalOffset: 0
verticalOffset: 0
radius: 15.0
samples: 16
color: main.glowColor1
source: appname
}
MouseArea {
id: ma
anchors.fill: parent
z: parent.z + 1
acceptedButtons: Qt.LeftButton | Qt.RightButton
cursorShape: Qt.PointingHandCursor
hoverEnabled: true
onClicked: {
if (mouse.button == Qt.RightButton ) {
if (favItem.hasActionList) {
var mapped = mapToItem(favItem, mouse.x, mouse.y);
favItem.openActionMenu(favItem, mouse.x, mouse.y);
}
} else {
kicker.globalFavorites.trigger(index, "", null);
root.toggle()
}
}
onReleased: {
isDraging: false
}
onEntered: {
if(plasmoid.configuration.enableGlow) {
appIconGlow.state = "highlight"
} else { rect.state = "highlight" }
}
onExited: {
if(plasmoid.configuration.enableGlow) {
appIconGlow.state = "default"
} else { rect.state = "default" }
}
onPositionChanged: {
isDraging = pressed
if (pressed){
if ("pluginName" in model) {
dragHelper.startDrag(kicker, model.url, model.decoration,
"text/x-plasmoidservicename", model.pluginName);
} else {
kicker.dragSource = favItem;
dragHelper.startDrag(kicker, model.url, model.icon);
}
}
}
}
ActionMenu {
id: actionMenu
onActionClicked: {
actionTriggered(actionId, actionArgument);
// root.toggle()
}
}
Transition {
id: highlight
ColorAnimation {duration: 100 }
}
}