2022-06-22 15:16:21 +03:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.3
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
import shared 1.0
|
2024-01-13 08:54:57 +05:30
|
|
|
import shared.stores 1.0
|
2022-06-22 15:16:21 +03:00
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.popups 1.0
|
|
|
|
import shared.controls.chat 1.0
|
|
|
|
|
|
|
|
import "../../popups"
|
|
|
|
import "../../stores"
|
|
|
|
import "../../controls"
|
2022-08-10 10:34:56 +02:00
|
|
|
import "../../panels"
|
2022-06-22 15:16:21 +03:00
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
2024-01-13 08:54:57 +05:30
|
|
|
import AppLayouts.Wallet.stores 1.0
|
|
|
|
|
2022-06-22 15:16:21 +03:00
|
|
|
ColumnLayout {
|
|
|
|
id: root
|
|
|
|
|
2023-03-08 02:56:41 +01:00
|
|
|
spacing: 20
|
|
|
|
|
2022-06-22 15:16:21 +03:00
|
|
|
property PrivacyStore privacyStore
|
|
|
|
property ProfileStore profileStore
|
|
|
|
property WalletStore walletStore
|
2024-01-13 08:54:57 +05:30
|
|
|
required property WalletAssetsStore walletAssetsStore
|
|
|
|
required property CurrenciesStore currencyStore
|
2023-02-28 16:00:10 +01:00
|
|
|
property var communitiesModel
|
2022-06-22 15:16:21 +03:00
|
|
|
|
2023-11-01 20:54:22 +04:00
|
|
|
property bool hasAnyProfileShowcaseChanges: false
|
|
|
|
|
2022-11-08 21:30:50 +03:00
|
|
|
property QtObject dirtyValues: QtObject {
|
|
|
|
property string displayName: descriptionPanel.displayName.text
|
|
|
|
property string bio: descriptionPanel.bio.text
|
|
|
|
property bool biomentricValue: biometricsSwitch.checked
|
2022-12-01 09:37:46 +01:00
|
|
|
property url profileLargeImage: profileHeader.previewIcon
|
2022-11-08 21:30:50 +03:00
|
|
|
}
|
|
|
|
|
2022-12-05 22:24:55 +03:00
|
|
|
readonly property bool dirty: (!descriptionPanel.isEnsName &&
|
|
|
|
descriptionPanel.displayName.text !== profileStore.displayName) ||
|
2023-11-01 20:54:22 +04:00
|
|
|
descriptionPanel.bio.text !== profileStore.bio ||
|
|
|
|
profileStore.socialLinksDirty ||
|
|
|
|
biometricsSwitch.checked !== biometricsSwitch.currentStoredValue ||
|
|
|
|
profileHeader.icon !== profileStore.profileLargeImage ||
|
|
|
|
hasAnyProfileShowcaseChanges
|
2022-06-22 15:16:21 +03:00
|
|
|
|
2022-08-10 10:34:56 +02:00
|
|
|
readonly property bool valid: !!descriptionPanel.displayName.text && descriptionPanel.displayName.valid
|
2022-06-22 15:16:21 +03:00
|
|
|
|
|
|
|
function reset() {
|
2022-08-10 10:34:56 +02:00
|
|
|
descriptionPanel.displayName.text = Qt.binding(() => { return profileStore.displayName })
|
|
|
|
descriptionPanel.bio.text = Qt.binding(() => { return profileStore.bio })
|
|
|
|
profileStore.resetSocialLinks()
|
2022-06-22 15:16:21 +03:00
|
|
|
biometricsSwitch.checked = Qt.binding(() => { return biometricsSwitch.currentStoredValue })
|
2022-11-08 21:30:50 +03:00
|
|
|
profileHeader.icon = Qt.binding(() => { return profileStore.profileLargeImage })
|
2023-11-01 20:54:22 +04:00
|
|
|
|
|
|
|
profileShowcaseCommunitiesPanel.reset()
|
|
|
|
profileShowcaseAccountsPanel.reset()
|
|
|
|
profileShowcaseCollectiblesPanel.reset()
|
|
|
|
profileShowcaseAssetsPanel.reset()
|
|
|
|
root.profileStore.requestProfileShowcasePreferences()
|
|
|
|
hasAnyProfileShowcaseChanges = false
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function save() {
|
2023-11-01 20:54:22 +04:00
|
|
|
if (hasAnyProfileShowcaseChanges)
|
|
|
|
profileStore.storeProfileShowcasePreferences()
|
|
|
|
|
2022-12-05 22:24:55 +03:00
|
|
|
if (!descriptionPanel.isEnsName)
|
|
|
|
profileStore.setDisplayName(descriptionPanel.displayName.text)
|
2023-08-08 16:54:36 +03:00
|
|
|
profileStore.setBio(descriptionPanel.bio.text.trim())
|
2022-08-10 10:34:56 +02:00
|
|
|
profileStore.saveSocialLinks()
|
2022-11-08 21:30:50 +03:00
|
|
|
if (profileHeader.icon === "") {
|
|
|
|
root.profileStore.removeImage()
|
|
|
|
} else {
|
|
|
|
profileStore.uploadImage(profileHeader.icon,
|
|
|
|
profileHeader.cropRect.x.toFixed(),
|
|
|
|
profileHeader.cropRect.y.toFixed(),
|
|
|
|
(profileHeader.cropRect.x + profileHeader.cropRect.width).toFixed(),
|
|
|
|
(profileHeader.cropRect.y + profileHeader.cropRect.height).toFixed());
|
|
|
|
}
|
2022-12-23 17:11:27 +02:00
|
|
|
|
|
|
|
if (biometricsSwitch.checked && !biometricsSwitch.currentStoredValue)
|
2023-02-02 14:54:35 +01:00
|
|
|
root.privacyStore.tryStoreToKeyChain()
|
2022-12-23 17:11:27 +02:00
|
|
|
else if (!biometricsSwitch.checked)
|
2023-02-02 14:54:35 +01:00
|
|
|
root.privacyStore.tryRemoveFromKeyChain()
|
2022-11-08 21:30:50 +03:00
|
|
|
|
|
|
|
reset()
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
2023-11-01 20:54:22 +04:00
|
|
|
onVisibleChanged: if (visible) profileStore.requestProfileShowcasePreferences()
|
|
|
|
Component.onCompleted: profileStore.requestProfileShowcasePreferences()
|
|
|
|
|
|
|
|
readonly property Connections privacyStoreConnections: Connections {
|
2023-03-20 13:29:05 +01:00
|
|
|
target: Qt.platform.os === Constants.mac ? root.privacyStore.privacyModule : null
|
2022-06-22 15:16:21 +03:00
|
|
|
|
2023-02-02 14:54:35 +01:00
|
|
|
function onStoreToKeychainError(errorDescription: string) {
|
|
|
|
root.reset()
|
|
|
|
}
|
|
|
|
|
|
|
|
function onStoreToKeychainSuccess() {
|
|
|
|
root.reset()
|
|
|
|
}
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
ProfileHeader {
|
2022-11-08 21:30:50 +03:00
|
|
|
id: profileHeader
|
2022-06-22 15:16:21 +03:00
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.leftMargin: Style.current.padding
|
|
|
|
Layout.rightMargin: Style.current.padding
|
|
|
|
|
2022-08-08 00:05:25 +03:00
|
|
|
store: root.profileStore
|
|
|
|
|
2022-06-22 15:16:21 +03:00
|
|
|
displayName: profileStore.name
|
|
|
|
pubkey: profileStore.pubkey
|
2022-07-06 21:07:33 +02:00
|
|
|
icon: profileStore.profileLargeImage
|
2022-06-22 15:16:21 +03:00
|
|
|
imageSize: ProfileHeader.ImageSize.Big
|
2022-08-10 10:34:56 +02:00
|
|
|
|
2022-06-22 15:16:21 +03:00
|
|
|
displayNameVisible: false
|
|
|
|
pubkeyVisible: false
|
|
|
|
emojiHashVisible: false
|
|
|
|
editImageButtonVisible: true
|
|
|
|
}
|
|
|
|
|
2022-08-10 10:34:56 +02:00
|
|
|
ProfileDescriptionPanel {
|
|
|
|
id: descriptionPanel
|
|
|
|
|
2022-12-13 12:37:27 +03:00
|
|
|
readonly property bool isEnsName: profileStore.preferredName
|
2022-08-10 10:34:56 +02:00
|
|
|
|
2022-12-05 22:24:55 +03:00
|
|
|
Layout.fillWidth: true
|
|
|
|
|
|
|
|
displayName.focus: !isEnsName
|
|
|
|
displayName.input.edit.readOnly: isEnsName
|
2022-12-13 12:37:27 +03:00
|
|
|
displayName.text: profileStore.name
|
|
|
|
displayName.validationMode: StatusInput.ValidationMode.Always
|
2022-12-05 22:24:55 +03:00
|
|
|
displayName.validators: isEnsName ? [] : Constants.validators.displayName
|
2022-08-10 10:34:56 +02:00
|
|
|
bio.text: profileStore.bio
|
2023-03-08 02:56:41 +01:00
|
|
|
}
|
2022-08-10 10:34:56 +02:00
|
|
|
|
2023-03-08 02:56:41 +01:00
|
|
|
Separator {
|
|
|
|
Layout.fillWidth: true
|
2022-08-10 10:34:56 +02:00
|
|
|
}
|
|
|
|
|
2023-03-08 02:56:41 +01:00
|
|
|
ProfileSocialLinksPanel {
|
|
|
|
Layout.fillWidth: true
|
2022-08-10 10:34:56 +02:00
|
|
|
profileStore: root.profileStore
|
2023-03-08 02:56:41 +01:00
|
|
|
socialLinksModel: root.profileStore.temporarySocialLinksModel
|
|
|
|
}
|
2022-08-10 10:34:56 +02:00
|
|
|
|
2023-03-08 02:56:41 +01:00
|
|
|
Separator {
|
|
|
|
Layout.fillWidth: true
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
StatusBaseText {
|
|
|
|
visible: Qt.platform.os === Constants.mac
|
|
|
|
text: qsTr("Security")
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
|
2022-06-22 15:16:21 +03:00
|
|
|
StatusListItem {
|
|
|
|
Layout.fillWidth: true
|
2023-02-28 16:00:10 +01:00
|
|
|
visible: Qt.platform.os === Constants.mac
|
2022-06-22 15:16:21 +03:00
|
|
|
title: qsTr("Biometric login and transaction authentication")
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.name: "touch-id"
|
2022-06-22 15:16:21 +03:00
|
|
|
components: [ StatusSwitch {
|
|
|
|
id: biometricsSwitch
|
2022-07-13 11:17:18 +02:00
|
|
|
horizontalPadding: 0
|
2022-07-21 13:29:18 +02:00
|
|
|
readonly property bool currentStoredValue: localAccountSettings.storeToKeychainValue === Constants.keychain.storedValue.store
|
2022-06-22 15:16:21 +03:00
|
|
|
checked: currentStoredValue
|
|
|
|
} ]
|
2022-08-24 17:37:05 +03:00
|
|
|
onClicked: biometricsSwitch.toggle()
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
2023-03-08 02:56:41 +01:00
|
|
|
Separator {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
visible: Qt.platform.os === Constants.mac
|
|
|
|
}
|
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
StatusBaseText {
|
2023-11-01 20:54:22 +04:00
|
|
|
text: qsTr("Showcase")
|
2023-03-20 13:29:05 +01:00
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
|
2022-06-22 15:16:21 +03:00
|
|
|
StatusTabBar {
|
|
|
|
id: showcaseTabBar
|
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
StatusTabButton {
|
|
|
|
width: implicitWidth
|
|
|
|
leftPadding: 0
|
|
|
|
text: qsTr("Communities")
|
|
|
|
}
|
2022-06-22 15:16:21 +03:00
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
StatusTabButton {
|
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Accounts")
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusTabButton {
|
2023-03-20 13:29:05 +01:00
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Collectibles")
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusTabButton {
|
2023-03-20 13:29:05 +01:00
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Assets")
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StackLayout {
|
2023-03-20 13:29:05 +01:00
|
|
|
id: showcaseStack
|
2022-06-22 15:16:21 +03:00
|
|
|
Layout.fillWidth: true
|
|
|
|
currentIndex: showcaseTabBar.currentIndex
|
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
ProfileShowcaseCommunitiesPanel {
|
2023-11-01 20:54:22 +04:00
|
|
|
id: profileShowcaseCommunitiesPanel
|
2023-03-20 13:29:05 +01:00
|
|
|
Layout.minimumHeight: implicitHeight
|
|
|
|
Layout.maximumHeight: implicitHeight
|
|
|
|
baseModel: root.communitiesModel
|
2023-11-01 20:54:22 +04:00
|
|
|
showcaseModel: root.profileStore.profileShowcaseCommunitiesModel
|
|
|
|
onShowcaseEntryChanged: hasAnyProfileShowcaseChanges = true
|
2023-03-20 13:29:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
ProfileShowcaseAccountsPanel {
|
2023-11-01 20:54:22 +04:00
|
|
|
id: profileShowcaseAccountsPanel
|
2023-03-20 13:29:05 +01:00
|
|
|
Layout.minimumHeight: implicitHeight
|
|
|
|
Layout.maximumHeight: implicitHeight
|
|
|
|
baseModel: root.walletStore.accounts
|
2023-11-01 20:54:22 +04:00
|
|
|
showcaseModel: root.profileStore.profileShowcaseAccountsModel
|
2023-04-25 18:54:50 +02:00
|
|
|
currentWallet: root.walletStore.overview.mixedcaseAddress
|
2023-11-01 20:54:22 +04:00
|
|
|
onShowcaseEntryChanged: hasAnyProfileShowcaseChanges = true
|
2023-03-20 13:29:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
ProfileShowcaseCollectiblesPanel {
|
2023-11-01 20:54:22 +04:00
|
|
|
id: profileShowcaseCollectiblesPanel
|
2023-03-20 13:29:05 +01:00
|
|
|
Layout.minimumHeight: implicitHeight
|
|
|
|
Layout.maximumHeight: implicitHeight
|
2024-01-25 21:43:36 +04:00
|
|
|
baseModel: root.profileStore.collectiblesModel
|
2023-11-01 20:54:22 +04:00
|
|
|
showcaseModel: root.profileStore.profileShowcaseCollectiblesModel
|
|
|
|
onShowcaseEntryChanged: hasAnyProfileShowcaseChanges = true
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
|
2023-03-20 13:29:05 +01:00
|
|
|
ProfileShowcaseAssetsPanel {
|
2023-11-01 20:54:22 +04:00
|
|
|
id: profileShowcaseAssetsPanel
|
2023-03-20 13:29:05 +01:00
|
|
|
Layout.minimumHeight: implicitHeight
|
|
|
|
Layout.maximumHeight: implicitHeight
|
2024-01-25 21:43:36 +04:00
|
|
|
baseModel: root.walletAssetsStore.groupedAccountAssetsModel // TODO: instantiate an assets model in profile module
|
2023-11-01 20:54:22 +04:00
|
|
|
showcaseModel: root.profileStore.profileShowcaseAssetsModel
|
|
|
|
onShowcaseEntryChanged: hasAnyProfileShowcaseChanges = true
|
2024-01-13 08:54:57 +05:30
|
|
|
formatCurrencyAmount: function(amount, symbol) {
|
|
|
|
return root.currencyStore.formatCurrencyAmount(amount, symbol)
|
|
|
|
}
|
2022-06-22 15:16:21 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|