aerothemeplasma/Plasma/Plasma_Widgets/User/io.gitgud.wackyideas.SevenStart/contents/ui/ItemGridDelegateBack.qml

150 lines
5.5 KiB
QML
Raw Normal View History

/***************************************************************************
* Copyright (C) 2015 by Eike Hein <hein@kde.org> *
* *
* 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.0
import org.kde.plasma.core 2.0 as PlasmaCore
import org.kde.plasma.components 2.0 as PlasmaComponents
import "code/tools.js" as Tools
Item {
id: item
width: GridView.view.cellWidth - units.gridUnit
height: GridView.view.cellHeight
property bool showLabel: true
property int itemIndex: model.index
property string favoriteId: model.favoriteId !== undefined ? model.favoriteId : ""
property url url: model.url !== undefined ? model.url : ""
property variant icon: model.decoration !== undefined ? model.decoration : ""
property var m: model
property bool hasActionList: ((model.favoriteId !== null)
|| (("hasActionList" in model) && (model.hasActionList === true)))
Accessible.role: Accessible.MenuItem
Accessible.name: model.display
function openActionMenu(x, y) {
var actionList = hasActionList ? model.actionList : [];
Tools.fillActionMenu(i18n, actionMenu, actionList, GridView.view.model.favoritesModel, model.favoriteId);
actionMenu.visualParent = item;
actionMenu.open(x, y);
}
function actionTriggered(actionId, actionArgument) {
var close = (Tools.triggerAction(GridView.view.model, model.index, actionId, actionArgument) === true);
if (close) {
2024-01-20 02:08:06 +00:00
root.visible = false;
}
}
2024-01-20 02:08:06 +00:00
function activateItem() {
if ("trigger" in GridView.view.model) {
var result = GridView.view.model.trigger(index, "", null);
if(result) root.visible = false;
}
itemGrid.itemActivated(index, "", null);
}
PlasmaCore.IconItem {
id: icon
anchors.left: parent.left
anchors.leftMargin: units.smallSpacing*2
anchors.verticalCenter: parent.verticalCenter
2024-01-20 02:08:06 +00:00
width: units.iconSizes.small
height: width
colorGroup: PlasmaCore.Theme.ComplementaryColorGroup
animated: false
//usesPlasmaTheme: item.GridView.view.usesPlasmaTheme
usesPlasmaTheme: false
source: {
return model.decoration
//if (model.display.indexOf(".") === -1 ) {
// var s = "-" + model.url
// if( s[s.length - 8 ] == "."){
// return model.decoration
// }
// return "folder"
//}else{
// return model.decoration
//}
}
smooth: true
Component.onCompleted: {
if(!icon.valid || icon.paintedHeight == 0) icon.source = "exec";
}
}
PlasmaComponents.Label {
id: label
visible: showLabel
anchors {
left: icon.right
2024-01-20 02:08:06 +00:00
leftMargin: units.smallSpacing * 2 - 2
//top: icon.top
verticalCenter: icon.verticalCenter
}
maximumLineCount: 1
elide: Text.ElideRight
wrapMode: Text.Wrap
color: "black"
width: parent.width - icon.width - units.largeSpacing
text: ("name" in model ? model.name : model.display)
}
PlasmaComponents.Label {
anchors.right: parent.right
anchors.rightMargin: units.smallSpacing*2
anchors.verticalCenter: label.verticalCenter
visible: showLabel
horizontalAlignment: Text.AlignRight
maximumLineCount: 1
2024-01-20 02:08:06 +00:00
width: parent.width - label.implicitWidth - icon.width * 2 - units.smallSpacing*2
elide: Text.ElideRight
wrapMode: Text.Wrap
color: "black"
opacity: 0.5
text: model.description
}
PlasmaCore.ToolTipArea {
id: toolTip
property string text: model.display
anchors.fill: parent
active: root.visible && label.truncated
mainItem: toolTipDelegate
onContainsMouseChanged: item.GridView.view.itemContainsMouseChanged(containsMouse)
}
Keys.onPressed: {
if (event.key === Qt.Key_Menu && hasActionList) {
event.accepted = true;
openActionMenu(item);
} else if ((event.key === Qt.Key_Enter || event.key === Qt.Key_Return)) {
event.accepted = true;
2024-01-20 02:08:06 +00:00
activateItem();
}
}
}