shift-shell/containments/taskpanel/package/contents/ui/main.qml

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

124 lines
4.3 KiB
QML
Raw Normal View History

// SPDX-FileCopyrightText: 2015 Marco Martin <mart@kde.org>
// SPDX-FileCopyrightText: 2021-2023 Devin Lin <devin@kde.org>
// SPDX-License-Identifier: GPL-2.0-or-later
import QtQuick 2.4
import QtQuick.Layouts 1.1
import QtQuick.Window 2.15
import org.kde.kirigami 2.20 as Kirigami
import org.kde.taskmanager 0.1 as TaskManager
import org.kde.plasma.plasmoid 2.0
import org.kde.plasma.core as PlasmaCore
import org.kde.kquickcontrolsaddons 2.0
import org.kde.plasma.private.mobileshell as MobileShell
import org.kde.plasma.private.mobileshell.shellsettingsplugin as ShellSettings
import org.kde.plasma.private.mobileshell.windowplugin as WindowPlugin
2020-07-22 15:17:10 +00:00
ContainmentItem {
2015-06-18 23:31:26 +00:00
id: root
Plasmoid.backgroundHints: PlasmaCore.Types.NoBackground
2023-10-17 05:12:44 +00:00
// filled in by the shell (Panel.qml) with the plasma-workspace PanelView
property var panel: null
onPanelChanged: {
setWindowProperties()
}
// filled in by the shell (Panel.qml)
property var tabBar: null
onTabBarChanged: {
if (tabBar) {
tabBar.visible = false;
}
}
2023-03-03 06:11:51 +00:00
readonly property bool inLandscape: Screen.width > Screen.height;
readonly property real navigationPanelHeight: Kirigami.Units.gridUnit * 2
2023-03-03 06:11:51 +00:00
readonly property real intendedWindowThickness: navigationPanelHeight
readonly property real intendedWindowLength: inLandscape ? Screen.height : Screen.width
readonly property real intendedWindowOffset: inLandscape ? MobileShell.Constants.topPanelHeight : 0; // offset for top panel
readonly property int intendedWindowLocation: inLandscape ? PlasmaCore.Types.RightEdge : PlasmaCore.Types.BottomEdge
2023-03-03 06:11:51 +00:00
onIntendedWindowLengthChanged: maximizeTimer.restart() // ensure it always takes up the full length of the screen
onIntendedWindowLocationChanged: locationChangeTimer.restart()
onIntendedWindowOffsetChanged: {
2023-10-17 05:12:44 +00:00
if (root.panel) {
root.panel.offset = intendedWindowOffset;
}
}
2023-03-03 06:11:51 +00:00
// use a timer so we don't have to maximize for every single pixel
// - improves performance if the shell is run in a window, and can be resized
Timer {
id: maximizeTimer
running: false
interval: 100
onTriggered: {
// maximize first, then we can apply offsets (otherwise they are overridden)
2023-10-17 05:12:44 +00:00
root.panel.maximize()
root.panel.offset = intendedWindowOffset;
2023-03-03 06:11:51 +00:00
}
}
// use a timer so that rotation events are faster (offload the panel movement to later, after everything is figured out)
Timer {
id: locationChangeTimer
running: false
interval: 100
2023-10-17 05:12:44 +00:00
onTriggered: root.panel.location = intendedWindowLocation
2023-03-03 06:11:51 +00:00
}
function setWindowProperties() {
2023-10-17 05:12:44 +00:00
if (root.panel) {
root.panel.floating = false;
2023-10-17 05:12:44 +00:00
root.panel.maximize(); // maximize first, then we can apply offsets (otherwise they are overridden)
root.panel.offset = intendedWindowOffset;
root.panel.thickness = navigationPanelHeight;
root.panel.location = intendedWindowLocation;
}
2023-03-03 06:11:51 +00:00
}
Connections {
2023-10-17 05:12:44 +00:00
target: root.panel
2023-03-03 06:11:51 +00:00
// HACK: There seems to be some component that overrides our initial bindings for the panel,
// which is particularly problematic on first start (since the panel is misplaced)
// - We set an event to override any attempts to override our bindings.
function onLocationChanged() {
2023-10-17 05:12:44 +00:00
if (root.panel.location !== root.intendedWindowLocation) {
2023-03-03 06:11:51 +00:00
root.setWindowProperties();
}
}
function onThicknessChanged() {
2023-10-17 05:12:44 +00:00
if (root.panel.thickness !== root.intendedWindowThickness) {
2023-03-03 06:11:51 +00:00
root.setWindowProperties();
}
}
}
Component.onCompleted: setWindowProperties();
// only opaque if there are no maximized windows on this screen
readonly property bool opaqueBar: WindowPlugin.WindowMaximizedTracker.showingWindow
2023-03-03 06:11:51 +00:00
Item {
2023-03-03 06:11:51 +00:00
anchors.fill: parent
// contrasting colour
Kirigami.Theme.colorSet: opaqueBar ? Kirigami.Theme.Window : Kirigami.Theme.Complementary
Kirigami.Theme.inherit: false
// load appropriate system navigation component
NavigationPanelComponent {
anchors.fill: parent
opaqueBar: root.opaqueBar
}
2023-03-03 06:11:51 +00:00
}
}