mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-10 06:16:32 +00:00
a26657bbca
Add new settings page for metrics management - Privacy and security Add popup to enable/disable metrics on Onboarding and Privacy screens Add MetricsStore in QML Issue #15490
562 lines
19 KiB
QML
562 lines
19 KiB
QML
import QtQuick 2.13
|
||
import QtQuick.Layouts 1.12
|
||
import QtQuick.Controls 2.13
|
||
import QtQuick.Controls.Universal 2.12
|
||
|
||
import StatusQ.Controls 0.1
|
||
import StatusQ.Core 0.1
|
||
import StatusQ.Core.Theme 0.1
|
||
import StatusQ.Components 0.1
|
||
|
||
import shared 1.0
|
||
import shared.panels 1.0
|
||
import shared.popups 1.0
|
||
import shared.stores 1.0
|
||
|
||
import "../popups"
|
||
import "../controls"
|
||
import "../stores"
|
||
|
||
import utils 1.0
|
||
|
||
Item {
|
||
id: root
|
||
|
||
property StartupStore startupStore
|
||
property MetricsStore metricsStore
|
||
|
||
Component.onCompleted: {
|
||
if (button1.visible) {
|
||
button1.forceActiveFocus()
|
||
}
|
||
}
|
||
|
||
QtObject {
|
||
id: d
|
||
readonly property int infoWidth: 292
|
||
readonly property int infoHeight: 309
|
||
readonly property int infoMargin: 24
|
||
readonly property int infoTextWidth: d.infoWidth - 2 * d.infoMargin
|
||
readonly property int imgKeysWH: 160
|
||
readonly property int imgSeedPhraseWH: 257
|
||
|
||
|
||
function showMetricsAndRunAction(action) {
|
||
if (root.startupStore.currentStartupState.stateType === Constants.startupState.welcomeNewStatusUser) {
|
||
metricsEnablePopup.actionOnClose = action
|
||
metricsEnablePopup.visible = true
|
||
} else {
|
||
action()
|
||
}
|
||
}
|
||
}
|
||
ColumnLayout {
|
||
anchors.centerIn: parent
|
||
height: Constants.onboarding.loginHeight
|
||
spacing: Style.current.bigPadding
|
||
|
||
Image {
|
||
id: keysImg
|
||
Layout.alignment: Qt.AlignHCenter
|
||
mipmap: true
|
||
cache: false
|
||
}
|
||
|
||
StyledText {
|
||
id: txtTitle
|
||
Layout.alignment: Qt.AlignHCenter
|
||
font.bold: true
|
||
font.letterSpacing: -0.2
|
||
font.pixelSize: Constants.onboarding.fontSize1
|
||
}
|
||
|
||
StyledText {
|
||
id: txtDesc
|
||
Layout.alignment: Qt.AlignHCenter
|
||
color: Style.current.secondaryText
|
||
horizontalAlignment: Text.AlignHCenter
|
||
wrapMode: Text.WordWrap
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
}
|
||
|
||
Item {
|
||
id: spacer
|
||
Layout.preferredHeight: Style.current.padding
|
||
Layout.preferredWidth: 1
|
||
}
|
||
|
||
Row {
|
||
id: whatYouLoseGet
|
||
visible: root.startupStore.currentStartupState.stateType === Constants.startupState.userProfileCreateSameChatKey
|
||
spacing: Style.current.bigPadding
|
||
Layout.alignment: Qt.AlignHCenter
|
||
|
||
Rectangle {
|
||
width: d.infoWidth
|
||
height: d.infoHeight
|
||
radius: Constants.onboarding.radius
|
||
color: Theme.palette.baseColor5
|
||
|
||
ColumnLayout {
|
||
anchors.fill: parent
|
||
anchors.margins: d.infoMargin
|
||
spacing: Style.current.bigPadding
|
||
|
||
RowLayout {
|
||
StyledText {
|
||
text: qsTr("What you lose")
|
||
font.pixelSize: Constants.onboarding.fontSize2
|
||
font.bold: true
|
||
}
|
||
Item {
|
||
Layout.fillWidth: true
|
||
Layout.preferredHeight: 1
|
||
}
|
||
StatusEmoji {
|
||
width: 24
|
||
height: 24
|
||
emojiId: "1f622"
|
||
}
|
||
}
|
||
|
||
ColumnLayout {
|
||
StyledText {
|
||
text: qsTr("Chat history")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
font.bold: true
|
||
}
|
||
|
||
StyledText {
|
||
Layout.preferredWidth: d.infoTextWidth
|
||
text: qsTr("Past is in the past. Move on :)")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
wrapMode: Text.WordWrap
|
||
}
|
||
}
|
||
|
||
ColumnLayout {
|
||
StyledText {
|
||
text: qsTr("Contacts")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
font.bold: true
|
||
}
|
||
|
||
StyledText {
|
||
Layout.preferredWidth: d.infoTextWidth
|
||
text: qsTr("You can add them back to your contact list")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
wrapMode: Text.WordWrap
|
||
}
|
||
}
|
||
|
||
ColumnLayout {
|
||
StyledText {
|
||
text: qsTr("Community memberships")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
font.bold: true
|
||
}
|
||
|
||
StyledText {
|
||
Layout.preferredWidth: d.infoTextWidth
|
||
text: qsTr("You’ll need to rejoin communities")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
wrapMode: Text.WordWrap
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
Rectangle {
|
||
width: d.infoWidth
|
||
height: d.infoHeight
|
||
radius: Constants.onboarding.radius
|
||
color: Theme.palette.baseColor5
|
||
|
||
ColumnLayout {
|
||
anchors.fill: parent
|
||
anchors.margins: d.infoMargin
|
||
spacing: Style.current.bigPadding
|
||
|
||
RowLayout {
|
||
StyledText {
|
||
text: qsTr("What you keep")
|
||
font.pixelSize: Constants.onboarding.fontSize2
|
||
font.bold: true
|
||
}
|
||
Item {
|
||
Layout.fillWidth: true
|
||
Layout.preferredHeight: 1
|
||
}
|
||
StatusEmoji {
|
||
width: 24
|
||
height: 24
|
||
emojiId: "1f389"
|
||
}
|
||
}
|
||
|
||
ColumnLayout {
|
||
StyledText {
|
||
text: qsTr("Chatkey")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
font.bold: true
|
||
}
|
||
|
||
StyledText {
|
||
Layout.preferredWidth: d.infoTextWidth
|
||
text: qsTr("Your contacts can still reach you just like before")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
wrapMode: Text.WordWrap
|
||
}
|
||
}
|
||
|
||
ColumnLayout {
|
||
StyledText {
|
||
text: qsTr("Wallet accounts")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
font.bold: true
|
||
}
|
||
|
||
StyledText {
|
||
Layout.preferredWidth: d.infoTextWidth
|
||
text: qsTr("All your assets and collectibles are safe in your accounts")
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
wrapMode: Text.WordWrap
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
StatusButton {
|
||
id: button1
|
||
objectName: "keysMainViewPrimaryActionButton"
|
||
Layout.alignment: Qt.AlignHCenter
|
||
visible: text !== ""
|
||
onClicked: {
|
||
d.showMetricsAndRunAction(root.startupStore.doPrimaryAction)
|
||
}
|
||
Keys.onPressed: {
|
||
if (event.key === Qt.Key_Return || event.key === Qt.Key_Enter) {
|
||
event.accepted = true
|
||
d.showMetricsAndRunAction(root.startupStore.doPrimaryAction)
|
||
}
|
||
}
|
||
}
|
||
|
||
StatusBaseText {
|
||
id: button2
|
||
objectName: "iDontHaveOtherDeviceButton"
|
||
Layout.alignment: Qt.AlignHCenter
|
||
visible: text !== ""
|
||
color: Theme.palette.primaryColor1
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
MouseArea {
|
||
anchors.fill: parent
|
||
cursorShape: Qt.PointingHandCursor
|
||
hoverEnabled: true
|
||
onEntered: {
|
||
parent.font.underline = true
|
||
}
|
||
onExited: {
|
||
parent.font.underline = false
|
||
}
|
||
onClicked: {
|
||
d.showMetricsAndRunAction(root.startupStore.doSecondaryAction)
|
||
}
|
||
}
|
||
}
|
||
|
||
Row {
|
||
id: button3
|
||
|
||
property string text: ""
|
||
property string link: ""
|
||
property bool useLinkForButton: false
|
||
|
||
Layout.alignment: Qt.AlignHCenter
|
||
visible: button3.text !== ""
|
||
spacing: 0
|
||
padding: 0
|
||
|
||
StatusBaseText {
|
||
text: button3.text
|
||
color: Theme.palette.primaryColor1
|
||
font.pixelSize: Constants.onboarding.fontSize3
|
||
MouseArea {
|
||
anchors.fill: parent
|
||
cursorShape: Qt.PointingHandCursor
|
||
hoverEnabled: true
|
||
onEntered: {
|
||
parent.font.underline = true
|
||
}
|
||
onExited: {
|
||
parent.font.underline = false
|
||
}
|
||
onClicked: {
|
||
if (button3.useLinkForButton) {
|
||
Qt.openUrlExternally(button3.link)
|
||
return
|
||
}
|
||
d.showMetricsAndRunAction(root.startupStore.doTertiaryAction)
|
||
}
|
||
}
|
||
}
|
||
|
||
StatusFlatRoundButton {
|
||
visible: button3.link !== ""
|
||
height: 20
|
||
width: 20
|
||
icon.name: "external"
|
||
icon.width: 16
|
||
icon.height: 16
|
||
onClicked: {
|
||
Qt.openUrlExternally(button3.link)
|
||
}
|
||
}
|
||
}
|
||
|
||
Item {
|
||
Layout.fillWidth: true
|
||
Layout.fillHeight: true
|
||
}
|
||
}
|
||
|
||
component MetricsEnablePopupWithActionOnClose: MetricsEnablePopup {
|
||
property var actionOnClose
|
||
}
|
||
|
||
MetricsEnablePopupWithActionOnClose {
|
||
id: metricsEnablePopup
|
||
isOnboarding: true
|
||
|
||
function finalAction(enable) {
|
||
if (!!actionOnClose)
|
||
actionOnClose()
|
||
root.metricsStore.toggleCentralizedMetrics(enable)
|
||
}
|
||
|
||
onAccepted: finalAction(true)
|
||
onRejected: finalAction(false)
|
||
}
|
||
|
||
states: [
|
||
State {
|
||
name: Constants.startupState.welcomeOldStatusUser
|
||
when: root.startupStore.currentStartupState.stateType === Constants.startupState.welcomeOldStatusUser
|
||
PropertyChanges {
|
||
target: keysImg
|
||
Layout.preferredWidth: d.imgKeysWH
|
||
Layout.preferredHeight: d.imgKeysWH
|
||
source: Style.png("onboarding/keys")
|
||
}
|
||
PropertyChanges {
|
||
target: txtTitle
|
||
text: qsTr("Sign in by syncing")
|
||
}
|
||
PropertyChanges {
|
||
target: txtDesc
|
||
text: qsTr("Get your data straight from your other device.")
|
||
height: Constants.onboarding.loginInfoHeight2
|
||
}
|
||
PropertyChanges {
|
||
target: button1
|
||
text: qsTr("Scan or enter a sync code")
|
||
}
|
||
PropertyChanges {
|
||
target: button2
|
||
text: qsTr("I don’t have other device")
|
||
}
|
||
PropertyChanges {
|
||
target: button3
|
||
text: ""
|
||
}
|
||
},
|
||
State {
|
||
name: Constants.startupState.recoverOldUser
|
||
when: root.startupStore.currentStartupState.stateType === Constants.startupState.recoverOldUser
|
||
PropertyChanges {
|
||
target: keysImg
|
||
Layout.preferredWidth: d.imgKeysWH
|
||
Layout.preferredHeight: d.imgKeysWH
|
||
source: Style.png("onboarding/keys")
|
||
}
|
||
PropertyChanges {
|
||
target: txtTitle
|
||
text: qsTr("Connect your keys")
|
||
}
|
||
PropertyChanges {
|
||
target: txtDesc
|
||
text: qsTr("Use your existing Status keys to login to this device.")
|
||
height: Constants.onboarding.loginInfoHeight2
|
||
}
|
||
PropertyChanges {
|
||
target: button1
|
||
text: ""
|
||
}
|
||
PropertyChanges {
|
||
target: button2
|
||
text: qsTr("Login with Keycard")
|
||
}
|
||
PropertyChanges {
|
||
target: button3
|
||
text: qsTr("Enter a seed phrase")
|
||
}
|
||
},
|
||
State {
|
||
name: Constants.startupState.welcomeNewStatusUser
|
||
when: root.startupStore.currentStartupState.stateType === Constants.startupState.welcomeNewStatusUser
|
||
PropertyChanges {
|
||
target: keysImg
|
||
Layout.preferredWidth: d.imgKeysWH
|
||
Layout.preferredHeight: d.imgKeysWH
|
||
source: Style.png("onboarding/keys")
|
||
}
|
||
PropertyChanges {
|
||
target: txtTitle
|
||
text: qsTr("Get your keys")
|
||
}
|
||
PropertyChanges {
|
||
target: txtDesc
|
||
text: qsTr("A set of keys controls your account. Your keys live on your\ndevice, so only you can use them.")
|
||
height: Constants.onboarding.loginInfoHeight2
|
||
}
|
||
PropertyChanges {
|
||
target: button1
|
||
text: qsTr("Generate new keys")
|
||
}
|
||
PropertyChanges {
|
||
target: button2
|
||
text: qsTr("Generate keys for a new Keycard")
|
||
}
|
||
PropertyChanges {
|
||
target: button3
|
||
text: qsTr("Import a seed phrase")
|
||
}
|
||
},
|
||
State {
|
||
name: Constants.startupState.userProfileImportSeedPhrase
|
||
when: root.startupStore.currentStartupState.stateType === Constants.startupState.userProfileImportSeedPhrase
|
||
PropertyChanges {
|
||
target: txtTitle
|
||
text: qsTr("Import a seed phrase")
|
||
}
|
||
PropertyChanges {
|
||
target: keysImg
|
||
Layout.preferredWidth: d.imgSeedPhraseWH
|
||
Layout.preferredHeight: d.imgSeedPhraseWH
|
||
source: Style.png("onboarding/seed-phrase")
|
||
}
|
||
PropertyChanges {
|
||
target: txtDesc
|
||
text: qsTr("Seed phrases are used to back up and restore your keys.\nOnly use this option if you already have a seed phrase.")
|
||
height: Constants.onboarding.loginInfoHeight2
|
||
}
|
||
PropertyChanges {
|
||
target: button1
|
||
text: qsTr("Import a seed phrase")
|
||
}
|
||
PropertyChanges {
|
||
target: button2
|
||
text: qsTr("Import a seed phrase into a new Keycard")
|
||
}
|
||
PropertyChanges {
|
||
target: button3
|
||
text: ""
|
||
}
|
||
},
|
||
State {
|
||
name: Constants.startupState.profileFetchingAnnouncement
|
||
when: root.startupStore.currentStartupState.stateType === Constants.startupState.profileFetchingAnnouncement
|
||
PropertyChanges {
|
||
target: keysImg
|
||
Layout.preferredWidth: d.imgKeysWH
|
||
Layout.preferredHeight: d.imgKeysWH
|
||
source: Style.png("onboarding/keys")
|
||
}
|
||
PropertyChanges {
|
||
target: txtTitle
|
||
text: qsTr("Unable to fetch your profile")
|
||
}
|
||
PropertyChanges {
|
||
target: txtDesc
|
||
text: qsTr("We cannot retrieve your profile data. If you have another device\nwith the Status profile, make sure that Status is running on the\nother device and that both devices are online.")
|
||
height: Constants.onboarding.loginInfoHeight3
|
||
}
|
||
PropertyChanges {
|
||
target: button1
|
||
text: qsTr("Try to fetch profile again")
|
||
}
|
||
PropertyChanges {
|
||
target: button2
|
||
text: qsTr("Create new profile with the same chatkey")
|
||
}
|
||
PropertyChanges {
|
||
target: button3
|
||
text: ""
|
||
}
|
||
},
|
||
State {
|
||
name: Constants.startupState.userProfileCreateSameChatKey
|
||
when: root.startupStore.currentStartupState.stateType === Constants.startupState.userProfileCreateSameChatKey
|
||
PropertyChanges {
|
||
target: keysImg
|
||
visible: false
|
||
}
|
||
PropertyChanges {
|
||
target: txtTitle
|
||
text: qsTr("Create a new profile with the same chatkey")
|
||
}
|
||
PropertyChanges {
|
||
target: txtDesc
|
||
text: qsTr("We cannot fetch your profile data, but you still can create a profile with a same\nchatkey, name and avatar so you contacts will be able to reach you. ")
|
||
height: Constants.onboarding.loginInfoHeight2
|
||
}
|
||
PropertyChanges {
|
||
target: button1
|
||
text: qsTr("Continue")
|
||
}
|
||
PropertyChanges {
|
||
target: button2
|
||
text: ""
|
||
}
|
||
PropertyChanges {
|
||
target: button3
|
||
text: ""
|
||
}
|
||
},
|
||
State {
|
||
name: Constants.startupState.lostKeycardOptions
|
||
when: root.startupStore.currentStartupState.stateType === Constants.startupState.lostKeycardOptions
|
||
PropertyChanges {
|
||
target: keysImg
|
||
Layout.preferredWidth: Constants.keycard.general.imageWidth
|
||
Layout.preferredHeight: Constants.keycard.general.imageHeight
|
||
source: Style.png("keycard/keycard-new")
|
||
}
|
||
PropertyChanges {
|
||
target: txtTitle
|
||
text: ""
|
||
}
|
||
PropertyChanges {
|
||
target: txtDesc
|
||
text: qsTr("Sorry to hear you’ve lost your Keycard, you have 3 options")
|
||
height: Constants.onboarding.loginInfoHeight2
|
||
}
|
||
PropertyChanges {
|
||
target: button1
|
||
text: qsTr("Create replacement Keycard with seed phrase")
|
||
}
|
||
PropertyChanges {
|
||
target: button2
|
||
text: qsTr("Start using account without keycard")
|
||
}
|
||
PropertyChanges {
|
||
target: button3
|
||
text: qsTr("Order new keycard")
|
||
link: "https://get.keycard.tech"
|
||
useLinkForButton: true
|
||
}
|
||
}
|
||
]
|
||
}
|