shift-shell/containments/homescreen2/package/contents/ui/launcher/Delegate.qml

163 lines
5.7 KiB
QML
Raw Normal View History

/*
* Copyright 2019 Marco Martin <mart@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 2.010-1301, USA.
*/
import QtQuick 2.4
import QtQuick.Layouts 1.1
import QtQuick.Controls 2.3 as Controls
import org.kde.plasma.plasmoid 2.0
import org.kde.plasma.core 2.0 as PlasmaCore
import org.kde.plasma.components 2.0 as PlasmaComponents
import org.kde.kquickcontrolsaddons 2.0
2019-07-30 10:20:21 +00:00
import org.kde.plasma.private.containmentlayoutmanager 1.0 as ContainmentLayoutManager
2019-07-30 10:20:21 +00:00
ContainmentLayoutManager.ItemContainer {
id: delegate
z: dragging ? 1 : 0
property var modelData: typeof model !== "undefined" ? model : null
2019-08-15 11:19:16 +00:00
property ContainmentLayoutManager.ItemContainer beforeItem
property Item container
property ContainmentLayoutManager.ItemContainer before
2019-07-30 10:20:21 +00:00
leftPadding: units.smallSpacing * 2
topPadding: units.smallSpacing * 2
rightPadding: units.smallSpacing * 2
bottomPadding: units.smallSpacing * 2
opacity: dragging ? 0.4 : 1
2019-08-01 16:41:42 +00:00
editModeCondition: ContainmentLayoutManager.ItemContainer.AfterPressAndHold//model.ApplicationOnDesktopRole ? ContainmentLayoutManager.ItemContainer.AfterPressAndHold: ContainmentLayoutManager.ItemContainer.Manual
onEditModeChanged: {//FIXME: remove
plasmoid.editMode = editMode
2019-08-15 11:19:16 +00:00
if (!editMode) {
root.forceLayout();
}
2019-08-01 16:41:42 +00:00
}
onDragActiveChanged: {
if (dragActive) {
2019-08-15 11:19:16 +00:00
if (container) {
container.showSpacerBefore(delegate);
}
2019-08-01 16:41:42 +00:00
return;
}
plasmoid.editMode = false;
editMode = false;
2019-08-15 11:19:16 +00:00
if (container) {
container.forceLayout();
container.hideSpacer();
}
2019-08-01 16:41:42 +00:00
}
2019-07-30 11:39:07 +00:00
2019-08-15 11:19:16 +00:00
onParentChanged: {
if (container) {
plasmoid.nativeInterface.orderItems(delegate, before);
}
}
2019-07-30 10:20:21 +00:00
2019-08-01 16:41:42 +00:00
onUserDrag: {
// newPosition
var newRow = 0;
// Put it in the favorites strip
if (favoriteStrip.contains(favoriteStrip.mapFromItem(delegate, dragCenter.x, dragCenter.y))) {
var pos = favoriteStrip.mapFromItem(delegate, 0, 0);
newRow = Math.floor((pos.x + dragCenter.x) / delegate.width);
2019-08-15 11:19:16 +00:00
before = favoriteStrip.flow.childAt(delegate.x + dragCenter.x, delegate.y + dragCenter.y);
2019-08-01 16:41:42 +00:00
// Put it on desktop
} else if (appletsLayout.contains(appletsLayout.mapFromItem(delegate, dragCenter.x, dragCenter.y))) {
var pos = appletsLayout.mapFromItem(delegate, 0, 0);
plasmoid.nativeInterface.applicationListModel.setDesktopItem(index, true);
delegate.x = pos.x
delegate.y = pos.y
2019-08-15 11:19:16 +00:00
before = null;
2019-08-01 16:41:42 +00:00
return;
// Put it in the general view
} else {
newRow = Math.round(applicationsFlow.width / delegate.width) * Math.floor((delegate.y + dragCenter.y) / delegate.height) + Math.floor((delegate.x + dragCenter.x) / delegate.width) + favoriteStrip.count;
2019-08-15 11:19:16 +00:00
before = applicationsFlow.childAt(delegate.x + dragCenter.x, delegate.y + dragCenter.y);
2019-08-01 16:41:42 +00:00
}
2019-08-01 16:41:42 +00:00
plasmoid.nativeInterface.applicationListModel.setDesktopItem(index, false);
plasmoid.nativeInterface.applicationListModel.moveItem(modelData.index, newRow);
2019-08-15 11:19:16 +00:00
if (container) {
container.showSpacerBefore(before);
}
2019-08-01 16:41:42 +00:00
//delegate.x = newPosition.x;
}
contentItem: MouseArea {
onClicked: {
if (modelData.ApplicationStartupNotifyRole) {
clickFedbackAnimation.target = delegate;
clickFedbackAnimation.running = true;
feedbackWindow.title = modelData.ApplicationNameRole;
feedbackWindow.state = "open";
}
plasmoid.nativeInterface.applicationListModel.runApplication(modelData.ApplicationStorageIdRole);
}
ColumnLayout {
anchors.fill: parent
spacing: 0
2019-07-30 10:20:21 +00:00
PlasmaCore.IconItem {
id: icon
Layout.alignment: Qt.AlignHCenter | Qt.AlignTop
Layout.fillWidth: true
Layout.preferredHeight: parent.height - root.reservedSpaceForLabel
source: modelData ? modelData.ApplicationIconRole : ""
scale: root.reorderingApps && dragDelegate && !dragging ? 0.6 : 1
Behavior on scale {
NumberAnimation {
duration: units.longDuration
easing.type: Easing.InOutQuad
}
}
}
PlasmaComponents.Label {
id: label
visible: text.length > 0
Layout.fillWidth: true
Layout.fillHeight: true
wrapMode: Text.WordWrap
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignTop
maximumLineCount: 2
elide: Text.ElideRight
text: modelData ? modelData.ApplicationNameRole : ""
font.pixelSize: theme.defaultFont.pixelSize
color: PlasmaCore.ColorScope.textColor
}
}
}
}