mirror of
https://invent.kde.org/marcoa/shift-shell.git
synced 2026-04-27 14:33:08 +00:00
mode droparea and appletslayout in own component
still casuses warnings and not fully functional but mostly works
This commit is contained in:
parent
6366d5bfaf
commit
e27cdfdf55
7 changed files with 229 additions and 195 deletions
|
|
@ -21,8 +21,6 @@ LauncherContainer {
|
||||||
|
|
||||||
flow.flow: Flow.TopToBottom
|
flow.flow: Flow.TopToBottom
|
||||||
|
|
||||||
visible: flow.children.length > 0 || launcherDragManager.active || dropArea.containsDrag
|
|
||||||
|
|
||||||
opacity: launcherDragManager.active && plasmoid.nativeInterface.applicationListModel.favoriteCount >= plasmoid.nativeInterface.applicationListModel.maxFavoriteCount ? 0.3 : 1
|
opacity: launcherDragManager.active && plasmoid.nativeInterface.applicationListModel.favoriteCount >= plasmoid.nativeInterface.applicationListModel.maxFavoriteCount ? 0.3 : 1
|
||||||
|
|
||||||
height: visible ? cellHeight : 0
|
height: visible ? cellHeight : 0
|
||||||
|
|
|
||||||
|
|
@ -30,6 +30,8 @@ Flickable {
|
||||||
readonly property int totalPages: Math.ceil(contentWidth / width)
|
readonly property int totalPages: Math.ceil(contentWidth / width)
|
||||||
property int currentIndex: 0
|
property int currentIndex: 0
|
||||||
|
|
||||||
|
property ContainmentLayoutManager.AppletsLayout appletsLayout: null
|
||||||
|
|
||||||
opacity: 1 - appDrawer.openFactor
|
opacity: 1 - appDrawer.openFactor
|
||||||
transform: Translate {
|
transform: Translate {
|
||||||
y: -mainFlickable.height/10 * appDrawer.openFactor
|
y: -mainFlickable.height/10 * appDrawer.openFactor
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,209 @@
|
||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2019 Marco Martin <mart@kde.org>
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: LGPL-2.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
import QtQuick 2.12
|
||||||
|
import QtQuick.Window 2.12
|
||||||
|
import QtQuick.Layouts 1.1
|
||||||
|
import QtGraphicalEffects 1.0
|
||||||
|
|
||||||
|
import org.kde.plasma.plasmoid 2.0
|
||||||
|
import org.kde.plasma.core 2.0 as PlasmaCore
|
||||||
|
import org.kde.plasma.components 3.0 as PlasmaComponents
|
||||||
|
import org.kde.draganddrop 2.0 as DragDrop
|
||||||
|
|
||||||
|
import org.kde.plasma.private.containmentlayoutmanager 1.0 as ContainmentLayoutManager
|
||||||
|
|
||||||
|
import org.kde.phone.homescreen 1.0
|
||||||
|
|
||||||
|
import org.kde.plasma.private.mobileshell 1.0 as MobileShell
|
||||||
|
|
||||||
|
import "private" as Private
|
||||||
|
|
||||||
|
DragDrop.DropArea {
|
||||||
|
id: dropArea
|
||||||
|
width: mainFlickable.width * 100
|
||||||
|
//width: Math.max(mainFlickable.width, mainFlickable.width * Math.ceil(appletsLayout.childrenRect.width/mainFlickable.width))
|
||||||
|
height: mainFlickable.height + favoriteStrip.height + units.gridUnit
|
||||||
|
|
||||||
|
property alias itemsBoundingRect: appletsLayout.childrenRect
|
||||||
|
|
||||||
|
property alias appletsLayout: appletsLayout
|
||||||
|
|
||||||
|
Connections {
|
||||||
|
target: plasmoid
|
||||||
|
function onEditModeChanged() {
|
||||||
|
appletsLayout.editMode = plasmoid.editMode
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onDragEnter: {
|
||||||
|
event.accept(event.proposedAction);
|
||||||
|
launcherDragManager.active = true;
|
||||||
|
}
|
||||||
|
onDragMove: {
|
||||||
|
let posInFavorites = favoriteStrip.mapFromItem(this, event.x, event.y);
|
||||||
|
if (posInFavorites.y > 0) {
|
||||||
|
if (plasmoid.nativeInterface.applicationListModel.favoriteCount >= plasmoid.nativeInterface.applicationListModel.maxFavoriteCount ) {
|
||||||
|
launcherDragManager.hideSpacer();
|
||||||
|
} else {
|
||||||
|
launcherDragManager.showSpacerAtPos(event.x, event.y, favoriteStrip);
|
||||||
|
}
|
||||||
|
appletsLayout.hidePlaceHolder();
|
||||||
|
} else {
|
||||||
|
appletsLayout.showPlaceHolderAt(
|
||||||
|
Qt.rect(event.x - appletsLayout.defaultItemWidth / 2,
|
||||||
|
event.y - appletsLayout.defaultItemHeight / 2,
|
||||||
|
appletsLayout.defaultItemWidth,
|
||||||
|
appletsLayout.defaultItemHeight)
|
||||||
|
);
|
||||||
|
launcherDragManager.hideSpacer();
|
||||||
|
|
||||||
|
//SCROLL LEFT
|
||||||
|
if (event.x < units.gridUnit) {
|
||||||
|
mainFlickable.scrollLeft();
|
||||||
|
//SCROLL RIGHT
|
||||||
|
} else if (event.x > mainFlickable.width - units.gridUnit) {
|
||||||
|
mainFlickable.scrollRight();
|
||||||
|
//DON't SCROLL
|
||||||
|
} else {
|
||||||
|
mainFlickable.stopScroll();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onDragLeave: {
|
||||||
|
appletsLayout.hidePlaceHolder();
|
||||||
|
launcherDragManager.active = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
preventStealing: true
|
||||||
|
|
||||||
|
onDrop: {
|
||||||
|
launcherDragManager.active = false;
|
||||||
|
if (event.mimeData.formats[0] === "text/x-plasma-phone-homescreen-launcher") {
|
||||||
|
let storageId = event.mimeData.getDataAsByteArray("text/x-plasma-phone-homescreen-launcher");
|
||||||
|
|
||||||
|
let posInFavorites = favoriteStrip.flow.mapFromItem(this, event.x, event.y);
|
||||||
|
if (posInFavorites.y > 0) {
|
||||||
|
if (plasmoid.nativeInterface.applicationListModel.favoriteCount >= plasmoid.nativeInterface.applicationListModel.maxFavoriteCount ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let pos = Math.min(plasmoid.nativeInterface.applicationListModel.count, Math.floor(posInFavorites.x/favoriteStrip.cellWidth))
|
||||||
|
plasmoid.nativeInterface.applicationListModel.addFavorite(storageId, pos, ApplicationListModel.Favorites)
|
||||||
|
let item = launcherRepeater.itemAt(pos);
|
||||||
|
|
||||||
|
if (item) {
|
||||||
|
item.x = posInFavorites.x;
|
||||||
|
item.y = 0//posInFavorites.y;
|
||||||
|
|
||||||
|
//launcherDragManager.showSpacer(item, item.width/2, item.height/2);
|
||||||
|
launcherDragManager.dropItem(item, item.width/2, item.height/2);
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
let pos = plasmoid.nativeInterface.applicationListModel.count;
|
||||||
|
plasmoid.nativeInterface.applicationListModel.addFavorite(storageId, pos, ApplicationListModel.Desktop)
|
||||||
|
let item = launcherRepeater.itemAt(pos);
|
||||||
|
|
||||||
|
event.accept(event.proposedAction);
|
||||||
|
if (item) {
|
||||||
|
item.x = appletsLayout.placeHolder.x;
|
||||||
|
item.y = appletsLayout.placeHolder.y;
|
||||||
|
appletsLayout.hidePlaceHolder();
|
||||||
|
launcherDragManager.dropItem(item, appletsLayout.placeHolder.x + appletsLayout.placeHolder.width/2, appletsLayout.placeHolder.y + appletsLayout.placeHolder.height/2);
|
||||||
|
}
|
||||||
|
appletsLayout.hidePlaceHolder();
|
||||||
|
} else {
|
||||||
|
plasmoid.processMimeData(event.mimeData,
|
||||||
|
event.x - appletsLayout.placeHolder.width / 2, event.y - appletsLayout.placeHolder.height / 2);
|
||||||
|
event.accept(event.proposedAction);
|
||||||
|
appletsLayout.hidePlaceHolder();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ContainmentLayoutManager.AppletsLayout {
|
||||||
|
id: appletsLayout
|
||||||
|
|
||||||
|
anchors {
|
||||||
|
fill: parent
|
||||||
|
bottomMargin: favoriteStrip.height
|
||||||
|
}
|
||||||
|
|
||||||
|
signal appletsLayoutInteracted
|
||||||
|
|
||||||
|
TapHandler {
|
||||||
|
target: mainFlickable
|
||||||
|
enabled: appDrawer.status !== AppDrawer.Status.Open
|
||||||
|
onTapped: {
|
||||||
|
//Hides icons close button
|
||||||
|
appletsLayout.appletsLayoutInteracted();
|
||||||
|
appletsLayout.editMode = false;
|
||||||
|
}
|
||||||
|
onLongPressed: appletsLayout.editMode = true;
|
||||||
|
onPressedChanged: root.focus = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
cellWidth: favoriteStrip.cellWidth
|
||||||
|
cellHeight: Math.floor(height / Math.floor(height / favoriteStrip.cellHeight))
|
||||||
|
|
||||||
|
configKey: width > height ? "ItemGeometriesHorizontal" : "ItemGeometriesVertical"
|
||||||
|
containment: plasmoid
|
||||||
|
editModeCondition: plasmoid.immutable
|
||||||
|
? ContainmentLayoutManager.AppletsLayout.Manual
|
||||||
|
: ContainmentLayoutManager.AppletsLayout.AfterPressAndHold
|
||||||
|
|
||||||
|
// Sets the containment in edit mode when we go in edit mode as well
|
||||||
|
onEditModeChanged: plasmoid.editMode = editMode
|
||||||
|
|
||||||
|
minimumItemWidth: units.gridUnit * 3
|
||||||
|
minimumItemHeight: minimumItemWidth
|
||||||
|
|
||||||
|
defaultItemWidth: units.gridUnit * 6
|
||||||
|
defaultItemHeight: defaultItemWidth
|
||||||
|
|
||||||
|
acceptsAppletCallback: function(applet, x, y) {
|
||||||
|
print("Applet: "+applet+" "+x+" "+y)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
appletContainerComponent: ContainmentLayoutManager.BasicAppletContainer {
|
||||||
|
id: appletContainer
|
||||||
|
configOverlayComponent: Private.ConfigOverlay {}
|
||||||
|
|
||||||
|
onEditModeChanged: {
|
||||||
|
launcherDragManager.active = dragActive || editMode;
|
||||||
|
}
|
||||||
|
onDragActiveChanged: {
|
||||||
|
launcherDragManager.active = dragActive || editMode;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
placeHolder: ContainmentLayoutManager.PlaceHolder {}
|
||||||
|
//FIXME: move
|
||||||
|
PlasmaComponents.Label {
|
||||||
|
id: metrics
|
||||||
|
text: "M\nM"
|
||||||
|
visible: false
|
||||||
|
font.pointSize: theme.defaultFont.pointSize * 0.9
|
||||||
|
}
|
||||||
|
LauncherRepeater {
|
||||||
|
id: launcherRepeater
|
||||||
|
cellWidth: appletsLayout.cellWidth
|
||||||
|
cellHeight: appletsLayout.cellHeight
|
||||||
|
appletsLayout: appletsLayout
|
||||||
|
favoriteStrip: favoriteStrip
|
||||||
|
onScrollLeftRequested: mainFlickable.scrollLeft()
|
||||||
|
onScrollRightRequested: mainFlickable.scrollRight()
|
||||||
|
onStopScrollRequested: mainFlickable.stopScroll()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -15,7 +15,10 @@ PlasmaCore.SvgItem {
|
||||||
|
|
||||||
z: 2
|
z: 2
|
||||||
opacity: 0
|
opacity: 0
|
||||||
svg: arrowsSvg
|
svg: PlasmaCore.Svg {
|
||||||
|
imagePath: "widgets/arrows"
|
||||||
|
colorGroup: PlasmaCore.Theme.ComplementaryColorGroup
|
||||||
|
}
|
||||||
elementId: "left-arrow"
|
elementId: "left-arrow"
|
||||||
width: units.iconSizes.large
|
width: units.iconSizes.large
|
||||||
height: width
|
height: width
|
||||||
|
|
|
||||||
|
|
@ -38,7 +38,7 @@ FocusScope {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
plasmoid.nativeInterface.applicationListModel.maxFavoriteCount = Math.max(4, Math.floor(Math.min(width, height) / appletsLayout.cellWidth));
|
plasmoid.nativeInterface.applicationListModel.maxFavoriteCount = Math.max(4, Math.floor(Math.min(width, height) / homeScreenContents.appletsLayout.cellWidth));
|
||||||
}
|
}
|
||||||
|
|
||||||
//END functions
|
//END functions
|
||||||
|
|
@ -89,18 +89,11 @@ FocusScope {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: plasmoid
|
|
||||||
function onEditModeChanged() {
|
|
||||||
appletsLayout.editMode = plasmoid.editMode
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Launcher.LauncherDragManager {
|
Launcher.LauncherDragManager {
|
||||||
id: launcherDragManager
|
id: launcherDragManager
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
z: 2
|
z: 2
|
||||||
appletsLayout: appletsLayout
|
appletsLayout: homeScreenContents.appletsLayout
|
||||||
favoriteStrip: favoriteStrip
|
favoriteStrip: favoriteStrip
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -113,187 +106,14 @@ FocusScope {
|
||||||
bottomMargin: favoriteStrip.height + plasmoid.screenGeometry.height - plasmoid.availableScreenRect.height - plasmoid.availableScreenRect.y
|
bottomMargin: favoriteStrip.height + plasmoid.screenGeometry.height - plasmoid.availableScreenRect.height - plasmoid.availableScreenRect.y
|
||||||
}
|
}
|
||||||
|
|
||||||
|
appletsLayout: homeScreenContents.appletsLayout
|
||||||
|
|
||||||
appDrawer: appDrawer
|
appDrawer: appDrawer
|
||||||
contentWidth: Math.max(width, width * Math.ceil(appletsLayout.childrenRect.width/width)) + (launcherDragManager.active ? width : 0)
|
contentWidth: Math.max(width, width * Math.ceil(homeScreenContents.itemsBoundingRect.width/width)) + (launcherDragManager.active ? width : 0)
|
||||||
|
|
||||||
// TODO: span on multiple pages
|
Launcher.HomeScreenContents {
|
||||||
DragDrop.DropArea {
|
id: homeScreenContents
|
||||||
id: dropArea
|
|
||||||
width: mainFlickable.width * 100
|
width: mainFlickable.width * 100
|
||||||
//width: Math.max(mainFlickable.width, mainFlickable.width * Math.ceil(appletsLayout.childrenRect.width/mainFlickable.width))
|
|
||||||
height: mainFlickable.height + favoriteStrip.height + units.gridUnit
|
|
||||||
|
|
||||||
onDragEnter: {
|
|
||||||
event.accept(event.proposedAction);
|
|
||||||
launcherDragManager.active = true;
|
|
||||||
}
|
|
||||||
onDragMove: {
|
|
||||||
let posInFavorites = favoriteStrip.mapFromItem(this, event.x, event.y);
|
|
||||||
if (posInFavorites.y > 0) {
|
|
||||||
if (plasmoid.nativeInterface.applicationListModel.favoriteCount >= plasmoid.nativeInterface.applicationListModel.maxFavoriteCount ) {
|
|
||||||
launcherDragManager.hideSpacer();
|
|
||||||
} else {
|
|
||||||
launcherDragManager.showSpacerAtPos(event.x, event.y, favoriteStrip);
|
|
||||||
}
|
|
||||||
appletsLayout.hidePlaceHolder();
|
|
||||||
} else {
|
|
||||||
appletsLayout.showPlaceHolderAt(
|
|
||||||
Qt.rect(event.x - appletsLayout.defaultItemWidth / 2,
|
|
||||||
event.y - appletsLayout.defaultItemHeight / 2,
|
|
||||||
appletsLayout.defaultItemWidth,
|
|
||||||
appletsLayout.defaultItemHeight)
|
|
||||||
);
|
|
||||||
launcherDragManager.hideSpacer();
|
|
||||||
|
|
||||||
//SCROLL LEFT
|
|
||||||
if (event.x < units.gridUnit) {
|
|
||||||
mainFlickable.scrollLeft();
|
|
||||||
//SCROLL RIGHT
|
|
||||||
} else if (event.x > mainFlickable.width - units.gridUnit) {
|
|
||||||
mainFlickable.scrollRight();
|
|
||||||
//DON't SCROLL
|
|
||||||
} else {
|
|
||||||
mainFlickable.stopScroll();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
onDragLeave: {
|
|
||||||
appletsLayout.hidePlaceHolder();
|
|
||||||
launcherDragManager.active = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
preventStealing: true
|
|
||||||
|
|
||||||
onDrop: {
|
|
||||||
launcherDragManager.active = false;
|
|
||||||
if (event.mimeData.formats[0] === "text/x-plasma-phone-homescreen-launcher") {
|
|
||||||
let storageId = event.mimeData.getDataAsByteArray("text/x-plasma-phone-homescreen-launcher");
|
|
||||||
|
|
||||||
let posInFavorites = favoriteStrip.flow.mapFromItem(this, event.x, event.y);
|
|
||||||
if (posInFavorites.y > 0) {
|
|
||||||
if (plasmoid.nativeInterface.applicationListModel.favoriteCount >= plasmoid.nativeInterface.applicationListModel.maxFavoriteCount ) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let pos = Math.min(plasmoid.nativeInterface.applicationListModel.count, Math.floor(posInFavorites.x/favoriteStrip.cellWidth))
|
|
||||||
plasmoid.nativeInterface.applicationListModel.addFavorite(storageId, pos, ApplicationListModel.Favorites)
|
|
||||||
let item = launcherRepeater.itemAt(pos);
|
|
||||||
|
|
||||||
if (item) {
|
|
||||||
item.x = posInFavorites.x;
|
|
||||||
item.y = 0//posInFavorites.y;
|
|
||||||
|
|
||||||
//launcherDragManager.showSpacer(item, item.width/2, item.height/2);
|
|
||||||
launcherDragManager.dropItem(item, item.width/2, item.height/2);
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
let pos = plasmoid.nativeInterface.applicationListModel.count;
|
|
||||||
plasmoid.nativeInterface.applicationListModel.addFavorite(storageId, pos, ApplicationListModel.Desktop)
|
|
||||||
let item = launcherRepeater.itemAt(pos);
|
|
||||||
|
|
||||||
event.accept(event.proposedAction);
|
|
||||||
if (item) {
|
|
||||||
item.x = appletsLayout.placeHolder.x;
|
|
||||||
item.y = appletsLayout.placeHolder.y;
|
|
||||||
appletsLayout.hidePlaceHolder();
|
|
||||||
launcherDragManager.dropItem(item, appletsLayout.placeHolder.x + appletsLayout.placeHolder.width/2, appletsLayout.placeHolder.y + appletsLayout.placeHolder.height/2);
|
|
||||||
}
|
|
||||||
appletsLayout.hidePlaceHolder();
|
|
||||||
} else {
|
|
||||||
plasmoid.processMimeData(event.mimeData,
|
|
||||||
event.x - appletsLayout.placeHolder.width / 2, event.y - appletsLayout.placeHolder.height / 2);
|
|
||||||
event.accept(event.proposedAction);
|
|
||||||
appletsLayout.hidePlaceHolder();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
PlasmaCore.Svg {
|
|
||||||
id: arrowsSvg
|
|
||||||
imagePath: "widgets/arrows"
|
|
||||||
colorGroup: PlasmaCore.Theme.ComplementaryColorGroup
|
|
||||||
}
|
|
||||||
|
|
||||||
ContainmentLayoutManager.AppletsLayout {
|
|
||||||
id: appletsLayout
|
|
||||||
|
|
||||||
anchors {
|
|
||||||
fill: parent
|
|
||||||
bottomMargin: favoriteStrip.height
|
|
||||||
}
|
|
||||||
|
|
||||||
signal appletsLayoutInteracted
|
|
||||||
|
|
||||||
TapHandler {
|
|
||||||
target: mainFlickable
|
|
||||||
enabled: appDrawer.status !== Launcher.AppDrawer.Status.Open
|
|
||||||
onTapped: {
|
|
||||||
//Hides icons close button
|
|
||||||
appletsLayout.appletsLayoutInteracted();
|
|
||||||
appletsLayout.editMode = false;
|
|
||||||
}
|
|
||||||
onLongPressed: appletsLayout.editMode = true;
|
|
||||||
onPressedChanged: root.focus = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
cellWidth: favoriteStrip.cellWidth
|
|
||||||
cellHeight: Math.floor(height / Math.floor(height / favoriteStrip.cellHeight))
|
|
||||||
|
|
||||||
configKey: width > height ? "ItemGeometriesHorizontal" : "ItemGeometriesVertical"
|
|
||||||
containment: plasmoid
|
|
||||||
editModeCondition: plasmoid.immutable
|
|
||||||
? ContainmentLayoutManager.AppletsLayout.Manual
|
|
||||||
: ContainmentLayoutManager.AppletsLayout.AfterPressAndHold
|
|
||||||
|
|
||||||
// Sets the containment in edit mode when we go in edit mode as well
|
|
||||||
onEditModeChanged: plasmoid.editMode = editMode
|
|
||||||
|
|
||||||
minimumItemWidth: units.gridUnit * 3
|
|
||||||
minimumItemHeight: minimumItemWidth
|
|
||||||
|
|
||||||
defaultItemWidth: units.gridUnit * 6
|
|
||||||
defaultItemHeight: defaultItemWidth
|
|
||||||
|
|
||||||
acceptsAppletCallback: function(applet, x, y) {
|
|
||||||
print("Applet: "+applet+" "+x+" "+y)
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
appletContainerComponent: ContainmentLayoutManager.BasicAppletContainer {
|
|
||||||
id: appletContainer
|
|
||||||
configOverlayComponent: ConfigOverlay {}
|
|
||||||
|
|
||||||
onEditModeChanged: {
|
|
||||||
launcherDragManager.active = dragActive || editMode;
|
|
||||||
}
|
|
||||||
onDragActiveChanged: {
|
|
||||||
launcherDragManager.active = dragActive || editMode;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
placeHolder: ContainmentLayoutManager.PlaceHolder {}
|
|
||||||
//FIXME: move
|
|
||||||
PlasmaComponents.Label {
|
|
||||||
id: metrics
|
|
||||||
text: "M\nM"
|
|
||||||
visible: false
|
|
||||||
font.pointSize: theme.defaultFont.pointSize * 0.9
|
|
||||||
}
|
|
||||||
Launcher.LauncherRepeater {
|
|
||||||
id: launcherRepeater
|
|
||||||
cellWidth: appletsLayout.cellWidth
|
|
||||||
cellHeight: appletsLayout.cellHeight
|
|
||||||
appletsLayout: appletsLayout
|
|
||||||
favoriteStrip: favoriteStrip
|
|
||||||
onScrollLeftRequested: mainFlickable.scrollLeft()
|
|
||||||
onScrollRightRequested: mainFlickable.scrollRight()
|
|
||||||
onStopScrollRequested: mainFlickable.stopScroll()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -313,23 +133,25 @@ FocusScope {
|
||||||
bottom: parent.bottom
|
bottom: parent.bottom
|
||||||
bottomMargin: plasmoid.screenGeometry.height - plasmoid.availableScreenRect.height - plasmoid.availableScreenRect.y
|
bottomMargin: plasmoid.screenGeometry.height - plasmoid.availableScreenRect.height - plasmoid.availableScreenRect.y
|
||||||
}
|
}
|
||||||
appletsLayout: appletsLayout
|
appletsLayout: homeScreenContents.appletsLayout
|
||||||
|
|
||||||
|
visible: flow.children.length > 0 || launcherDragManager.active || homeScreenContents.containsDrag
|
||||||
|
|
||||||
LauncherPrivate.DragGestureHandler {
|
LauncherPrivate.DragGestureHandler {
|
||||||
target: favoriteStrip
|
target: favoriteStrip
|
||||||
appDrawer: appDrawer
|
appDrawer: appDrawer
|
||||||
mainFlickable: mainFlickable
|
mainFlickable: mainFlickable
|
||||||
enabled: root.focus && appDrawer.status !== Launcher.AppDrawer.Status.Open && !appletsLayout.editMode && !plasmoid.editMode && !launcherDragManager.active
|
enabled: root.focus && appDrawer.status !== Launcher.AppDrawer.Status.Open && !homeScreenContents.appletsLayout.editMode && !plasmoid.editMode && !launcherDragManager.active
|
||||||
onSnapPage: mainFlickable.snapPage();
|
onSnapPage: mainFlickable.snapPage();
|
||||||
}
|
}
|
||||||
TapHandler {
|
TapHandler {
|
||||||
target: favoriteStrip
|
target: favoriteStrip
|
||||||
onTapped: {
|
onTapped: {
|
||||||
//Hides icons close button
|
//Hides icons close button
|
||||||
appletsLayout.appletsLayoutInteracted();
|
homeScreenContents.appletsLayout.appletsLayoutInteracted();
|
||||||
appletsLayout.editMode = false;
|
homeScreenContents.appletsLayout.editMode = false;
|
||||||
}
|
}
|
||||||
onLongPressed: appletsLayout.editMode = true;
|
onLongPressed: homeScreenContents.appletsLayout.editMode = true;
|
||||||
onPressedChanged: root.focus = true;
|
onPressedChanged: root.focus = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue