2022-10-04 22:25:14 +02:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
2022-10-14 10:29:36 +02:00
|
|
|
import QtQuick.Layouts 1.14
|
2022-10-04 22:25:14 +02:00
|
|
|
|
|
|
|
import Qt.labs.settings 1.0
|
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import Storybook 1.0
|
2022-10-04 22:25:14 +02:00
|
|
|
|
|
|
|
ApplicationWindow {
|
2022-10-14 10:29:36 +02:00
|
|
|
id: root
|
2022-10-04 22:25:14 +02:00
|
|
|
|
|
|
|
width: 1450
|
|
|
|
height: 840
|
|
|
|
visible: true
|
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
property string currentPage
|
2022-10-04 22:25:14 +02:00
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
font.pixelSize: 13
|
|
|
|
|
2022-10-18 20:47:41 +02:00
|
|
|
HotReloader {
|
2022-10-19 21:51:39 +02:00
|
|
|
id: reloader
|
2022-10-18 20:47:41 +02:00
|
|
|
|
2022-10-19 21:51:39 +02:00
|
|
|
loader: viewLoader
|
|
|
|
enabled: hotReloaderControls.enabled
|
|
|
|
onReloaded: hotReloaderControls.notifyReload()
|
2022-10-18 20:47:41 +02:00
|
|
|
}
|
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
ListModel {
|
|
|
|
id: pagesModel
|
2022-10-04 22:25:14 +02:00
|
|
|
|
2022-10-20 17:12:38 +02:00
|
|
|
ListElement {
|
|
|
|
title: "ProfileDialogView"
|
|
|
|
}
|
2022-10-14 10:29:36 +02:00
|
|
|
ListElement {
|
|
|
|
title: "CommunitiesPortalLayout"
|
2022-10-04 22:25:14 +02:00
|
|
|
}
|
2022-10-19 21:51:39 +02:00
|
|
|
ListElement {
|
|
|
|
title: "StatusCommunityCard"
|
|
|
|
}
|
2022-10-14 10:29:36 +02:00
|
|
|
ListElement {
|
|
|
|
title: "LoginView"
|
|
|
|
}
|
2022-10-13 15:02:40 -04:00
|
|
|
ListElement {
|
|
|
|
title: "AboutView"
|
|
|
|
}
|
2022-10-13 16:56:25 -04:00
|
|
|
ListElement {
|
|
|
|
title: "LanguageCurrencySettings"
|
|
|
|
}
|
2022-10-25 10:24:47 +02:00
|
|
|
ListElement {
|
|
|
|
title: "CommunityProfilePopupInviteFriendsPanel"
|
|
|
|
}
|
|
|
|
ListElement {
|
|
|
|
title: "CommunityProfilePopupInviteMessagePanel"
|
|
|
|
}
|
|
|
|
ListElement {
|
|
|
|
title: "InviteFriendsToCommunityPopup"
|
|
|
|
}
|
2022-10-25 09:57:04 -04:00
|
|
|
ListElement {
|
|
|
|
title: "BrowserSettings"
|
|
|
|
}
|
2022-11-08 22:23:55 +01:00
|
|
|
ListElement {
|
|
|
|
title: "CreateChannelPopup"
|
|
|
|
}
|
2022-10-14 10:29:36 +02:00
|
|
|
}
|
2022-10-04 22:25:14 +02:00
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
SplitView {
|
|
|
|
anchors.fill: parent
|
2022-10-04 22:25:14 +02:00
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
ColumnLayout {
|
|
|
|
SplitView.preferredWidth: 240
|
2022-10-04 23:51:14 +02:00
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
CheckBox {
|
|
|
|
id: loadAsyncCheckBox
|
2022-10-12 13:02:37 +02:00
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
Layout.fillWidth: true
|
|
|
|
|
|
|
|
text: "Load asynchronously"
|
|
|
|
}
|
2022-10-12 13:02:37 +02:00
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
CheckBox {
|
|
|
|
id: darkModeCheckBox
|
2022-10-12 13:02:37 +02:00
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
Layout.fillWidth: true
|
|
|
|
|
|
|
|
text: "Dark mode"
|
|
|
|
|
|
|
|
StatusLightTheme { id: lightTheme }
|
|
|
|
StatusDarkTheme { id: darkTheme }
|
|
|
|
|
|
|
|
Binding {
|
|
|
|
target: Theme
|
|
|
|
property: "palette"
|
|
|
|
value: darkModeCheckBox.checked ? darkTheme : lightTheme
|
2022-10-12 11:42:51 +02:00
|
|
|
}
|
2022-10-14 10:29:36 +02:00
|
|
|
}
|
2022-10-12 11:42:51 +02:00
|
|
|
|
2022-10-19 21:51:39 +02:00
|
|
|
HotReloaderControls {
|
|
|
|
id: hotReloaderControls
|
2022-10-18 20:47:41 +02:00
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
2022-10-19 21:51:39 +02:00
|
|
|
onForceReloadClicked: reloader.forceReload()
|
2022-10-18 20:47:41 +02:00
|
|
|
}
|
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
Pane {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
2022-11-08 11:19:14 +01:00
|
|
|
FilteredPagesList {
|
2022-10-14 10:29:36 +02:00
|
|
|
anchors.fill: parent
|
|
|
|
currentPage: root.currentPage
|
|
|
|
model: pagesModel
|
|
|
|
|
|
|
|
onPageSelected: root.currentPage = page
|
2022-10-04 23:51:14 +02:00
|
|
|
}
|
2022-10-04 22:25:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-14 10:29:36 +02:00
|
|
|
Item {
|
|
|
|
SplitView.fillWidth: true
|
2022-10-04 22:25:14 +02:00
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: viewLoader
|
2022-10-12 13:02:37 +02:00
|
|
|
|
2022-10-04 22:25:14 +02:00
|
|
|
anchors.fill: parent
|
|
|
|
clip: true
|
2022-10-12 13:02:37 +02:00
|
|
|
|
2022-10-18 20:47:41 +02:00
|
|
|
source: `pages/${root.currentPage}Page.qml`
|
2022-10-14 10:29:36 +02:00
|
|
|
asynchronous: loadAsyncCheckBox.checked
|
2022-10-12 13:02:37 +02:00
|
|
|
visible: status === Loader.Ready
|
|
|
|
|
|
|
|
// force reload when `asynchronous` changes
|
|
|
|
onAsynchronousChanged: {
|
2022-10-14 10:29:36 +02:00
|
|
|
active = false
|
|
|
|
active = true
|
2022-10-12 13:02:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
BusyIndicator {
|
|
|
|
anchors.centerIn: parent
|
|
|
|
visible: viewLoader.status === Loader.Loading
|
2022-10-04 22:25:14 +02:00
|
|
|
}
|
2022-10-19 21:51:39 +02:00
|
|
|
|
|
|
|
Label {
|
|
|
|
anchors.centerIn: parent
|
|
|
|
visible: viewLoader.status === Loader.Error
|
|
|
|
text: "Loading page failed"
|
|
|
|
}
|
2022-10-04 22:25:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Settings {
|
2022-10-14 10:29:36 +02:00
|
|
|
property alias currentPage: root.currentPage
|
|
|
|
property alias loadAsynchronously: loadAsyncCheckBox.checked
|
|
|
|
property alias darkMode: darkModeCheckBox.checked
|
2022-10-19 21:51:39 +02:00
|
|
|
property alias hotReloading: hotReloaderControls.enabled
|
2022-10-04 22:25:14 +02:00
|
|
|
}
|
|
|
|
}
|