2020-09-16 23:04:02 +03:00
/ *
2020-10-19 20:34:47 +03:00
Copyright ( C ) 2020 Sebastian J . Wolf and other contributors
2020-09-16 23:04:02 +03:00
This file is part of Fernschreiber .
Fernschreiber is free software: you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation , either version 3 of the License , or
( at your option ) any later version .
Fernschreiber is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with Fernschreiber . If not , see < http: //www.gnu.org/licenses/>.
* /
2020-10-31 22:49:03 +03:00
import QtQuick 2.6
2020-09-16 23:04:02 +03:00
import Sailfish . Silica 1.0
2021-01-27 01:26:40 +03:00
import Sailfish . Pickers 1.0
2020-10-10 18:46:08 +03:00
import WerkWolf . Fernschreiber 1.0
2021-01-19 02:02:37 +03:00
import "../components"
2020-09-16 23:04:02 +03:00
import "../js/functions.js" as Functions
2021-01-25 01:46:30 +03:00
import "../js/debug.js" as Debug
2020-09-16 23:04:02 +03:00
Page {
id: settingsPage
allowedOrientations: Orientation . All
2021-02-06 00:49:56 +03:00
readonly property bool landscapeLayout: settingsPage . isLandscape
2021-01-26 01:39:54 +03:00
readonly property var userInformation: tdLibWrapper . getUserInformation ( )
2021-01-27 01:26:40 +03:00
property bool uploadInProgress: false
2021-01-26 01:39:54 +03:00
onStatusChanged: {
if ( status === PageStatus . Active ) {
tdLibWrapper . getUserProfilePhotos ( userInformation . id , 100 , 0 ) ;
}
}
2021-01-17 23:05:30 +03:00
2021-01-19 02:02:37 +03:00
Connections {
target: tdLibWrapper
onOwnUserUpdated: {
firstNameEditArea . text = userInformation . first_name ;
lastNameEditArea . text = userInformation . last_name ;
2021-01-20 01:58:58 +03:00
userNameEditArea . text = userInformation . username ;
2021-01-19 02:02:37 +03:00
}
2021-01-26 01:39:54 +03:00
onUserProfilePhotosReceived: {
if ( extra === userInformation . id . toString ( ) ) {
imageContainer . thumbnailModel = photos ;
}
}
2021-01-27 01:26:40 +03:00
onFileUpdated: {
if ( uploadInProgress ) {
profilePictureButtonColumn . visible = ! fileInformation . remote . is_uploading_active ;
uploadInProgress = fileInformation . remote . is_uploading_active ;
if ( ! fileInformation . remote . is_uploading_active ) {
uploadInProgress = false ;
tdLibWrapper . getUserProfilePhotos ( userInformation . id , 100 , 0 ) ;
}
}
}
onOkReceived: {
if ( request === "deleteProfilePhoto" ) {
tdLibWrapper . getUserProfilePhotos ( userInformation . id , 100 , 0 ) ;
}
2021-01-27 01:54:37 +03:00
if ( request === "setProfilePhoto" ) {
tdLibWrapper . getUserProfilePhotos ( userInformation . id , 100 , 0 ) ;
profilePictureButtonColumn . visible = true ;
uploadInProgress = false ;
}
2021-01-27 01:26:40 +03:00
}
2021-01-19 02:02:37 +03:00
}
2020-09-16 23:04:02 +03:00
SilicaFlickable {
id: settingsContainer
contentHeight: column . height
anchors.fill: parent
Column {
id: column
width: settingsPage . width
PageHeader {
title: qsTr ( "Settings" )
}
2021-01-19 02:02:37 +03:00
SectionHeader {
text: qsTr ( "User Profile" )
}
2021-01-20 01:58:58 +03:00
Grid {
2021-01-19 02:02:37 +03:00
width: parent . width - ( 2 * Theme . horizontalPageMargin )
2021-01-20 01:58:58 +03:00
columns: landscapeLayout ? 2 : 1
2021-02-05 01:46:06 +03:00
columnSpacing: Theme . paddingLarge
2021-01-19 02:02:37 +03:00
anchors.horizontalCenter: parent . horizontalCenter
2021-01-20 01:58:58 +03:00
readonly property real columnWidth: width / columns
InformationEditArea {
id: firstNameEditArea
visible: true
canEdit: true
headerText: qsTr ( "First Name" , "first name of the logged-in profile - header" )
2021-01-26 01:39:54 +03:00
text: userInformation . first_name
2021-01-20 01:58:58 +03:00
width: parent . columnWidth
headerLeftAligned: true
onSaveButtonClicked: {
if ( ! editItem . errorHighlight ) {
tdLibWrapper . setName ( textValue , lastNameEditArea . text ) ;
} else {
isEditing = true ;
}
2021-01-19 02:02:37 +03:00
}
2021-01-20 01:58:58 +03:00
onTextEdited: {
if ( textValue . length > 0 && textValue . length < 65 ) {
editItem . errorHighlight = false ;
editItem . label = "" ;
editItem . placeholderText = "" ;
} else {
editItem . label = qsTr ( "Enter 1-64 characters" ) ;
editItem . placeholderText = editItem . label ;
editItem . errorHighlight = true ;
}
2021-01-19 02:02:37 +03:00
}
}
2021-01-20 01:58:58 +03:00
InformationEditArea {
id: lastNameEditArea
visible: true
canEdit: true
headerText: qsTr ( "Last Name" , "last name of the logged-in profile - header" )
2021-01-26 01:39:54 +03:00
text: userInformation . last_name
2021-01-20 01:58:58 +03:00
width: parent . columnWidth
headerLeftAligned: true
onSaveButtonClicked: {
if ( ! editItem . errorHighlight ) {
tdLibWrapper . setName ( firstNameEditArea . text , textValue ) ;
} else {
isEditing = true ;
}
}
2021-01-19 02:02:37 +03:00
2021-01-20 01:58:58 +03:00
onTextEdited: {
if ( textValue . length >= 0 && textValue . length < 65 ) {
editItem . errorHighlight = false ;
editItem . label = "" ;
editItem . placeholderText = "" ;
} else {
editItem . label = qsTr ( "Enter 0-64 characters" ) ;
editItem . placeholderText = editItem . label ;
editItem . errorHighlight = true ;
}
2021-01-19 02:02:37 +03:00
}
}
2021-01-20 01:58:58 +03:00
InformationEditArea {
id: userNameEditArea
visible: true
canEdit: true
headerText: qsTr ( "Username" , "user name of the logged-in profile - header" )
2021-01-26 01:39:54 +03:00
text: userInformation . username
2021-01-20 01:58:58 +03:00
width: parent . columnWidth
headerLeftAligned: true
onSaveButtonClicked: {
tdLibWrapper . setUsername ( textValue ) ;
2021-01-19 02:02:37 +03:00
}
}
2021-01-20 01:58:58 +03:00
2021-01-19 02:02:37 +03:00
}
2021-01-26 01:39:54 +03:00
SectionHeader {
horizontalAlignment: Text . AlignLeft
text: qsTr ( "Profile Pictures" )
}
Row {
width: parent . width - ( 2 * Theme . horizontalPageMargin )
spacing: Theme . paddingMedium
Item {
id: imageContainer
anchors.verticalCenter: parent . verticalCenter
width: parent . width / 2
height: profilePictureLoader . height
property var thumbnailModel: ( { } )
property bool thumbnailVisible: true
property bool thumbnailActive: thumbnailModel . length > 0
property int thumbnailRadius: imageContainer . width / 2
Loader {
id: profilePictureLoader
active: imageContainer . thumbnailActive
asynchronous: true
width: Theme . itemSizeExtraLarge
height: Theme . itemSizeExtraLarge
anchors.horizontalCenter: parent . horizontalCenter
source: "../components/ProfilePictureList.qml"
}
2021-01-27 01:54:37 +03:00
ProfileThumbnail {
id: chatPictureReplacement
visible: ! profilePictureLoader . active
replacementStringHint: Functions . getUserName ( settingsPage . userInformation )
radius: imageContainer . thumbnailRadius
anchors.horizontalCenter: parent . horizontalCenter
width: Theme . itemSizeExtraLarge
height: Theme . itemSizeExtraLarge
}
2021-01-26 01:39:54 +03:00
}
Column {
2021-01-27 01:26:40 +03:00
id: profilePictureButtonColumn
2021-01-26 01:39:54 +03:00
spacing: Theme . paddingSmall
width: parent . width / 2
Button {
id: addProfilePictureButton
text: qsTr ( "Add Picture" )
anchors {
horizontalCenter: parent . horizontalCenter
}
onClicked: {
2021-01-27 01:26:40 +03:00
pageStack . push ( imagePickerPage ) ;
2021-01-26 01:39:54 +03:00
}
}
Button {
id: removeProfilePictureButton
2021-01-27 01:26:40 +03:00
text: qsTr ( "Delete Picture" )
2021-01-26 01:39:54 +03:00
anchors {
horizontalCenter: parent . horizontalCenter
}
onClicked: {
2021-01-27 01:26:40 +03:00
var pictureIdForDeletion = imageContainer . thumbnailModel [ profilePictureLoader . item . currentPictureIndex ] . id ;
Remorse . popupAction ( settingsPage , qsTr ( "Deleting profile picture" ) , function ( ) { tdLibWrapper . deleteProfilePhoto ( pictureIdForDeletion ) } ) ;
2021-01-26 01:39:54 +03:00
}
}
2021-01-27 01:26:40 +03:00
}
Column {
id: uploadStatusColumn
visible: ! profilePictureButtonColumn . visible
spacing: Theme . paddingMedium
width: parent . width / 2
Text {
id: uploadingText
font.pixelSize: Theme . fontSizeSmall
text: qsTr ( "Uploading..." )
horizontalAlignment: Text . AlignHCenter
color: Theme . secondaryColor
width: parent . width
}
BusyIndicator {
anchors.horizontalCenter: parent . horizontalCenter
running: uploadStatusColumn . visible
size: BusyIndicatorSize . Medium
}
2021-01-26 01:39:54 +03:00
}
2021-01-27 01:26:40 +03:00
2021-01-26 01:39:54 +03:00
}
2021-01-27 01:26:40 +03:00
Component {
id: imagePickerPage
ImagePickerPage {
onSelectedContentPropertiesChanged: {
profilePictureButtonColumn . visible = false ;
uploadInProgress = true ;
tdLibWrapper . setProfilePhoto ( selectedContentProperties . filePath ) ;
}
}
}
2021-01-26 01:39:54 +03:00
SectionHeader {
horizontalAlignment: Text . AlignLeft
2021-01-27 01:26:40 +03:00
text: qsTr ( "Privacy" )
2021-01-26 01:39:54 +03:00
}
2021-01-25 01:46:30 +03:00
Grid {
width: parent . width
columns: landscapeLayout ? 2 : 1
anchors.horizontalCenter: parent . horizontalCenter
readonly property real columnWidth: width / columns
Connections {
target: tdLibWrapper
onUserPrivacySettingUpdated: {
Debug . log ( "Received updated privacy setting: " + setting + ":" + rule ) ;
switch ( setting ) {
case TelegramAPI.SettingAllowChatInvites:
allowChatInvitesComboBox . currentIndex = rule ;
break ;
case TelegramAPI.SettingAllowFindingByPhoneNumber:
allowFindingByPhoneNumberComboBox . currentIndex = rule ;
break ;
case TelegramAPI.SettingShowLinkInForwardedMessages:
showLinkInForwardedMessagesComboBox . currentIndex = rule ;
break ;
case TelegramAPI.SettingShowPhoneNumber:
showPhoneNumberComboBox . currentIndex = rule ;
break ;
case TelegramAPI.SettingShowProfilePhoto:
showProfilePhotoComboBox . currentIndex = rule ;
break ;
case TelegramAPI.SettingShowStatus:
showStatusComboBox . currentIndex = rule ;
break ;
}
}
}
ComboBox {
id: allowChatInvitesComboBox
width: parent . columnWidth
label: qsTr ( "Allow chat invites" )
description: qsTr ( "Privacy setting for managing whether you can be invited to chats." )
menu: ContextMenu {
2021-01-30 02:16:13 +03:00
x: 0
width: allowChatInvitesComboBox . width
2021-01-25 01:46:30 +03:00
MenuItem {
text: qsTr ( "Yes" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingAllowChatInvites , TelegramAPI . RuleAllowAll ) ;
}
}
MenuItem {
text: qsTr ( "Your contacts only" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingAllowChatInvites , TelegramAPI . RuleAllowContacts ) ;
}
}
MenuItem {
text: qsTr ( "No" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingAllowChatInvites , TelegramAPI . RuleRestrictAll ) ;
}
}
}
Component.onCompleted: {
currentIndex = tdLibWrapper . getUserPrivacySettingRule ( TelegramAPI . SettingAllowChatInvites ) ;
}
}
ComboBox {
id: allowFindingByPhoneNumberComboBox
width: parent . columnWidth
label: qsTr ( "Allow finding by phone number" )
description: qsTr ( "Privacy setting for managing whether you can be found by your phone number." )
menu: ContextMenu {
2021-01-30 02:16:13 +03:00
x: 0
width: allowFindingByPhoneNumberComboBox . width
2021-01-25 01:46:30 +03:00
MenuItem {
text: qsTr ( "Yes" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingAllowFindingByPhoneNumber , TelegramAPI . RuleAllowAll ) ;
}
}
MenuItem {
text: qsTr ( "Your contacts only" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingAllowFindingByPhoneNumber , TelegramAPI . RuleAllowContacts ) ;
}
}
}
Component.onCompleted: {
currentIndex = tdLibWrapper . getUserPrivacySettingRule ( TelegramAPI . SettingAllowFindingByPhoneNumber ) ;
}
}
ComboBox {
id: showLinkInForwardedMessagesComboBox
width: parent . columnWidth
label: qsTr ( "Show link in forwarded messages" )
description: qsTr ( "Privacy setting for managing whether a link to your account is included in forwarded messages." )
menu: ContextMenu {
2021-01-30 02:16:13 +03:00
x: 0
width: showLinkInForwardedMessagesComboBox . width
2021-01-25 01:46:30 +03:00
MenuItem {
text: qsTr ( "Yes" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowLinkInForwardedMessages , TelegramAPI . RuleAllowAll ) ;
}
}
MenuItem {
text: qsTr ( "Your contacts only" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowLinkInForwardedMessages , TelegramAPI . RuleAllowContacts ) ;
}
}
MenuItem {
text: qsTr ( "No" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowLinkInForwardedMessages , TelegramAPI . RuleRestrictAll ) ;
}
}
}
Component.onCompleted: {
currentIndex = tdLibWrapper . getUserPrivacySettingRule ( TelegramAPI . SettingShowLinkInForwardedMessages ) ;
}
}
ComboBox {
id: showPhoneNumberComboBox
width: parent . columnWidth
label: qsTr ( "Show phone number" )
description: qsTr ( "Privacy setting for managing whether your phone number is visible." )
menu: ContextMenu {
2021-01-30 02:16:13 +03:00
x: 0
width: showPhoneNumberComboBox . width
2021-01-25 01:46:30 +03:00
MenuItem {
text: qsTr ( "Yes" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowPhoneNumber , TelegramAPI . RuleAllowAll ) ;
}
}
MenuItem {
text: qsTr ( "Your contacts only" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowPhoneNumber , TelegramAPI . RuleAllowContacts ) ;
}
}
MenuItem {
text: qsTr ( "No" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowPhoneNumber , TelegramAPI . RuleRestrictAll ) ;
}
}
}
Component.onCompleted: {
currentIndex = tdLibWrapper . getUserPrivacySettingRule ( TelegramAPI . SettingShowPhoneNumber ) ;
}
}
ComboBox {
id: showProfilePhotoComboBox
width: parent . columnWidth
label: qsTr ( "Show profile photo" )
description: qsTr ( "Privacy setting for managing whether your profile photo is visible." )
menu: ContextMenu {
2021-01-30 02:16:13 +03:00
x: 0
width: showProfilePhotoComboBox . width
2021-01-25 01:46:30 +03:00
MenuItem {
text: qsTr ( "Yes" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowProfilePhoto , TelegramAPI . RuleAllowAll ) ;
}
}
MenuItem {
text: qsTr ( "Your contacts only" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowProfilePhoto , TelegramAPI . RuleAllowContacts ) ;
}
}
MenuItem {
text: qsTr ( "No" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowProfilePhoto , TelegramAPI . RuleRestrictAll ) ;
}
}
}
Component.onCompleted: {
currentIndex = tdLibWrapper . getUserPrivacySettingRule ( TelegramAPI . SettingShowProfilePhoto ) ;
}
}
ComboBox {
id: showStatusComboBox
width: parent . columnWidth
label: qsTr ( "Show status" )
description: qsTr ( "Privacy setting for managing whether your online status is visible." )
menu: ContextMenu {
2021-01-30 02:16:13 +03:00
x: 0
width: showStatusComboBox . width
2021-01-25 01:46:30 +03:00
MenuItem {
text: qsTr ( "Yes" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowStatus , TelegramAPI . RuleAllowAll ) ;
}
}
MenuItem {
text: qsTr ( "Your contacts only" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowStatus , TelegramAPI . RuleAllowContacts ) ;
}
}
MenuItem {
text: qsTr ( "No" )
onClicked: {
tdLibWrapper . setUserPrivacySettingRule ( TelegramAPI . SettingShowStatus , TelegramAPI . RuleRestrictAll ) ;
}
}
}
Component.onCompleted: {
currentIndex = tdLibWrapper . getUserPrivacySettingRule ( TelegramAPI . SettingShowStatus ) ;
}
}
}
2021-02-03 23:54:46 +03:00
TextSwitch {
checked: appSettings . allowInlineBotLocationAccess
text: qsTr ( "Allow sending Location to inline bots" )
description: qsTr ( "Some inline bots request location data when using them" )
automaticCheck: false
onClicked: {
appSettings . allowInlineBotLocationAccess = ! checked
}
}
2020-09-16 23:04:02 +03:00
SectionHeader {
text: qsTr ( "Behavior" )
}
2021-01-17 23:05:30 +03:00
Grid {
width: parent . width
columns: landscapeLayout ? 2 : 1
readonly property real columnWidth: width / columns
TextSwitch {
width: parent . columnWidth
checked: appSettings . sendByEnter
text: qsTr ( "Send message by enter" )
description: qsTr ( "Send your message by pressing the enter key" )
automaticCheck: false
onClicked: {
appSettings . sendByEnter = ! checked
}
2020-09-16 23:04:02 +03:00
}
2021-05-12 21:23:31 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . focusTextAreaOnChatOpen
text: qsTr ( "Focus text input on chat open" )
description: qsTr ( "Focus the text input area when entering a chat" )
automaticCheck: false
onClicked: {
appSettings . focusTextAreaOnChatOpen = ! checked
}
}
2021-01-17 23:05:30 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . focusTextAreaAfterSend
text: qsTr ( "Focus text input area after send" )
description: qsTr ( "Focus the text input area after sending a message" )
automaticCheck: false
onClicked: {
appSettings . focusTextAreaAfterSend = ! checked
}
2021-01-01 03:30:23 +03:00
}
2021-02-04 00:16:22 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . delayMessageRead
text: qsTr ( "Delay before marking messages as read" )
description: qsTr ( "Fernschreiber will wait a bit before messages are marked as read" )
automaticCheck: false
onClicked: {
appSettings . delayMessageRead = ! checked
}
}
2021-01-17 23:05:30 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . useOpenWith
text: qsTr ( "Open-with menu integration" )
description: qsTr ( "Integrate Fernschreiber into open-with menu of Sailfish OS" )
automaticCheck: false
onClicked: {
appSettings . useOpenWith = ! checked
}
}
2021-01-30 19:21:42 +03:00
ComboBox {
id: feedbackComboBox
width: parent . columnWidth
label: qsTr ( "Notification feedback" )
description: qsTr ( "Use non-graphical feedback (sound, vibration) for notifications" )
menu: ContextMenu {
id: feedbackMenu
x: 0
width: feedbackComboBox . width
MenuItem {
readonly property int value: AppSettings . NotificationFeedbackAll
text: qsTr ( "All events" )
onClicked: {
appSettings . notificationFeedback = value
}
}
MenuItem {
readonly property int value: AppSettings . NotificationFeedbackNew
text: qsTr ( "Only new events" )
onClicked: {
appSettings . notificationFeedback = value
}
}
MenuItem {
readonly property int value: AppSettings . NotificationFeedbackNone
text: qsTr ( "None" )
onClicked: {
appSettings . notificationFeedback = value
}
}
}
Component.onCompleted: updateFeedbackSelection ( )
function updateFeedbackSelection ( ) {
var menuItems = feedbackMenu . children
var n = menuItems . length
for ( var i = 0 ; i < n ; i ++ ) {
if ( menuItems [ i ] . value === appSettings . notificationFeedback ) {
currentIndex = i
return
}
}
}
Connections {
target: appSettings
onNotificationFeedbackChanged: {
feedbackComboBox . updateFeedbackSelection ( )
}
}
}
2021-01-17 23:05:30 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . notificationTurnsDisplayOn && enabled
text: qsTr ( "Notification turns on the display" )
2021-01-30 19:21:42 +03:00
enabled: appSettings . notificationFeedback !== AppSettings . NotificationFeedbackNone
height: enabled ? implicitHeight: 0
2021-01-17 23:05:30 +03:00
clip: height < implicitHeight
visible: height > 0
automaticCheck: false
onClicked: {
appSettings . notificationTurnsDisplayOn = ! checked
}
Behavior on height { SmoothedAnimation { duration: 200 } }
2020-11-08 23:13:04 +03:00
}
2020-10-10 18:46:08 +03:00
2021-01-30 19:21:42 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . notificationSoundsEnabled && enabled
text: qsTr ( "Enable notification sounds" )
2021-02-01 00:00:35 +03:00
description: qsTr ( "When sounds are enabled, Fernschreiber will use the current Sailfish OS notification sound for chats, which can be configured in the system settings." )
2021-01-30 19:21:42 +03:00
enabled: appSettings . notificationFeedback !== AppSettings . NotificationFeedbackNone
height: enabled ? implicitHeight: 0
clip: height < implicitHeight
visible: height > 0
automaticCheck: false
onClicked: {
appSettings . notificationSoundsEnabled = ! checked
2020-10-10 18:46:08 +03:00
}
2021-01-30 19:21:42 +03:00
Behavior on height { SmoothedAnimation { duration: 200 } }
2020-10-10 18:46:08 +03:00
}
}
2020-10-09 18:20:09 +03:00
SectionHeader {
text: qsTr ( "Appearance" )
}
2021-01-17 23:05:30 +03:00
Grid {
width: parent . width
columns: landscapeLayout ? 2 : 1
readonly property real columnWidth: width / columns
2021-05-21 00:41:55 +03:00
TextSwitch {
id: stickersAsEmojisTextSwitch
width: parent . columnWidth
checked: appSettings . showStickersAsEmojis
text: qsTr ( "Show stickers as emojis" )
description: qsTr ( "Only display emojis instead of the actual stickers" )
automaticCheck: false
onClicked: {
appSettings . showStickersAsEmojis = ! checked
}
}
2021-01-17 23:05:30 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . showStickersAsImages
text: qsTr ( "Show stickers as images" )
description: qsTr ( "Show background for stickers and align them centrally like images" )
automaticCheck: false
onClicked: {
appSettings . showStickersAsImages = ! checked
}
2021-05-21 00:41:55 +03:00
enabled: ! stickersAsEmojisTextSwitch . checked
2020-11-11 04:10:34 +03:00
}
2021-01-17 23:05:30 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . animateStickers
text: qsTr ( "Animate stickers" )
automaticCheck: false
onClicked: {
appSettings . animateStickers = ! checked
}
2021-05-21 00:41:55 +03:00
enabled: ! stickersAsEmojisTextSwitch . checked
2020-10-09 18:20:09 +03:00
}
}
2021-01-10 04:06:41 +03:00
SectionHeader {
2020-11-24 01:15:17 +03:00
text: qsTr ( "Storage" )
}
2021-01-17 23:05:30 +03:00
Grid {
width: parent . width
columns: landscapeLayout ? 2 : 1
readonly property real columnWidth: width / columns
TextSwitch {
width: parent . columnWidth
checked: appSettings . onlineOnlyMode
text: qsTr ( "Enable online-only mode" )
description: qsTr ( "Disables offline caching. Certain features may be limited or missing in this mode. Changes require a restart of Fernschreiber to take effect." )
automaticCheck: false
onClicked: {
appSettings . onlineOnlyMode = ! checked
}
2020-11-24 01:15:17 +03:00
}
2021-01-17 23:05:30 +03:00
TextSwitch {
width: parent . columnWidth
checked: appSettings . storageOptimizer
text: qsTr ( "Enable storage optimizer" )
automaticCheck: false
onClicked: {
appSettings . storageOptimizer = ! checked
}
2021-01-10 15:35:34 +03:00
}
}
2020-11-24 01:15:17 +03:00
Item {
width: 1
height: Theme . paddingLarge // Some space at the bottom
}
2020-09-16 23:04:02 +03:00
}
2020-10-09 18:20:09 +03:00
VerticalScrollDecorator { }
2020-09-16 23:04:02 +03:00
}
}