shift-shell/components/mobilehomescreencomponents/qml/FlickablePages.qml

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

217 lines
6.6 KiB
QML
Raw Normal View History

2021-03-19 16:30:43 +00:00
/*
* 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 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 "private" as Private
2021-03-19 16:30:43 +00:00
import org.kde.plasma.private.containmentlayoutmanager 1.0 as ContainmentLayoutManager
import org.kde.plasma.private.mobileshell 1.0 as MobileShell
import org.kde.plasma.private.mobilehomescreencomponents 0.1 as HomeScreenComponents
2021-03-19 16:30:43 +00:00
Flickable {
id: mainFlickable
property AbstractAppDrawer appDrawer
2021-03-19 16:30:43 +00:00
readonly property int totalPages: Math.ceil(contentWidth / width)
property int currentIndex: 0
property ContainmentLayoutManager.AppletsLayout appletsLayout: null
2021-04-08 12:54:06 +00:00
property Item footer
property alias dragGestureEnabled: gestureHandler.enabled
opacity: appDrawer ? 1 - appDrawer.openFactor : 1
2021-03-19 16:30:43 +00:00
transform: Translate {
y: appDrawer ? (-mainFlickable.height / 20) * appDrawer.openFactor : 0
2021-03-19 16:30:43 +00:00
}
2021-04-08 10:16:32 +00:00
clip: true
2021-03-19 16:30:43 +00:00
2021-04-08 16:57:20 +00:00
property bool showAddPageIndicator: false
2021-03-19 16:30:43 +00:00
contentHeight: height
interactive: false
signal cancelEditModeForItemsRequested
onDragStarted: cancelEditModeForItemsRequested()
onDragEnded: cancelEditModeForItemsRequested()
onFlickStarted: cancelEditModeForItemsRequested()
onFlickEnded: cancelEditModeForItemsRequested()
2021-03-25 11:50:04 +00:00
//onCurrentIndexChanged: contentX = width * currentIndex;
onContentXChanged: mainFlickable.currentIndex = Math.floor(contentX / width)
2021-03-19 16:30:43 +00:00
2021-04-08 12:54:06 +00:00
onFooterChanged: {
if (footer) {
footer.parent = mainFlickable;
footer.anchors.left = mainFlickable.left;
footer.anchors.bottom = mainFlickable.bottom;
footer.anchors.right = mainFlickable.right;
}
2021-04-08 12:54:06 +00:00
}
//Autoscroll related functions
function scrollLeft() {
if (mainFlickable.atXBeginning) {
return;
}
autoScrollTimer.scrollRight = false;
autoScrollTimer.running = true;
scrollLeftIndicator.opacity = 1;
scrollRightIndicator.opacity = 0;
}
function scrollRight() {
if (mainFlickable.atXEnd) {
return;
}
autoScrollTimer.scrollRight = true;
autoScrollTimer.running = true;
scrollLeftIndicator.opacity = 0;
scrollRightIndicator.opacity = 1;
}
function stopScroll() {
autoScrollTimer.running = false;
scrollLeftIndicator.opacity = 0;
scrollRightIndicator.opacity = 0;
}
function snapPage() {
scrollAnim.running = false;
scrollAnim.to = mainFlickable.width * Math.round(mainFlickable.contentX / mainFlickable.width)
scrollAnim.running = true;
}
2021-03-25 16:04:59 +00:00
function snapNextPage() {
scrollAnim.running = false;
scrollAnim.to = mainFlickable.width * Math.ceil(mainFlickable.contentX / mainFlickable.width)
scrollAnim.running = true;
}
function snapPrevPage() {
scrollAnim.running = false;
scrollAnim.to = mainFlickable.width * Math.floor(mainFlickable.contentX / mainFlickable.width)
scrollAnim.running = true;
}
function scrollToPage(index) {
scrollAnim.running = false;
scrollAnim.to = mainFlickable.width * Math.max(0, Math.min(index, mainFlickable.contentWidth - mainFlickable.width))
scrollAnim.running = true;
}
2021-03-25 16:04:59 +00:00
Timer {
id: autoScrollTimer
property bool scrollRight: true
repeat: true
interval: 1500
onTriggered: {
scrollAnim.to = scrollRight ?
//Scroll Right
Math.min(mainFlickable.contentItem.width - mainFlickable.width, mainFlickable.contentX + mainFlickable.width) :
//Scroll Left
Math.max(0, mainFlickable.contentX - mainFlickable.width);
scrollAnim.running = true;
}
}
Private.DragGestureHandler {
2021-03-19 16:30:43 +00:00
id: gestureHandler
target: appletsLayout
appDrawer: mainFlickable.appDrawer
2021-03-19 16:30:43 +00:00
mainFlickable: mainFlickable
onSnapPage: mainFlickable.snapPage();
2021-03-25 16:04:59 +00:00
onSnapNextPage: mainFlickable.snapNextPage();
onSnapPrevPage: mainFlickable.snapPrevPage();
2021-03-19 16:30:43 +00:00
}
NumberAnimation {
id: scrollAnim
target: mainFlickable
properties: "contentX"
2021-09-13 16:40:56 +00:00
duration: PlasmaCore.Units.longDuration
2021-03-19 16:30:43 +00:00
easing.type: Easing.InOutQuad
}
PlasmaComponents.PageIndicator {
2021-04-08 16:57:20 +00:00
id: pageIndicator
2021-03-19 16:30:43 +00:00
anchors {
bottom: parent.bottom
horizontalCenter: parent.horizontalCenter
2021-04-08 12:54:06 +00:00
bottomMargin: mainFlickable.footer ? mainFlickable.footer.height : 0
2021-03-19 16:30:43 +00:00
}
PlasmaCore.ColorScope.inherit: false
PlasmaCore.ColorScope.colorGroup: PlasmaCore.Theme.ComplementaryColorGroup
parent: mainFlickable
count: mainFlickable.totalPages
2021-03-19 16:30:43 +00:00
visible: count > 1
currentIndex: Math.round(mainFlickable.contentX / mainFlickable.width)
2021-04-08 16:57:20 +00:00
delegate: Rectangle {
property bool isAddPageIndicator: index === pageIndicator.count-1 && mainFlickable.showAddPageIndicator
implicitWidth: PlasmaCore.Units.gridUnit/2
implicitHeight: implicitWidth
radius: width
color: isAddPageIndicator ? "transparent" : PlasmaCore.ColorScope.textColor
PlasmaComponents.Label {
anchors.centerIn: parent
visible: parent.isAddPageIndicator
text: "⊕"
}
opacity: index === currentIndex ? 0.9 : pressed ? 0.7 : 0.5
Behavior on opacity {
OpacityAnimator {
duration: PlasmaCore.Units.longDuration
easing.type: Easing.InOutQuad
}
}
}
2021-03-19 16:30:43 +00:00
}
Item {
z: 9999999
anchors.fill: parent
parent: {
let candidate = mainFlickable;
while (candidate.parent) {
candidate = candidate.parent;
}
return candidate;
}
Private.ScrollIndicator {
id: scrollLeftIndicator
anchors {
left: parent.left
2021-09-13 16:40:56 +00:00
leftMargin: PlasmaCore.Units.smallSpacing
}
elementId: "left-arrow"
}
Private.ScrollIndicator {
id: scrollRightIndicator
anchors {
right: parent.right
2021-09-13 16:40:56 +00:00
rightMargin: PlasmaCore.Units.smallSpacing
}
elementId: "right-arrow"
}
}
2021-03-19 16:30:43 +00:00
}