// SPDX-License-Identifier: LGPL-3.0-or-later import QtQuick 2.12 import QtQuick.Controls 2.12 import QtQuick.Layouts 1.12 import QtQuick.Window 2.12 import QtGraphicalEffects 1.12 import "Base" import "MainPane" HLoader { id: pageLoader property bool isWide: width > theme.contentIsWideAbove // List of previously loaded [componentUrl, {properties}] property var history: [] property int historyLength: 20 readonly property alias appearAnimation: appearAnimation signal recycled() signal previousShown(string componentUrl, var properties) function showPage(componentUrl, properties={}) { history.unshift([componentUrl, properties]) if (history.length > historyLength) history.pop() const recycle = window.uiState.page === componentUrl && componentUrl === "Pages/Chat/Chat.qml" && item if (recycle) { for (const [prop, value] of Object.entries(properties)) item[prop] = value recycled() } else { pageLoader.setSource(componentUrl, properties) window.uiState.page = componentUrl } window.uiState.pageProperties = properties window.uiStateChanged() } function showRoom(userId, roomId) { showPage("Pages/Chat/Chat.qml", {userId, roomId}) } function showPrevious(timesBack=1) { timesBack = Math.min(timesBack, history.length - 1) if (timesBack < 1) return false const [componentUrl, properties] = history[timesBack] showPage(componentUrl, properties) previousShown(componentUrl, properties) return true } function closeMainPane() { if (mainPane.collapse) mainPane.close() } function takeFocus() { pageLoader.item.forceActiveFocus() closeMainPane() } clip: appearAnimation.running onLoaded: { takeFocus(); appearAnimation.restart() } onRecycled: { closeMainPane(); appearAnimation.restart() } Component.onCompleted: { if (! py.startupAnyAccountsSaved) { pageLoader.showPage( "AddAccount/AddAccount", {"header.show": false}, ) return } const page = window.uiState.page const props = window.uiState.pageProperties if (page === "Pages/Chat/Chat.qml") { pageLoader.showRoom(props.userId, props.roomId) } else { pageLoader._show(page, props) } } HNumberAnimation { id: appearAnimation target: pageLoader.item property: "x" from: -pageLoader.width to: 0 easing.type: Easing.OutCirc factor: 2 } HShortcut { sequences: window.settings.keys.goToLastPage onActivated: showPrevious() } }