mirror of
https://invent.kde.org/marcoa/shift-shell.git
synced 2026-04-28 06:33:09 +00:00
This makes the behavior of the app drawer a bit more familiar and slightly more similar to Android for now: * The drawer always contains every application * Applications are always alphabetically ordered * The drawer opens completely, not staying stuck in "in between" states * is possible to drag more copies of a single app on the homescreen/favorites * possible to remove an icon from the homescreen or favorites Two things have been prepared in there (but are material for 5.22 only, so not finished) * Things have been reordered such in a way that makes easy for most of the qml files to become components to make easy for people to build their own customized homescreen * basic infrastructure is there to allow for multiple horizontal pages scroll, though not implemented yet as needs changes to plasma-workspace layouting code beforehand
219 lines
7.7 KiB
QML
219 lines
7.7 KiB
QML
/*
|
|
* 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 QtGraphicalEffects 1.6
|
|
|
|
import org.kde.plasma.plasmoid 2.0
|
|
import org.kde.plasma.core 2.0 as PlasmaCore
|
|
import org.kde.plasma.components 3.0 as PC3
|
|
import org.kde.kquickcontrolsaddons 2.0
|
|
|
|
import org.kde.plasma.private.containmentlayoutmanager 1.0 as ContainmentLayoutManager
|
|
import org.kde.plasma.private.mobileshell 1.0 as MobileShell
|
|
import org.kde.phone.homescreen 1.0
|
|
|
|
import "private" as Private
|
|
|
|
ContainmentLayoutManager.ItemContainer {
|
|
id: delegate
|
|
|
|
z: dragActive ? 1 : 0
|
|
|
|
property var modelData: typeof model !== "undefined" ? model : null
|
|
|
|
Layout.minimumWidth: appletsLayout.cellWidth
|
|
Layout.minimumHeight: appletsLayout.cellHeight
|
|
|
|
key: model.applicationUniqueId
|
|
property ContainmentLayoutManager.AppletsLayout appletsLayout
|
|
property int reservedSpaceForLabel
|
|
property real dragCenterX
|
|
property real dragCenterY
|
|
property alias iconItem: icon
|
|
|
|
editModeCondition: ContainmentLayoutManager.ItemContainer.AfterPressAndHold
|
|
|
|
signal launch(int x, int y, var source, string title)
|
|
|
|
function syncDelegateGeometry() {
|
|
if (!applicationRunning) {
|
|
return;
|
|
}
|
|
|
|
if (!MobileShell.HomeScreenControls.taskSwitcherVisible) {
|
|
plasmoid.nativeInterface.applicationListModel.setMinimizedDelegate(index, delegate);
|
|
} else {
|
|
plasmoid.nativeInterface.applicationListModel.unsetMinimizedDelegate(index, delegate);
|
|
}
|
|
}
|
|
|
|
readonly property bool applicationRunning: model.applicationRunning
|
|
onApplicationRunningChanged: {
|
|
syncDelegateGeometry();
|
|
}
|
|
Connections {
|
|
target: mainFlickable
|
|
function onCancelEditModeForItemsRequested() {
|
|
cancelEdit()
|
|
}
|
|
function onContentYChanged() {
|
|
syncDelegateGeometry()
|
|
}
|
|
}
|
|
Connections {
|
|
target: MobileShell.HomeScreenControls
|
|
function onTaskSwitcherVisibleChanged() {
|
|
syncDelegateGeometry();
|
|
}
|
|
}
|
|
Connections {
|
|
target: appletsLayout
|
|
function onAppletsLayoutInteracted() {
|
|
removeButton.hide();
|
|
}
|
|
}
|
|
|
|
onDragActiveChanged: {
|
|
launcherDragManager.active = dragActive
|
|
if (dragActive) {
|
|
// Must be 0, 0 as at this point dragCenterX and dragCenterY are on the drag before"
|
|
launcherDragManager.startDrag(delegate);
|
|
launcherDragManager.currentlyDraggedDelegate = delegate;
|
|
removeButton.show();
|
|
mouseArea.enabled = true;
|
|
} else {
|
|
launcherDragManager.dropItem(delegate, dragCenterX, dragCenterY);
|
|
plasmoid.editMode = false;
|
|
editMode = false;
|
|
plasmoid.fullRepresentationItem.stopScroll();
|
|
launcherDragManager.currentlyDraggedDelegate = null;
|
|
forceActiveFocus();
|
|
}
|
|
}
|
|
|
|
onUserDrag: {
|
|
dragCenterX = dragCenter.x;
|
|
dragCenterY = dragCenter.y;
|
|
launcherDragManager.dragItem(delegate, dragCenter.x, dragCenter.y);
|
|
|
|
delegate.width = appletsLayout.cellWidth;
|
|
delegate.height = appletsLayout.cellHeight;
|
|
|
|
var pos = plasmoid.fullRepresentationItem.mapFromItem(delegate, dragCenter.x, dragCenter.y);
|
|
//SCROLL LEFT
|
|
if (pos.x < plasmoid.availableScreenRect.x + units.gridUnit) {
|
|
plasmoid.fullRepresentationItem.scrollLeft();
|
|
//SCROLL RIGHT
|
|
} else if (pos.x > plasmoid.availableScreenRect.x + plasmoid.availableScreenRect.width - units.gridUnit) {
|
|
plasmoid.fullRepresentationItem.scrollRight();
|
|
//DON't SCROLL
|
|
} else {
|
|
plasmoid.fullRepresentationItem.stopScroll();
|
|
}
|
|
}
|
|
|
|
contentItem: MouseArea {
|
|
id: mouseArea
|
|
onClicked: {
|
|
if (modelData.applicationRunning) {
|
|
delegate.launch(0, 0, "", modelData.applicationName);
|
|
} else {
|
|
delegate.launch(delegate.x + (units.smallSpacing * 2), delegate.y + (units.smallSpacing * 2), icon.source, modelData.applicationName);
|
|
}
|
|
|
|
plasmoid.nativeInterface.applicationListModel.setMinimizedDelegate(index, delegate);
|
|
plasmoid.nativeInterface.applicationListModel.runApplication(modelData.applicationStorageId);
|
|
}
|
|
|
|
//preventStealing: true
|
|
ColumnLayout {
|
|
anchors {
|
|
fill: parent
|
|
leftMargin: units.smallSpacing * 2
|
|
topMargin: units.smallSpacing * 2
|
|
rightMargin: units.smallSpacing * 2
|
|
bottomMargin: units.smallSpacing * 2
|
|
}
|
|
spacing: 0
|
|
|
|
PlasmaCore.IconItem {
|
|
id: icon
|
|
|
|
Layout.alignment: Qt.AlignHCenter | Qt.AlignTop
|
|
Layout.fillWidth: true
|
|
Layout.minimumHeight: Math.min(units.iconSizes.large, parent.height - delegate.reservedSpaceForLabel)
|
|
Layout.preferredHeight: Layout.minimumHeight
|
|
|
|
usesPlasmaTheme: false
|
|
source: modelData ? modelData.applicationIcon : ""
|
|
|
|
Rectangle {
|
|
anchors {
|
|
horizontalCenter: parent.horizontalCenter
|
|
bottom: parent.bottom
|
|
}
|
|
visible: model.applicationRunning
|
|
radius: width
|
|
width: units.smallSpacing
|
|
height: width
|
|
color: theme.highlightColor
|
|
}
|
|
//TODO: in loader?
|
|
Private.DelegateRemoveButton {
|
|
id: removeButton
|
|
}
|
|
}
|
|
|
|
PC3.Label {
|
|
id: label
|
|
visible: text.length > 0
|
|
|
|
Layout.fillWidth: true
|
|
Layout.preferredHeight: delegate.reservedSpaceForLabel
|
|
wrapMode: Text.WordWrap
|
|
Layout.alignment: Qt.AlignTop
|
|
Layout.leftMargin: -parent.anchors.leftMargin + units.smallSpacing
|
|
Layout.rightMargin: -parent.anchors.rightMargin + units.smallSpacing
|
|
horizontalAlignment: Text.AlignHCenter
|
|
verticalAlignment: Text.AlignTop
|
|
maximumLineCount: 2
|
|
elide: Text.ElideRight
|
|
|
|
text: model.applicationName
|
|
|
|
//FIXME: export smallestReadableFont
|
|
font.pointSize: theme.defaultFont.pointSize * 0.9
|
|
color: "white"//model.applicationLocation == ApplicationListModel.Desktop ? "white" : theme.textColor
|
|
|
|
layer.enabled: true//model.applicationLocation == ApplicationListModel.Desktop
|
|
layer.effect: DropShadow {
|
|
horizontalOffset: 0
|
|
verticalOffset: 2
|
|
radius: 8.0
|
|
samples: 16
|
|
cached: true
|
|
color: Qt.rgba(0, 0, 0, 1)
|
|
}
|
|
}
|
|
Item {Layout.fillHeight:true}
|
|
}
|
|
}
|
|
}
|