status-desktop/app/qml/Status/Application/StatusContentView.qml
Stefan cecfd7f8e8 chore(CPP): base for the window and layouting system
Demo controls migrations to Qt6
POC for an application layout with isolated components

Closes: #5902
2022-07-01 16:57:51 +02:00

74 lines
1.7 KiB
QML

import QtQml
import QtQuick
import QtQuick.Controls
import Status.Application
import Status.Onboarding
import Status.Controls.Navigation
/*! Has entry responsibility for the main workflows
*/
Item {
id: root
required property ApplicationState appState
required property ApplicationController appController
implicitWidth: d.isViewLoaded ? d.loadedView.implicitWidth : 800
implicitHeight: d.isViewLoaded ? d.loadedView.implicitHeight : 600
QtObject {
id: d
readonly property bool isViewLoaded: contentLoader.status === Loader.Ready
readonly property Item loadedView: isViewLoaded ? contentLoader.item : null
}
Component {
id: onboardingViewComponent
OnboardingView {
onUserLoggedIn: {
splashScreenPopup.open()
contentLoader.sourceComponent = mainViewComponent
}
}
}
Component {
id: mainViewComponent
MainView {
onReady: splashScreenPopup.close()
appController: root.appController
}
}
Popup {
id: splashScreenPopup
onAboutToShow: splashScreenLoader.active = true
onClosed: splashScreenLoader.active = false
anchors.centerIn: Overlay.overlay
Loader {
id: splashScreenLoader
active: false
sourceComponent: SplashScreen {
id: splasScreen
onAnimationFinished: splashScreenPopup.close()
}
onStatusChanged: if(status === Loader.Ready) item.show()
}
background: Item {}
}
Loader {
id: contentLoader
anchors.fill: parent
sourceComponent: onboardingViewComponent
}
}