mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-10 06:16:32 +00:00
216 lines
6.6 KiB
QML
216 lines
6.6 KiB
QML
import QtQuick 2.13
|
|
import QtQuick.Controls 2.13
|
|
import QtQuick.Layouts 1.13
|
|
import QtGraphicalEffects 1.13
|
|
import "../../../../imports"
|
|
import "../../../../shared"
|
|
import "../../../../shared/status"
|
|
|
|
Item {
|
|
id: privacyContainer
|
|
Layout.fillHeight: true
|
|
Layout.fillWidth: true
|
|
|
|
ListModel {
|
|
id: previewableSites
|
|
}
|
|
|
|
Column {
|
|
id: containerColumn
|
|
spacing: Style.current.padding
|
|
anchors.top: parent.top
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: contentMargin
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: contentMargin
|
|
anchors.bottom: parent.bottom
|
|
|
|
StatusSectionHeadline {
|
|
id: labelSecurity
|
|
//% "Security"
|
|
text: qsTrId("security")
|
|
}
|
|
|
|
Item {
|
|
id: backupSeedPhrase
|
|
height: backupText.height
|
|
width: parent.width
|
|
|
|
StyledText {
|
|
id: backupText
|
|
//% "Backup Seed Phrase"
|
|
text: qsTrId("backup-seed-phrase")
|
|
font.pixelSize: 15
|
|
color: !badge.visible ? Style.current.darkGrey : Style.current.textColor
|
|
}
|
|
|
|
Rectangle {
|
|
id: badge
|
|
visible: !profileModel.mnemonic.isBackedUp
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: 0
|
|
radius: 9
|
|
color: Style.current.blue
|
|
width: 18
|
|
height: 18
|
|
Text {
|
|
font.pixelSize: 12
|
|
color: Style.current.white
|
|
anchors.centerIn: parent
|
|
text: "1"
|
|
}
|
|
}
|
|
|
|
MouseArea {
|
|
enabled: !profileModel.mnemonic.isBackedUp
|
|
anchors.fill: parent
|
|
onClicked: backupSeedModal.open()
|
|
cursorShape: enabled ? Qt.PointingHandCursor : Qt.ArrowCursor
|
|
}
|
|
}
|
|
|
|
BackupSeedModal {
|
|
id: backupSeedModal
|
|
}
|
|
|
|
Separator {
|
|
id: separator
|
|
Layout.topMargin: Style.current.bigPadding - containerColumn.spacing
|
|
}
|
|
|
|
Separator {
|
|
id: separator2
|
|
Layout.topMargin: Style.current.bigPadding - containerColumn.spacing
|
|
}
|
|
|
|
StatusSectionHeadline {
|
|
id: labelPrivacy
|
|
//% "Privacy"
|
|
text: qsTrId("privacy")
|
|
}
|
|
RowLayout {
|
|
spacing: Style.current.padding
|
|
width: parent.width
|
|
Column {
|
|
Layout.fillWidth: true
|
|
StyledText {
|
|
//% "Display images in chat automatically"
|
|
text: qsTrId("display-images-in-chat-automatically")
|
|
font.pixelSize: 15
|
|
font.weight: Font.Medium
|
|
}
|
|
StyledText {
|
|
width: parent.width
|
|
text: qsTr("All images (links that contain an image extension) will be downloaded and displayed, regardless of the whitelist settings below")
|
|
font.pixelSize: 15
|
|
font.weight: Font.Thin
|
|
color: Style.current.secondaryText
|
|
wrapMode: Text.WordWrap
|
|
}
|
|
}
|
|
StatusSwitch {
|
|
id: displayChatImagesSwitch
|
|
Layout.rightMargin: 0
|
|
checked: appSettings.displayChatImages
|
|
onCheckedChanged: function (value) {
|
|
appSettings.displayChatImages = this.checked
|
|
}
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: openLinksWithModal
|
|
OpenLinksWithModal {}
|
|
}
|
|
|
|
StatusSettingsLineButton {
|
|
text: qsTr("Open links with...")
|
|
currentValue: appSettings.openLinksInStatus ? "Status" : qsTr("My default browser")
|
|
onClicked: openPopup(openLinksWithModal)
|
|
}
|
|
|
|
StatusSectionHeadline {
|
|
id: labelURLUnfurling
|
|
text: qsTr("Chat link previews")
|
|
font.pixelSize: 17
|
|
font.weight: Font.Bold
|
|
color: Style.current.textColor
|
|
}
|
|
|
|
StatusSectionHeadline {
|
|
id: labelWebsites
|
|
text: qsTr("Websites")
|
|
}
|
|
|
|
Connections {
|
|
target: applicationWindow
|
|
onSettingsLoaded: {
|
|
let whitelist = JSON.parse(profileModel.getLinkPreviewWhitelist())
|
|
whitelist.forEach(entry => {
|
|
entry.isWhitelisted = appSettings.whitelistedUnfurlingSites[entry.address] || false
|
|
previewableSites.append(entry)
|
|
})
|
|
}
|
|
}
|
|
|
|
ListView {
|
|
id: sitesListView
|
|
width: parent.width
|
|
model: previewableSites
|
|
interactive: false
|
|
height: childrenRect.height
|
|
spacing: Style.current.padding
|
|
|
|
delegate: Component {
|
|
Item {
|
|
width: parent.width
|
|
height: childrenRect.height
|
|
|
|
StyledText {
|
|
id: siteTitle
|
|
text: title
|
|
font.pixelSize: 15
|
|
font.weight: Font.Medium
|
|
}
|
|
|
|
StyledText {
|
|
text: address
|
|
font.pixelSize: 15
|
|
font.weight: Font.Thin
|
|
color: Style.current.secondaryText
|
|
anchors.top: siteTitle.bottom
|
|
}
|
|
|
|
StatusSwitch {
|
|
checked: !!isWhitelisted
|
|
onCheckedChanged: function () {
|
|
const settings = appSettings.whitelistedUnfurlingSites
|
|
settings[address] = this.checked
|
|
appSettings.whitelistedUnfurlingSites = settings
|
|
}
|
|
anchors.verticalCenter: siteTitle.bottom
|
|
anchors.right: parent.right
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
StyledText {
|
|
text: qsTr("Previewing links from these websites may share your metadata with their owners.")
|
|
width: parent.width
|
|
wrapMode: Text.WordWrap
|
|
font.weight: Font.Thin
|
|
color: Style.current.secondaryText
|
|
font.pixelSize: 15
|
|
}
|
|
}
|
|
}
|
|
|
|
/*##^##
|
|
Designer {
|
|
D{i:0;autoSize:true;formeditorColor:"#ffffff";height:480;width:640}
|
|
}
|
|
##^##*/
|