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
2023-04-27 13:30:15 +02:00
Qt . callLater ( root . languageStore . changeLanguage , languagePicker . newKey )
2022-08-11 15:27:13 +02:00
}
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-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 ) {
2023-04-27 13:30:15 +02:00
root . changeLanguage ( key )
languageConfirmationDialog . active = true
languageConfirmationDialog . item . open ( )
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
Loader {
2023-04-27 13:30:15 +02:00
id: languageConfirmationDialog
2022-05-07 13:45:15 +02:00
active: false
sourceComponent: ConfirmationDialog {
2023-05-23 14:46:16 +02:00
headerSettings.title: qsTr ( "Change language" )
2022-05-07 13:45:15 +02:00
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-04-27 13:30:15 +02:00
languageConfirmationDialog . 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