moment/src/gui/Window.qml
miruka fda5bc0039 Add CLI arguments parsing + --start-in-tray
- Loading a QML file in place of src/gui/UI.qml is now possible via
  -l / --load-qml instead of taking the first positional argument

- New option to start application in tray without showing a window

- --help and --version
2021-03-03 17:14:55 -04:00

138 lines
3.8 KiB
QML

// Copyright Mirage authors & contributors <https://github.com/mirukana/mirage>
// SPDX-License-Identifier: LGPL-3.0-or-later
import QtQuick 2.12
import QtQuick.Controls 2.12
import "."
import "Base"
import "PythonBridge"
ApplicationWindow {
id: window
enum NotificationLevel { None, MentionsKeywords, All }
// FIXME: Qt 5.13.1 bug, this randomly stops updating after the cursor
// leaves the window until it's clicked again.
readonly property bool hidden:
Qt.application.state === Qt.ApplicationSuspended ||
Qt.application.state === Qt.ApplicationHidden ||
window.visibility === window.Minimized ||
window.visibility === window.Hidden
property int notificationLevel: Window.NotificationLevel.All
property var notifiedIds: new Set()
property var mainUI: null
property var settings: ({})
property var uiState: ({})
property var history: ({})
property var theme: null
property var themeRules: null
property string settingsFolder
readonly property var visibleMenus: ({})
readonly property var visiblePopups: ({})
readonly property bool anyMenu: Object.keys(visibleMenus).length > 0
readonly property bool anyPopup: Object.keys(visiblePopups).length > 0
readonly property bool anyPopupOrMenu: anyMenu || anyPopup
function saveSettings() {
settingsChanged()
py.saveConfig("settings", settings)
}
function saveUIState() {
uiStateChanged()
py.saveConfig("ui_state", uiState)
}
function saveHistory() {
historyChanged()
py.saveConfig("history", history)
}
function saveState(obj) {
if (! obj.saveName || ! obj.saveProperties ||
obj.saveProperties.length < 1) return
const propertyValues = {}
for (const prop of obj.saveProperties) {
propertyValues[prop] = obj[prop]
}
utils.objectUpdateRecursive(uiState, {
[obj.saveName]: { [obj.saveId || "ALL"]: propertyValues },
})
saveUIState()
}
function getState(obj, property, defaultValue=undefined) {
try {
const props = uiState[obj.saveName][obj.saveId || "ALL"]
return property in props ? props[property] : defaultValue
} catch(err) {
return defaultValue
}
}
function makePopup(
urlComponent, properties={}, callback=null, autoDestruct=true,
) {
utils.makePopup(
urlComponent, window, properties, callback, autoDestruct,
)
}
function restoreFromTray() {
window.show()
window.raise()
window.requestActivate()
}
flags: Qt.WA_TranslucentBackground
minimumWidth: theme ? theme.minimumSupportedWidth : 240
minimumHeight: theme ? theme.minimumSupportedHeight : 120
width: Math.min(screen.width, 1152)
height: Math.min(screen.height, 768)
visible: ArgumentParser.ready && ! ArgumentParser.startInTray
color: "transparent"
onClosing: {
close.accepted = ! settings.General.close_to_tray
settings.General.close_to_tray ? hide() : Qt.quit()
}
PythonRootBridge { id: py }
Utils { id: utils }
HLoader {
anchors.fill: parent
source: py.ready ? "" : "LoadingScreen.qml"
}
HLoader {
// true makes the initially loaded chat page invisible for some reason
asynchronous: false
anchors.fill: parent
focus: true
scale: py.ready ? 1 : 0.5
source:
ArgumentParser.ready && py.ready ?
(ArgumentParser.loadQml || "UI.qml") :
""
Behavior on scale { HNumberAnimation { overshoot: 3; factor: 1.2 } }
}
TrayIcon {
window: window
settingsFolder: window.settingsFolder
}
}