mirror of
https://invent.kde.org/marcoa/shift-shell.git
synced 2026-04-26 22:33:08 +00:00
Make sure that the view colorset is correct, remove unnecessary layer (clip is enabled), and remove unnecessary visibility hack for the notifications widget.
97 lines
4.4 KiB
QML
97 lines
4.4 KiB
QML
// SPDX-FileCopyrightText: 2021-2024 Devin Lin <devin@kde.org>
|
|
// SPDX-License-Identifier: LGPL-2.0-or-later
|
|
|
|
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
import QtQuick.Layouts
|
|
import QtQuick.Window 2.2
|
|
|
|
import org.kde.plasma.private.mobileshell as MobileShell
|
|
import org.kde.plasma.components 3.0 as PlasmaComponents
|
|
import org.kde.kirigami 2.20 as Kirigami
|
|
import org.kde.plasma.private.mobileshell.quicksettingsplugin as QS
|
|
|
|
/**
|
|
* Root element that contains all the ActionDrawer's contents, and is anchored to the screen.
|
|
*/
|
|
Item {
|
|
id: root
|
|
|
|
required property var actionDrawer
|
|
|
|
// pinned position (disabled when openToPinnedMode is false)
|
|
readonly property real minimizedQuickSettingsOffset: quickSettingsDrawer.minimizedHeight
|
|
|
|
// fully open position
|
|
readonly property real maximizedQuickSettingsOffset: minimizedQuickSettingsOffset + quickSettingsDrawer.maxAddedHeight
|
|
|
|
property alias quickSettings: quickSettingsDrawer.quickSettings
|
|
property alias statusBar: quickSettingsDrawer.statusBar
|
|
property alias mediaControlsWidget: quickSettingsDrawer.mediaControlsWidget
|
|
property alias notificationsWidget: notificationWidgetProxy.contentItem
|
|
|
|
Kirigami.Theme.colorSet: Kirigami.Theme.View
|
|
Kirigami.Theme.inherit: false
|
|
|
|
function applyMinMax(val) {
|
|
return Math.max(0, Math.min(1, val));
|
|
}
|
|
|
|
MobileShell.QuickSettingsDrawer {
|
|
id: quickSettingsDrawer
|
|
z: 1 // ensure it's above notifications
|
|
|
|
// physically move the drawer when between closed <-> pinned mode
|
|
readonly property real offsetHeight: actionDrawer.openToPinnedMode ? minimizedQuickSettingsOffset : maximizedQuickSettingsOffset
|
|
anchors.topMargin: Math.min(root.actionDrawer.offset - offsetHeight, 0)
|
|
anchors.top: parent.top
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
|
|
actionDrawer: root.actionDrawer
|
|
|
|
// opacity and move animation (disabled when openToPinnedMode is false)
|
|
property real offsetDist: actionDrawer.offset - minimizedQuickSettingsOffset
|
|
property real totalOffsetDist: maximizedQuickSettingsOffset - minimizedQuickSettingsOffset
|
|
minimizedToFullProgress: actionDrawer.openToPinnedMode ? (actionDrawer.opened ? applyMinMax(offsetDist / totalOffsetDist) : 0) : 1
|
|
|
|
// this drawer opens in two stages when pinned mode is enabled:
|
|
// ---
|
|
// stage 1: the transform effect is used, the drawer physically moves down to the pinned mode
|
|
// stage 2: the rectangle increases height to reveal content, but the content stays still
|
|
// when pinned mode is disabled, only stage 1 happens
|
|
|
|
// increase height of drawer when between pinned mode <-> maximized mode
|
|
addedHeight: {
|
|
if (!actionDrawer.openToPinnedMode) {
|
|
// if pinned mode disabled, just go to full height
|
|
let progress = (root.actionDrawer.offset - maximizedQuickSettingsOffset) / (quickSettingsDrawer.maxAddedHeight * 4);
|
|
let effectProgress = Math.atan(Math.max(0, progress));
|
|
return (quickSettingsDrawer.maxAddedHeight * effectProgress) + quickSettingsDrawer.maxAddedHeight;
|
|
} else if (!actionDrawer.opened) {
|
|
// over-scroll effect for initial opening
|
|
let progress = (root.actionDrawer.offset - minimizedQuickSettingsOffset) / quickSettingsDrawer.maxAddedHeight;
|
|
let effectProgress = Math.atan(Math.max(0, progress));
|
|
return quickSettingsDrawer.maxAddedHeight * 0.25 * effectProgress;
|
|
} else {
|
|
// over-scroll effect for full drawer
|
|
let progress = (root.actionDrawer.offset - maximizedQuickSettingsOffset) / (quickSettingsDrawer.maxAddedHeight * 4);
|
|
let effectProgress = Math.atan(Math.max(0, progress));
|
|
// as the drawer opens, add height to the rectangle, revealing content
|
|
return (quickSettingsDrawer.maxAddedHeight * effectProgress) + Math.max(0, Math.min(quickSettingsDrawer.maxAddedHeight, root.actionDrawer.offset - minimizedQuickSettingsOffset));
|
|
}
|
|
}
|
|
}
|
|
|
|
MobileShell.BaseItem {
|
|
id: notificationWidgetProxy
|
|
|
|
anchors {
|
|
top: quickSettingsDrawer.bottom
|
|
bottom: parent.bottom
|
|
left: parent.left
|
|
right: parent.right
|
|
}
|
|
opacity: applyMinMax(root.actionDrawer.offset / root.minimizedQuickSettingsOffset)
|
|
}
|
|
}
|