2024-02-22 16:16:47 +01:00
import QtQuick 2.15
import QtQuick . Controls 2.15
import QtQuick . Layouts 1.15
import QtQuick . Window 2.15
import QtQuick . Controls . Universal 2.15
2021-09-28 18:04:06 +03:00
import utils 1.0
2021-10-28 00:27:49 +03:00
import shared 1.0
2021-10-28 23:23:30 +03:00
import shared . views 1.0
2021-10-28 00:27:49 +03:00
import shared . status 1.0
2021-10-28 23:23:30 +03:00
import shared . views . chat 1.0
2020-07-21 17:03:22 -04:00
2021-10-06 11:16:39 +02:00
import StatusQ . Core 0.1
2021-11-01 10:44:43 +01:00
import StatusQ . Core . Theme 0.1
2021-10-22 14:48:52 +02:00
import StatusQ . Controls 0.1 as StatusQ
2021-10-06 11:16:39 +02:00
import "../popups"
2021-12-30 13:39:47 +01:00
import "../stores"
2021-10-06 11:16:39 +02:00
2022-05-07 13:45:15 +02:00
SettingsContentBase {
2021-12-09 14:28:02 +01:00
id: appearanceView
2021-12-29 11:32:43 +01:00
2021-12-30 13:39:47 +01:00
property AppearanceStore appearanceStore
2021-12-09 14:28:02 +01:00
property var systemPalette
2020-07-21 17:03:22 -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
function updateTheme ( theme ) {
2021-10-20 12:55:10 +02:00
localAppSettings . theme = theme
2024-10-15 21:26:12 +02:00
Theme . changeTheme ( theme , systemPalette . isCurrentSystemThemeDark ( ) )
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
}
2020-11-25 11:46:18 +01:00
function updateFontSize ( fontSize ) {
2024-10-15 21:26:12 +02:00
Theme . changeFontSize ( fontSize )
2020-11-25 11:46:18 +01:00
}
2021-12-29 11:32:43 +01:00
Component.onCompleted: {
appearanceView . updateFontSize ( localAccountSensitiveSettings . fontSize )
}
2021-12-09 14:28:02 +01:00
2020-11-24 13:14:49 +01:00
Item {
id: appearanceContainer
2023-01-24 19:31:20 +02:00
anchors.left: ! ! parent ? parent.left : undefined
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
width: appearanceView . contentWidth - 2 * Theme . padding
2022-07-26 13:53:18 +02:00
height: childrenRect . height
2020-07-21 17:03:22 -04:00
2020-11-25 11:46:18 +01:00
Rectangle {
id: preview
2022-07-26 13:53:18 +02:00
anchors.top: parent . top
2020-11-25 11:46:18 +01:00
anchors.left: parent . left
anchors.right: parent . right
2022-07-05 14:12:27 +04:00
height: placeholderMessage . implicitHeight +
placeholderMessage . anchors . leftMargin +
placeholderMessage . anchors . rightMargin
2024-10-15 21:26:12 +02:00
radius: Theme . radius
border.color: Theme . palette . border
color: Theme . palette . transparent
2020-11-25 11:46:18 +01:00
2021-10-01 18:58:36 +03:00
MessageView {
2022-07-05 14:12:27 +04:00
id: placeholderMessage
2020-11-25 11:46:18 +01:00
anchors.top: parent . top
anchors.left: parent . left
2022-07-05 14:12:27 +04:00
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.margins: Theme . smallPadding
2021-12-18 00:06:40 +02:00
isMessage: true
shouldRepeatHeader: true
2022-07-05 14:12:27 +04:00
messageTimestamp: Date . now ( )
2022-11-08 12:37:25 +01:00
senderDisplayName: "vitalik.eth"
2021-12-18 00:06:40 +02:00
senderIcon: ""
2022-07-05 14:12:27 +04:00
messageText: qsTr ( "Blockchains will drop search costs, causing a kind of decomposition that allows you to have markets of entities that are horizontally segregated and vertically segregated." )
2021-12-18 00:06:40 +02:00
messageContentType: Constants . messageContentType . messageType
placeholderMessage: true
2020-11-25 11:46:18 +01:00
}
}
StatusSectionHeadline {
id: sectionHeadlineFontSize
2022-07-26 13:53:18 +02:00
text: qsTr ( "Text size" )
2020-11-25 11:46:18 +01:00
anchors.top: preview . bottom
2024-10-15 21:26:12 +02:00
anchors.topMargin: Theme . bigPadding * 2
2020-11-25 11:46:18 +01:00
anchors.left: parent . left
anchors.right: parent . right
}
2022-05-20 13:51:44 +03:00
StatusQ . StatusLabeledSlider {
2020-11-25 11:46:18 +01:00
id: fontSizeSlider
2022-07-26 13:53:18 +02:00
anchors.top: sectionHeadlineFontSize . bottom
2024-10-15 21:26:12 +02:00
anchors.topMargin: Theme . padding
2020-11-25 11:46:18 +01:00
width: parent . width
2022-10-03 16:39:30 +03:00
textRole: "name"
valueRole: "value"
model: ListModel {
ListElement { name: qsTr ( "XS" ) ; value: Theme . FontSizeXS }
ListElement { name: qsTr ( "S" ) ; value: Theme . FontSizeS }
ListElement { name: qsTr ( "M" ) ; value: Theme . FontSizeM }
ListElement { name: qsTr ( "L" ) ; value: Theme . FontSizeL }
ListElement { name: qsTr ( "XL" ) ; value: Theme . FontSizeXL }
ListElement { name: qsTr ( "XXL" ) ; value: Theme . FontSizeXXL }
}
2021-10-20 11:50:50 +02:00
value: localAccountSensitiveSettings . fontSize
2022-10-03 16:39:30 +03:00
onCurrentValueChanged: {
const fontSize = currentValue
if ( localAccountSensitiveSettings . fontSize !== fontSize ) {
localAccountSensitiveSettings . fontSize = fontSize
appearanceView . updateFontSize ( fontSize )
2022-05-16 18:02:03 +03:00
}
2020-11-25 11:46:18 +01:00
}
}
2022-07-26 13:53:18 +02:00
Rectangle {
id: modeSeparator
2024-05-13 19:56:26 +02:00
anchors.top: fontSizeSlider . bottom
2024-10-15 21:26:12 +02:00
anchors.topMargin: Theme . padding * 3
2022-07-26 13:53:18 +02:00
anchors.left: parent . left
anchors.right: parent . right
height: 1
2024-10-15 21:26:12 +02:00
color: Theme . palette . separator
2022-07-26 13:53:18 +02:00
}
2020-11-24 13:14:49 +01:00
StatusSectionHeadline {
id: sectionHeadlineAppearance
2022-07-26 13:53:18 +02:00
text: qsTr ( "Mode" )
anchors.top: modeSeparator . bottom
2024-10-15 21:26:12 +02:00
anchors.topMargin: Theme . padding * 3
2020-11-24 13:14:49 +01:00
anchors.left: parent . left
anchors.right: parent . right
2020-07-21 17:03:22 -04:00
}
2020-11-24 13:14:49 +01:00
RowLayout {
id: appearanceSection
anchors.top: sectionHeadlineAppearance . bottom
2024-10-15 21:26:12 +02:00
anchors.topMargin: Theme . padding
2020-11-24 13:14:49 +01:00
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
spacing: Theme . halfPadding
2020-11-24 13:14:49 +01:00
StatusImageRadioButton {
2022-07-26 13:53:18 +02:00
Layout.preferredWidth: parent . width / 3 - parent . spacing
Layout.preferredHeight: implicitHeight
2024-10-15 21:26:12 +02:00
image.source: Theme . png ( "appearance-light" )
2022-04-04 13:26:30 +02:00
control.text: qsTr ( "Light" )
2021-10-20 12:55:10 +02:00
control.checked: localAppSettings . theme === Universal . Light
2021-01-19 14:51:02 -05:00
onRadioCheckedChanged: {
if ( checked ) {
2021-12-09 14:28:02 +01:00
appearanceView . updateTheme ( Universal . Light )
2020-11-24 13:14:49 +01:00
}
}
}
StatusImageRadioButton {
2022-07-26 13:53:18 +02:00
Layout.preferredWidth: parent . width / 3 - parent . spacing
2024-10-15 21:26:12 +02:00
image.source: Theme . png ( "appearance-dark" )
2022-04-04 13:26:30 +02:00
control.text: qsTr ( "Dark" )
2021-10-20 12:55:10 +02:00
control.checked: localAppSettings . theme === Universal . Dark
2021-01-19 14:51:02 -05:00
onRadioCheckedChanged: {
if ( checked ) {
2021-12-09 14:28:02 +01:00
appearanceView . updateTheme ( Universal . Dark )
2020-11-24 13:14:49 +01:00
}
}
}
StatusImageRadioButton {
2022-07-26 13:53:18 +02:00
Layout.preferredWidth: parent . width / 3 - parent . spacing
2024-10-15 21:26:12 +02:00
image.source: Theme . png ( "appearance-system" )
2022-04-04 13:26:30 +02:00
control.text: qsTr ( "System" )
2021-10-20 12:55:10 +02:00
control.checked: localAppSettings . theme === Universal . System
2021-01-19 14:51:02 -05:00
onRadioCheckedChanged: {
if ( checked ) {
2021-12-09 14:28:02 +01:00
appearanceView . updateTheme ( Universal . System )
2020-11-24 13:14:49 +01:00
}
}
}
2020-07-21 17:03:22 -04:00
}
}
}