2021-10-06 11:16:39 +02:00
import QtQuick 2.13
import QtQuick . Controls 2.13
import QtQuick . Layouts 1.13
import utils 1.0
2022-04-01 12:30:55 +02:00
import shared . panels 1.0
import shared . popups 1.0
2021-10-06 11:16:39 +02:00
import StatusQ . Core 0.1
import StatusQ . Core . Theme 0.1
2022-07-22 13:57:48 +02:00
import StatusQ . Core . Utils 0.1 as StatusQUtils
2021-10-06 11:16:39 +02:00
import StatusQ . Components 0.1
2022-04-01 12:30:55 +02:00
import StatusQ . Controls 0.1
2021-10-06 11:16:39 +02:00
2022-10-25 09:57:04 -04:00
import AppLayouts . Profile . stores 1.0
2021-10-06 11:16:39 +02:00
import "../popups"
2022-07-22 13:57:48 +02:00
import SortFilterProxyModel 0.2
2022-05-07 13:45:15 +02:00
SettingsContentBase {
2022-04-01 12:30:55 +02:00
id: root
2021-10-06 11:16:39 +02:00
2021-12-30 13:39:47 +01:00
property LanguageStore languageStore
2022-04-01 12:30:55 +02:00
property var currencyStore
2022-04-01 12:30:55 +02:00
2022-08-11 15:27:13 +02:00
objectName: "languageView"
2022-04-01 12:30:55 +02:00
onVisibleChanged: { if ( ! visible ) root . setViewIdleState ( ) }
onBaseAreaClicked: { root . setViewIdleState ( ) }
2022-04-01 12:30:55 +02:00
2022-04-01 12:30:55 +02:00
Component.onCompleted: {
root . currencyStore . updateCurrenciesModel ( )
}
2022-04-01 12:30:55 +02:00
2022-04-01 12:30:55 +02:00
function setViewIdleState ( ) {
currencyPicker . close ( )
languagePicker . close ( )
}
2022-08-11 15:27:13 +02:00
function changeLanguage ( key ) {
languagePicker . newKey = key
languagePause . start ( )
}
2022-05-07 13:45:15 +02:00
ColumnLayout {
spacing: Constants . settingsSection . itemSpacing
width: root . contentWidth
2021-10-06 11:16:39 +02:00
2023-01-12 23:39:46 +01:00
RowLayout {
2022-05-07 13:45:15 +02:00
Layout.fillWidth: true
Layout.leftMargin: Style . current . padding
Layout.rightMargin: Style . current . padding
2022-04-01 12:30:55 +02:00
z: root . z + 2
2021-10-06 11:16:39 +02:00
2022-05-07 13:45:15 +02:00
StatusBaseText {
text: qsTr ( "Set Display Currency" )
}
2023-01-12 23:39:46 +01:00
Item { Layout.fillWidth: true }
2022-05-07 13:45:15 +02:00
StatusListPicker {
id: currencyPicker
2022-04-01 12:30:55 +02:00
2022-05-07 13:45:15 +02:00
property string newKey
Timer {
id: currencyPause
interval: 100
onTriggered: {
// updateCurrency function operation blocks a little bit the UI so getting around it with a small pause (timer) in order to get the desired visual behavior
root . currencyStore . updateCurrency ( currencyPicker . newKey )
2022-04-01 12:30:55 +02:00
}
2022-05-07 13:45:15 +02:00
}
2022-04-01 12:30:55 +02:00
2022-04-01 12:30:55 +02:00
z: root . z + 2
2022-05-07 13:45:15 +02:00
inputList: root . currencyStore . currenciesModel
printSymbol: true
placeholderSearchText: qsTr ( "Search Currencies" )
2022-04-01 12:30:55 +02:00
maxPickerHeight: 350
2022-05-07 13:45:15 +02:00
onItemPickerChanged: {
if ( selected ) {
currencyPicker . newKey = key
currencyPause . start ( )
2021-10-06 11:16:39 +02:00
}
2022-04-01 12:30:55 +02:00
}
2022-04-01 12:30:55 +02:00
}
2022-05-07 13:45:15 +02:00
}
2022-04-01 12:30:55 +02:00
2023-01-12 23:39:46 +01:00
RowLayout {
2022-05-07 13:45:15 +02:00
Layout.fillWidth: true
Layout.leftMargin: Style . current . padding
Layout.rightMargin: Style . current . padding
2022-04-01 12:30:55 +02:00
z: root . z + 1
2022-04-01 12:30:55 +02:00
2022-05-07 13:45:15 +02:00
StatusBaseText {
text: qsTr ( "Language" )
}
2023-01-12 23:39:46 +01:00
Item { Layout.fillWidth: true }
2022-05-07 13:45:15 +02:00
StatusListPicker {
id: languagePicker
property string newKey
2022-04-01 12:30:55 +02:00
2022-07-28 19:52:19 +02:00
function descriptionForState ( state ) {
2022-09-05 11:39:59 +02:00
if ( state === Constants . translationsState . alpha ) return qsTr ( "Alpha languages" )
if ( state === Constants . translationsState . beta ) return qsTr ( "Beta languages" )
2022-07-28 19:52:19 +02:00
return ""
}
2022-05-07 13:45:15 +02:00
Timer {
id: languagePause
interval: 100
onTriggered: {
2022-07-26 20:46:07 +02:00
// changeLanguage function operation blocks a little bit the UI so getting around it with a small pause (timer) in order to get the desired visual behavior
root . languageStore . changeLanguage ( languagePicker . newKey )
2022-04-01 12:30:55 +02:00
}
2022-05-07 13:45:15 +02:00
}
2022-08-11 15:27:13 +02:00
objectName: "languagePicker"
2022-07-28 19:52:19 +02:00
inputList: SortFilterProxyModel {
sourceModel: root . languageStore . languageModel
// !Don't use proxy roles cause they harm performance a lot!
// "category" is the only role that can't be mocked by StatusListPicker::proxy
// due to StatusListPicker internal implementation limitation (ListView's section.property)
proxyRoles: [
ExpressionRole {
name: "category"
expression: languagePicker . descriptionForState ( model . state )
}
]
sorters: [
RoleSorter {
roleName: "state"
sortOrder: Qt . DescendingOrder
} ,
StringSorter {
roleName: "name"
}
]
}
2022-07-28 18:52:29 +02:00
proxy {
key: ( model ) = > model . locale
name: ( model ) = > model . name
shortName: ( model ) = > model . native
symbol: ( model ) = > ""
imageSource: ( model ) = > StatusQUtils . Emoji . iconSource ( model . flag )
selected: ( model ) = > model . locale === root . languageStore . currentLanguage
setSelected: ( model , val ) = > null // readonly
2022-07-22 13:57:48 +02:00
}
2022-04-01 12:30:55 +02:00
z: root . z + 1
2022-05-07 13:45:15 +02:00
placeholderSearchText: qsTr ( "Search Languages" )
2022-04-01 12:30:55 +02:00
maxPickerHeight: 350
2022-05-07 13:45:15 +02:00
onItemPickerChanged: {
2022-07-26 20:46:07 +02:00
if ( selected && root . languageStore . currentLanguage !== key ) {
2022-10-07 15:54:08 +02:00
// IMPORTANT: Workaround to temporary resolve the crash we have when language is changed (`startupModule` is null and some qml bindings are still calling this dead pointer) so, change language will not retranslate
// and instead, also on mac and win, the app will quit to apply the new language
2022-05-07 13:45:15 +02:00
// TEMPORARY: It should be removed as it is only used in Linux OS but it must be investigated how to change language in execution time, as well, in Linux (will be addressed in another task)
2022-10-07 15:54:08 +02:00
//if (Qt.platform.os === Constants.linux) {
2022-08-11 15:27:13 +02:00
root . changeLanguage ( key )
2022-05-07 13:45:15 +02:00
linuxConfirmationDialog . active = true
linuxConfirmationDialog . item . open ( )
2022-10-07 15:54:08 +02:00
// }
//else {
// root.changeLanguage(key)
//}
2022-04-01 12:30:55 +02:00
}
}
2021-10-06 11:16:39 +02:00
}
2022-05-07 13:45:15 +02:00
}
2022-04-01 12:30:55 +02:00
2022-05-07 13:45:15 +02:00
Separator {
Layout.fillWidth: true
2022-04-01 12:30:55 +02:00
Layout.bottomMargin: Style . current . padding
}
// Time format options:
Column {
Layout.fillWidth: true
Layout.leftMargin: Style . current . padding
Layout.rightMargin: Style . current . padding
Layout.topMargin: Style . current . padding
spacing: Style . current . padding
StatusBaseText {
text: qsTr ( "Time Format" )
}
2023-01-12 23:39:46 +01:00
StatusCheckBox {
id: use24hDefault
text: qsTr ( "Use System Settings" )
2022-04-01 12:30:55 +02:00
font.pixelSize: 13
2023-01-12 23:39:46 +01:00
checked: LocaleUtils . settings . timeFormatUsesDefaults
onToggled: {
LocaleUtils . settings . timeFormatUsesDefaults = checked
if ( checked )
LocaleUtils . settings . timeFormatUses24Hours = LocaleUtils . is24hTimeFormatDefault ( )
}
2022-04-01 12:30:55 +02:00
}
2023-01-12 23:39:46 +01:00
StatusCheckBox {
text: qsTr ( "Use 24-Hour Time" )
2022-04-01 12:30:55 +02:00
font.pixelSize: 13
2023-01-12 23:39:46 +01:00
enabled: ! use24hDefault . checked
checked: LocaleUtils . settings . timeFormatUses24Hours
onToggled: LocaleUtils . settings . timeFormatUses24Hours = checked
2022-04-01 12:30:55 +02:00
}
}
2022-04-01 12:30:55 +02:00
2022-05-07 13:45:15 +02:00
// TEMPORARY: It should be removed as it is only used in Linux OS but it must be investigated how to change language in execution time, as well, in Linux (will be addressed in another task)
Loader {
id: linuxConfirmationDialog
active: false
sourceComponent: ConfirmationDialog {
header.title: qsTr ( "Change language" )
confirmationText: qsTr ( "Display language has been changed. You must restart the application for changes to take effect." )
confirmButtonLabel: qsTr ( "Close the app now" )
onConfirmButtonClicked: {
2023-01-12 23:39:46 +01:00
linuxConfirmationDialog . active = false
2022-05-07 13:45:15 +02:00
Qt . quit ( )
}
}
}
2021-10-06 11:16:39 +02:00
}
}
2022-04-01 12:30:55 +02:00