2022-01-09 02:28:03 +03:00
|
|
|
// SPDX-FileCopyrightText: 2021 Nheko Contributors
|
|
|
|
// SPDX-FileCopyrightText: 2022 Nheko Contributors
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2022-01-09 08:56:02 +03:00
|
|
|
import ".."
|
|
|
|
import "../ui"
|
2022-01-09 02:28:03 +03:00
|
|
|
import Qt.labs.platform 1.1 as Platform
|
|
|
|
import QtQuick 2.15
|
2022-01-11 06:12:42 +03:00
|
|
|
import QtQuick.Controls 2.15
|
2022-01-09 02:28:03 +03:00
|
|
|
import QtQuick.Layouts 1.2
|
2022-01-11 06:12:42 +03:00
|
|
|
import QtQuick.Window 2.15
|
2022-01-09 02:28:03 +03:00
|
|
|
import im.nheko 1.0
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: userSettingsDialog
|
|
|
|
|
2022-01-11 06:12:42 +03:00
|
|
|
property int collapsePoint: 800
|
|
|
|
property bool collapsed: width < collapsePoint
|
2022-01-09 02:28:03 +03:00
|
|
|
color: Nheko.colors.window
|
|
|
|
|
|
|
|
ScrollView {
|
|
|
|
id: scroll
|
|
|
|
|
|
|
|
palette: Nheko.colors
|
|
|
|
ScrollBar.horizontal.visible: false
|
|
|
|
anchors.fill: parent
|
|
|
|
anchors.margins: Nheko.paddingLarge
|
|
|
|
|
|
|
|
contentWidth: availableWidth
|
|
|
|
|
|
|
|
Timer {
|
|
|
|
id: deadTimer
|
|
|
|
interval: 500
|
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: scroll.contentItem
|
|
|
|
function onContentYChanged() { deadTimer.restart(); }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
GridLayout {
|
|
|
|
id: grid
|
|
|
|
|
|
|
|
columns: userSettingsDialog.collapsed ? 1 : 2
|
|
|
|
rowSpacing: Nheko.paddingMedium
|
|
|
|
columnSpacing: Nheko.paddingMedium
|
|
|
|
|
|
|
|
anchors.fill: parent
|
2022-01-11 06:12:42 +03:00
|
|
|
anchors.leftMargin: userSettingsDialog.collapsed ? Nheko.paddingLarge : (userSettingsDialog.width-userSettingsDialog.collapsePoint) * 0.4
|
|
|
|
anchors.rightMargin: anchors.leftMargin
|
2022-01-09 02:28:03 +03:00
|
|
|
|
|
|
|
Repeater {
|
|
|
|
model: UserSettingsModel
|
|
|
|
|
|
|
|
delegate: Item {
|
|
|
|
required property var model
|
|
|
|
id: r
|
|
|
|
|
|
|
|
Component.onCompleted: {
|
|
|
|
while (children.length) {
|
|
|
|
children[0].parent = grid;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
|
|
|
Layout.alignment: Qt.AlignLeft
|
|
|
|
Layout.fillWidth: true
|
|
|
|
color: Nheko.colors.text
|
|
|
|
text: model.name
|
|
|
|
//Layout.column: 0
|
|
|
|
Layout.columnSpan: (model.type == UserSettingsModel.SectionTitle && !userSettingsDialog.collapsed) ? 2 : 1
|
|
|
|
//Layout.row: model.index
|
|
|
|
Layout.minimumWidth: implicitWidth
|
|
|
|
Layout.leftMargin: model.type == UserSettingsModel.SectionTitle ? 0 : Nheko.paddingMedium
|
|
|
|
Layout.topMargin: model.type == UserSettingsModel.SectionTitle ? Nheko.paddingLarge : 0
|
2022-01-11 06:12:42 +03:00
|
|
|
font.pointSize: 1.1 * fontMetrics.font.pointSize
|
2022-01-09 02:28:03 +03:00
|
|
|
|
|
|
|
HoverHandler {
|
|
|
|
id: hovered
|
|
|
|
enabled: model.description ?? false
|
|
|
|
}
|
|
|
|
ToolTip.visible: hovered.hovered && model.description
|
|
|
|
ToolTip.text: model.description ?? ""
|
|
|
|
ToolTip.delay: Nheko.tooltipDelay
|
|
|
|
}
|
|
|
|
|
|
|
|
DelegateChooser {
|
|
|
|
id: chooser
|
|
|
|
|
|
|
|
roleValue: model.type
|
|
|
|
Layout.alignment: Qt.AlignRight
|
|
|
|
|
|
|
|
Layout.columnSpan: (model.type == UserSettingsModel.SectionTitle && !userSettingsDialog.collapsed) ? 2 : 1
|
|
|
|
Layout.preferredHeight: child.height
|
|
|
|
Layout.preferredWidth: Math.min(child.implicitWidth, child.width || 1000)
|
2022-01-13 06:15:33 +03:00
|
|
|
Layout.fillWidth: model.type == UserSettingsModel.SectionTitle || model.type == UserSettingsModel.Options || model.type == UserSettingsModel.Number
|
2022-01-09 02:28:03 +03:00
|
|
|
Layout.rightMargin: model.type == UserSettingsModel.SectionTitle ? 0 : Nheko.paddingMedium
|
|
|
|
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.Toggle
|
|
|
|
ToggleButton {
|
|
|
|
checked: model.value
|
|
|
|
onCheckedChanged: model.value = checked
|
|
|
|
enabled: model.enabled
|
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.Options
|
|
|
|
ComboBox {
|
2022-01-13 06:15:33 +03:00
|
|
|
anchors.right: parent.right
|
|
|
|
width: Math.min(parent.width, implicitWidth)
|
2022-01-09 02:28:03 +03:00
|
|
|
model: r.model.values
|
|
|
|
currentIndex: r.model.value
|
|
|
|
enabled: !deadTimer.running
|
|
|
|
onCurrentIndexChanged: r.model.value = currentIndex
|
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
2022-01-13 07:51:57 +03:00
|
|
|
roleValue: UserSettingsModel.Integer
|
2022-01-09 02:28:03 +03:00
|
|
|
|
|
|
|
SpinBox {
|
2022-01-13 06:15:33 +03:00
|
|
|
anchors.right: parent.right
|
|
|
|
width: Math.min(parent.width, implicitWidth)
|
2022-01-09 02:28:03 +03:00
|
|
|
enabled: !deadTimer.running && model.enabled
|
|
|
|
from: model.valueLowerBound
|
|
|
|
to: model.valueUpperBound
|
|
|
|
stepSize: model.valueStep
|
|
|
|
value: model.value
|
|
|
|
onValueChanged: model.value = value
|
2022-01-13 07:51:57 +03:00
|
|
|
editable: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.Double
|
|
|
|
|
|
|
|
SpinBox {
|
|
|
|
id: spinbox
|
|
|
|
|
|
|
|
readonly property double div: 100
|
|
|
|
readonly property int decimals: 2
|
|
|
|
|
|
|
|
anchors.right: parent.right
|
|
|
|
width: Math.min(parent.width, implicitWidth)
|
|
|
|
enabled: !deadTimer.running && model.enabled
|
|
|
|
from: model.valueLowerBound * div
|
|
|
|
to: model.valueUpperBound * div
|
|
|
|
stepSize: model.valueStep * div
|
|
|
|
value: model.value * div
|
|
|
|
onValueChanged: model.value = value/div
|
|
|
|
editable: true
|
|
|
|
|
|
|
|
property real realValue: value / div
|
|
|
|
|
|
|
|
validator: DoubleValidator {
|
|
|
|
bottom: Math.min(spinbox.from/spinbox.div, spinbox.to/spinbox.div)
|
|
|
|
top: Math.max(spinbox.from/spinbox.div, spinbox.to/spinbox.div)
|
|
|
|
}
|
|
|
|
|
|
|
|
textFromValue: function(value, locale) {
|
|
|
|
return Number(value / spinbox.div).toLocaleString(locale, 'f', spinbox.decimals)
|
|
|
|
}
|
|
|
|
|
|
|
|
valueFromText: function(text, locale) {
|
|
|
|
return Number.fromLocaleString(locale, text) * spinbox.div
|
|
|
|
}
|
2022-01-09 02:28:03 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.ReadOnlyText
|
2022-01-13 06:15:33 +03:00
|
|
|
TextEdit {
|
2022-01-09 02:28:03 +03:00
|
|
|
color: Nheko.colors.text
|
|
|
|
text: model.value
|
2022-01-13 06:15:33 +03:00
|
|
|
readOnly: true
|
|
|
|
selectByMouse: !Settings.mobileMode
|
|
|
|
textFormat: Text.PlainText
|
2022-01-09 02:28:03 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.SectionTitle
|
|
|
|
Item {
|
|
|
|
width: grid.width
|
|
|
|
height: fontMetrics.lineSpacing
|
|
|
|
Rectangle {
|
|
|
|
anchors.topMargin: Nheko.paddingSmall
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
color: Nheko.colors.buttonText
|
|
|
|
height: 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.KeyStatus
|
|
|
|
Text {
|
|
|
|
color: model.good ? "green" : Nheko.theme.error
|
|
|
|
text: model.value ? qsTr("CACHED") : qsTr("NOT CACHED")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.SessionKeyImportExport
|
|
|
|
RowLayout {
|
|
|
|
Button {
|
|
|
|
text: qsTr("IMPORT")
|
|
|
|
onClicked: UserSettingsModel.importSessionKeys()
|
|
|
|
}
|
|
|
|
Button {
|
|
|
|
text: qsTr("EXPORT")
|
|
|
|
onClicked: UserSettingsModel.exportSessionKeys()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
roleValue: UserSettingsModel.XSignKeysRequestDownload
|
|
|
|
RowLayout {
|
|
|
|
Button {
|
|
|
|
text: qsTr("DOWNLOAD")
|
|
|
|
onClicked: UserSettingsModel.downloadCrossSigningSecrets()
|
|
|
|
}
|
|
|
|
Button {
|
|
|
|
text: qsTr("REQUEST")
|
|
|
|
onClicked: UserSettingsModel.requestCrossSigningSecrets()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice {
|
|
|
|
Text {
|
|
|
|
text: model.value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ImageButton {
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.margins: Nheko.paddingMedium
|
|
|
|
width: Nheko.avatarSize
|
|
|
|
height: Nheko.avatarSize
|
|
|
|
image: ":/icons/icons/ui/angle-arrow-left.svg"
|
|
|
|
ToolTip.visible: hovered
|
|
|
|
ToolTip.text: qsTr("Back")
|
|
|
|
onClicked: mainWindow.pop()
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|