2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
2020-05-12 07:24:08 +10:00
|
|
|
import Qt.labs.platform 1.1
|
2020-06-23 16:49:04 -04:00
|
|
|
import Qt.labs.settings 1.0
|
2020-07-10 17:47:31 -04:00
|
|
|
import QtQuick.Window 2.12
|
2020-06-23 16:49:04 -04:00
|
|
|
import QtQml 2.13
|
feat: Support system dark mode theme
Supports system dark mode. Changes the user appearance setting to a 3-way setting of System, Light, Dark.
New accounts will have their appearance setting set to "System", which uses the system setting to determine if dark mode should be applied.
Breaking change: Users who had their settings on Light Theme, will now get the system theme (light or dark). Users who had their theme set to Dark, will now get the Light theme.
At startup, the onboarding screens will have the system-level setting of dark mode applied or not. Once, logged in, the user settings will be applied.
## Note
An appearance setting of "System" is not dynamic to the system-level setting. This means that if a user has "System" set for their appearance (and ie, the user has light mode set), and then user then changes their system setting from light to dark, the app will not respond until it is restarted. This is due to a limitation of Qt not having a reliable way to propagate these changes to QML.
2020-09-29 16:18:00 +10:00
|
|
|
import QtQuick.Controls.Universal 2.12
|
2020-07-12 12:47:46 -04:00
|
|
|
|
2021-05-19 17:03:14 +03:00
|
|
|
import DotherSide 0.1
|
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
import utils 1.0
|
|
|
|
import shared 1.0
|
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.popups 1.0
|
|
|
|
|
2022-03-04 00:50:53 +02:00
|
|
|
import mainui 1.0
|
2022-03-08 13:49:33 -05:00
|
|
|
import AppLayouts.Onboarding 1.0
|
2020-05-12 07:24:08 +10:00
|
|
|
|
2021-05-19 17:03:14 +03:00
|
|
|
StatusWindow {
|
2022-01-27 16:29:17 +01:00
|
|
|
property bool appIsReady: false
|
2020-06-23 16:49:04 -04:00
|
|
|
|
feat: Support system dark mode theme
Supports system dark mode. Changes the user appearance setting to a 3-way setting of System, Light, Dark.
New accounts will have their appearance setting set to "System", which uses the system setting to determine if dark mode should be applied.
Breaking change: Users who had their settings on Light Theme, will now get the system theme (light or dark). Users who had their theme set to Dark, will now get the Light theme.
At startup, the onboarding screens will have the system-level setting of dark mode applied or not. Once, logged in, the user settings will be applied.
## Note
An appearance setting of "System" is not dynamic to the system-level setting. This means that if a user has "System" set for their appearance (and ie, the user has light mode set), and then user then changes their system setting from light to dark, the app will not respond until it is restarted. This is due to a limitation of Qt not having a reliable way to propagate these changes to QML.
2020-09-29 16:18:00 +10:00
|
|
|
Universal.theme: Universal.System
|
|
|
|
|
2020-05-12 07:24:08 +10:00
|
|
|
id: applicationWindow
|
2021-08-12 13:52:04 +02:00
|
|
|
objectName: "mainWindow"
|
2021-04-08 11:44:58 -04:00
|
|
|
minimumWidth: 900
|
2022-07-14 00:13:37 +02:00
|
|
|
minimumHeight: 680
|
2020-07-13 14:45:54 -04:00
|
|
|
color: Style.current.background
|
2020-06-23 16:49:04 -04:00
|
|
|
title: {
|
|
|
|
// Set application settings
|
2022-07-19 14:12:29 +02:00
|
|
|
Qt.application.name = "Status Desktop"
|
|
|
|
Qt.application.displayName = qsTr("Status Desktop")
|
2020-06-23 16:49:04 -04:00
|
|
|
Qt.application.organization = "Status"
|
|
|
|
Qt.application.domain = "status.im"
|
2022-07-19 14:12:29 +02:00
|
|
|
return Qt.application.displayName
|
2020-06-23 16:49:04 -04:00
|
|
|
}
|
2020-05-12 07:24:08 +10:00
|
|
|
visible: true
|
2020-05-18 11:07:30 -04:00
|
|
|
|
2022-05-16 09:57:51 +03:00
|
|
|
function restoreAppState() {
|
|
|
|
let geometry = localAppSettings.geometry;
|
|
|
|
let visibility = localAppSettings.visibility;
|
|
|
|
|
|
|
|
if (visibility !== Window.Windowed &&
|
|
|
|
visibility !== Window.Maximized &&
|
|
|
|
visibility !== Window.FullScreen) {
|
|
|
|
visibility = Window.Windowed;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (geometry === undefined) {
|
|
|
|
let screen = Qt.application.screens[0];
|
|
|
|
|
|
|
|
geometry = Qt.rect(0,
|
|
|
|
0,
|
|
|
|
Math.min(Screen.desktopAvailableWidth - 125, 1400),
|
|
|
|
Math.min(Screen.desktopAvailableHeight - 125, 840));
|
|
|
|
geometry.x = (screen.width - geometry.width) / 2;
|
|
|
|
geometry.y = (screen.height - geometry.height) / 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
applicationWindow.visibility = visibility;
|
2022-07-19 14:15:00 +02:00
|
|
|
if (visibility === Window.Windowed) {
|
2022-05-16 09:57:51 +03:00
|
|
|
applicationWindow.x = geometry.x;
|
|
|
|
applicationWindow.y = geometry.y;
|
|
|
|
applicationWindow.width = geometry.width;
|
|
|
|
applicationWindow.height = geometry.height;
|
|
|
|
}
|
2021-11-26 13:58:15 +01:00
|
|
|
}
|
|
|
|
|
2022-05-16 09:57:51 +03:00
|
|
|
function storeAppState() {
|
|
|
|
if (!applicationWindow.appIsReady)
|
|
|
|
return;
|
|
|
|
|
|
|
|
localAppSettings.visibility = applicationWindow.visibility;
|
2022-07-19 14:15:00 +02:00
|
|
|
if (applicationWindow.visibility === Window.Windowed) {
|
2022-05-16 09:57:51 +03:00
|
|
|
localAppSettings.geometry = Qt.rect(applicationWindow.x, applicationWindow.y,
|
|
|
|
applicationWindow.width, applicationWindow.height);
|
|
|
|
}
|
2021-11-26 13:58:15 +01:00
|
|
|
}
|
|
|
|
|
2022-05-16 09:57:51 +03:00
|
|
|
onXChanged: Qt.callLater(storeAppState)
|
|
|
|
onYChanged: Qt.callLater(storeAppState)
|
|
|
|
onWidthChanged: Qt.callLater(storeAppState)
|
|
|
|
onHeightChanged: Qt.callLater(storeAppState)
|
2021-11-26 13:58:15 +01:00
|
|
|
|
2020-11-17 14:07:01 +11:00
|
|
|
Action {
|
|
|
|
shortcut: StandardKey.FullScreen
|
|
|
|
onTriggered: {
|
2022-07-19 14:15:00 +02:00
|
|
|
if (applicationWindow.visibility === Window.FullScreen) {
|
2020-11-17 14:07:01 +11:00
|
|
|
showNormal()
|
|
|
|
} else {
|
|
|
|
showFullScreen()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Action {
|
|
|
|
shortcut: "Ctrl+M"
|
|
|
|
onTriggered: {
|
2022-07-19 14:15:00 +02:00
|
|
|
if (applicationWindow.visibility === Window.Minimized) {
|
2020-11-17 14:07:01 +11:00
|
|
|
showNormal()
|
|
|
|
} else {
|
|
|
|
showMinimized()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-09-21 10:29:33 -05:00
|
|
|
|
2021-01-28 23:00:33 -04:00
|
|
|
Action {
|
|
|
|
shortcut: "Ctrl+W"
|
2021-11-10 13:48:22 +01:00
|
|
|
enabled: loader.item && !!loader.item.appLayout? loader.item.appLayout.appView.currentIndex === Constants.appViewStackIndex.browser
|
2021-04-20 23:15:16 +03:00
|
|
|
: true
|
2021-02-22 13:26:24 -04:00
|
|
|
onTriggered: {
|
|
|
|
applicationWindow.visible = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Action {
|
|
|
|
shortcut: "Ctrl+Q"
|
2021-01-28 23:00:33 -04:00
|
|
|
onTriggered: {
|
|
|
|
Qt.quit()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-16 21:03:01 +02:00
|
|
|
Connections {
|
2021-10-20 11:58:39 +02:00
|
|
|
target: startupModule
|
2022-01-27 16:29:17 +01:00
|
|
|
|
2022-07-19 14:15:00 +02:00
|
|
|
function onStartUpUIRaised() {
|
2022-05-16 09:57:51 +03:00
|
|
|
applicationWindow.appIsReady = true;
|
|
|
|
applicationWindow.storeAppState();
|
2022-01-27 16:29:17 +01:00
|
|
|
}
|
|
|
|
|
2022-07-19 14:15:00 +02:00
|
|
|
function onAppStateChanged(state) {
|
2022-08-05 10:52:29 +02:00
|
|
|
if(state === Constants.appState.startup) {
|
|
|
|
// we're here only in case of error when we're returning from the app loading state
|
|
|
|
loader.sourceComponent = undefined
|
|
|
|
startupOnboarding.visible = true
|
|
|
|
}
|
|
|
|
else if(state === Constants.appState.appLoading) {
|
2022-08-01 16:39:05 +02:00
|
|
|
loader.sourceComponent = appLoadingAnimation
|
2022-08-05 10:52:29 +02:00
|
|
|
startupOnboarding.visible = false
|
2022-08-01 16:39:05 +02:00
|
|
|
}
|
|
|
|
else if(state === Constants.appState.main) {
|
2022-01-12 00:16:17 +01:00
|
|
|
// We set main module to the Global singleton once user is logged in and we move to the main app.
|
|
|
|
Global.mainModuleInst = mainModule
|
2022-07-20 14:34:44 +02:00
|
|
|
loader.sourceComponent = app
|
2022-01-12 00:16:17 +01:00
|
|
|
|
|
|
|
if(localAccountSensitiveSettings.recentEmojis === "") {
|
|
|
|
localAccountSensitiveSettings.recentEmojis = [];
|
|
|
|
}
|
|
|
|
if (localAccountSensitiveSettings.whitelistedUnfurlingSites === "") {
|
|
|
|
localAccountSensitiveSettings.whitelistedUnfurlingSites = {};
|
|
|
|
}
|
|
|
|
if (localAccountSensitiveSettings.hiddenCommunityWelcomeBanners === "") {
|
|
|
|
localAccountSensitiveSettings.hiddenCommunityWelcomeBanners = [];
|
|
|
|
}
|
|
|
|
if (localAccountSensitiveSettings.hiddenCommunityBackUpBanners === "") {
|
|
|
|
localAccountSensitiveSettings.hiddenCommunityBackUpBanners = [];
|
|
|
|
}
|
2022-08-05 10:52:29 +02:00
|
|
|
startupOnboarding.unload()
|
|
|
|
startupOnboarding.visible = false
|
2022-08-30 18:23:21 +03:00
|
|
|
|
|
|
|
Style.changeTheme(localAppSettings.theme, systemPalette.isCurrentSystemThemeDark())
|
2021-11-24 14:30:00 +01:00
|
|
|
}
|
2021-10-16 21:03:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-19 17:03:14 +03:00
|
|
|
//! Workaround for custom QQuickWindow
|
|
|
|
Connections {
|
2021-06-03 11:29:14 +03:00
|
|
|
target: applicationWindow
|
2022-07-19 14:15:00 +02:00
|
|
|
function onClosing(close) {
|
2021-11-17 15:27:19 -05:00
|
|
|
if (Qt.platform.os === "osx") {
|
|
|
|
loader.sourceComponent = undefined
|
|
|
|
close.accepted = true
|
|
|
|
} else {
|
2022-03-25 12:54:27 +03:00
|
|
|
if (loader.sourceComponent != app) {
|
2021-11-17 15:27:19 -05:00
|
|
|
Qt.quit();
|
|
|
|
}
|
|
|
|
else if (loader.sourceComponent == app) {
|
|
|
|
if (localAccountSensitiveSettings.quitOnClose) {
|
|
|
|
Qt.quit();
|
|
|
|
} else {
|
|
|
|
applicationWindow.visible = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-05-19 17:03:14 +03:00
|
|
|
}
|
2021-01-28 23:00:33 -04:00
|
|
|
}
|
2021-09-21 10:29:33 -05:00
|
|
|
|
2021-09-06 16:37:00 +03:00
|
|
|
Connections {
|
2022-07-04 23:14:13 +02:00
|
|
|
target: singleInstance
|
2021-09-06 16:37:00 +03:00
|
|
|
|
2022-07-19 14:15:00 +02:00
|
|
|
function onSecondInstanceDetected() {
|
2021-09-06 16:37:00 +03:00
|
|
|
console.log("User attempted to run the second instance of the application")
|
|
|
|
// activating this instance to give user visual feedback
|
|
|
|
applicationWindow.show()
|
|
|
|
applicationWindow.raise()
|
|
|
|
applicationWindow.requestActivate()
|
|
|
|
}
|
|
|
|
}
|
2021-01-28 23:00:33 -04:00
|
|
|
|
2021-08-12 13:52:04 +02:00
|
|
|
// The easiest way to get current system theme (is it light or dark) without using
|
|
|
|
// OS native methods is to check lightness (0 - 1.0) of the window color.
|
|
|
|
// If it's too high (0.85+) means light theme is an active.
|
|
|
|
SystemPalette {
|
|
|
|
id: systemPalette
|
|
|
|
function isCurrentSystemThemeDark() {
|
|
|
|
return window.hslLightness < 0.85
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function changeThemeFromOutside() {
|
2022-08-30 18:23:21 +03:00
|
|
|
Style.changeTheme(startupOnboarding.visible ? Universal.System : localAppSettings.theme,
|
|
|
|
systemPalette.isCurrentSystemThemeDark())
|
2021-08-12 13:52:04 +02:00
|
|
|
}
|
|
|
|
|
2020-07-12 12:47:46 -04:00
|
|
|
Component.onCompleted: {
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.applicationWindow = this;
|
2022-08-30 18:23:21 +03:00
|
|
|
Style.changeTheme(Universal.System, systemPalette.isCurrentSystemThemeDark());
|
2022-02-03 15:42:22 -05:00
|
|
|
|
2022-05-16 09:57:51 +03:00
|
|
|
restoreAppState();
|
2020-07-12 12:47:46 -04:00
|
|
|
}
|
|
|
|
|
2020-06-04 17:38:24 +10:00
|
|
|
signal navigateTo(string path)
|
2021-09-21 10:29:33 -05:00
|
|
|
|
2021-08-18 16:43:59 +02:00
|
|
|
function makeStatusAppActive() {
|
|
|
|
applicationWindow.show()
|
|
|
|
applicationWindow.raise()
|
|
|
|
applicationWindow.requestActivate()
|
|
|
|
}
|
|
|
|
|
2020-05-18 11:07:30 -04:00
|
|
|
SystemTrayIcon {
|
2020-12-07 12:37:39 -05:00
|
|
|
id: systemTray
|
2020-05-18 11:07:30 -04:00
|
|
|
visible: true
|
2021-07-19 18:00:05 +02:00
|
|
|
icon.source: {
|
2021-07-20 07:12:11 +03:00
|
|
|
if (production) {
|
|
|
|
if (Qt.platform.os == "osx")
|
2022-07-13 14:26:59 -04:00
|
|
|
return "imports/assets/icons/status-logo-round-rect.svg"
|
2021-07-19 18:00:05 +02:00
|
|
|
else
|
2022-07-13 14:26:59 -04:00
|
|
|
return "imports/assets/icons/status-logo-circle.svg"
|
2021-07-20 07:12:11 +03:00
|
|
|
} else {
|
|
|
|
if (Qt.platform.os == "osx")
|
2022-07-13 14:26:59 -04:00
|
|
|
return "imports/assets/icons/status-logo-dev-round-rect.svg"
|
2021-07-19 18:00:05 +02:00
|
|
|
else
|
2022-07-13 14:26:59 -04:00
|
|
|
return "imports/assets/icons/status-logo-dev-circle.svg"
|
2021-07-19 18:00:05 +02:00
|
|
|
}
|
|
|
|
}
|
2021-07-19 15:14:10 +03:00
|
|
|
|
2020-05-18 11:07:30 -04:00
|
|
|
menu: Menu {
|
2021-01-28 23:00:33 -04:00
|
|
|
MenuItem {
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Open Status")
|
2021-01-28 23:00:33 -04:00
|
|
|
onTriggered: {
|
2021-08-18 16:43:59 +02:00
|
|
|
applicationWindow.makeStatusAppActive()
|
2021-01-28 23:00:33 -04:00
|
|
|
}
|
|
|
|
}
|
2021-09-21 10:29:33 -05:00
|
|
|
|
2021-05-19 17:03:14 +03:00
|
|
|
MenuSeparator {
|
2021-01-28 23:00:33 -04:00
|
|
|
}
|
|
|
|
|
2020-05-18 11:07:30 -04:00
|
|
|
MenuItem {
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Quit")
|
2020-05-18 11:07:30 -04:00
|
|
|
onTriggered: Qt.quit()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onActivated: {
|
2021-07-19 15:14:10 +03:00
|
|
|
if (reason !== SystemTrayIcon.Context) {
|
2021-08-18 16:43:59 +02:00
|
|
|
applicationWindow.makeStatusAppActive()
|
2021-04-07 14:33:23 -04:00
|
|
|
}
|
2020-05-18 11:07:30 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-04 17:38:24 +10:00
|
|
|
Loader {
|
|
|
|
id: loader
|
2020-05-18 11:07:30 -04:00
|
|
|
anchors.fill: parent
|
2022-10-18 11:06:18 +02:00
|
|
|
asynchronous: true
|
2022-03-04 00:50:53 +02:00
|
|
|
opacity: active ? 1.0 : 0.0
|
|
|
|
visible: (opacity > 0.0001)
|
|
|
|
Behavior on opacity { NumberAnimation { duration: 120 }}
|
2020-05-19 23:22:38 +10:00
|
|
|
}
|
2020-05-18 11:07:30 -04:00
|
|
|
|
2020-06-04 17:38:24 +10:00
|
|
|
Component {
|
2020-05-19 23:22:38 +10:00
|
|
|
id: app
|
2021-12-09 14:28:02 +01:00
|
|
|
AppMain {
|
|
|
|
sysPalette: systemPalette
|
|
|
|
}
|
2020-06-04 17:38:24 +10:00
|
|
|
}
|
|
|
|
|
2022-08-01 16:39:05 +02:00
|
|
|
Component {
|
|
|
|
id: appLoadingAnimation
|
|
|
|
SplashScreen {
|
2022-09-29 16:30:25 +02:00
|
|
|
objectName: "splashScreen"
|
2022-08-01 16:39:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-04 00:50:53 +02:00
|
|
|
OnboardingLayout {
|
2022-07-20 14:34:44 +02:00
|
|
|
id: startupOnboarding
|
2022-08-22 13:35:58 +02:00
|
|
|
objectName: "startupOnboardingLayout"
|
2022-07-20 14:34:44 +02:00
|
|
|
anchors.fill: parent
|
2020-05-12 07:24:08 +10:00
|
|
|
}
|
2020-07-10 17:47:31 -04:00
|
|
|
|
|
|
|
NotificationWindow {
|
|
|
|
id: notificationWindow
|
|
|
|
}
|
2021-05-19 21:31:18 +03:00
|
|
|
|
|
|
|
MacTrafficLights {
|
2021-06-03 11:29:14 +03:00
|
|
|
// parent: Overlay.overlay
|
2021-05-19 21:31:18 +03:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.margins: 13
|
|
|
|
|
|
|
|
visible: Qt.platform.os === "osx" && !applicationWindow.isFullScreen
|
2021-06-03 11:29:14 +03:00
|
|
|
|
|
|
|
onClose: {
|
2022-03-25 12:54:27 +03:00
|
|
|
if (loader.sourceComponent != app) {
|
2021-08-11 13:47:32 +02:00
|
|
|
Qt.quit();
|
2021-06-03 11:29:14 +03:00
|
|
|
}
|
|
|
|
else if (loader.sourceComponent == app) {
|
2021-10-20 11:50:50 +02:00
|
|
|
if (localAccountSensitiveSettings.quitOnClose) {
|
2021-06-03 11:29:14 +03:00
|
|
|
Qt.quit();
|
|
|
|
} else {
|
|
|
|
applicationWindow.visible = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onMinimised: {
|
|
|
|
applicationWindow.showMinimized()
|
|
|
|
}
|
|
|
|
|
|
|
|
onMaximized: {
|
|
|
|
applicationWindow.toggleFullScreen()
|
|
|
|
}
|
2021-05-19 21:31:18 +03:00
|
|
|
}
|
2020-05-12 07:24:08 +10:00
|
|
|
}
|
2020-07-01 13:35:57 -04:00
|
|
|
|
|
|
|
/*##^##
|
|
|
|
Designer {
|
|
|
|
D{i:0;formeditorZoom:0.5}
|
|
|
|
}
|
|
|
|
##^##*/
|