Keys: remove wallet QR code; define states; hide copy button and warning msg when field is empty

This commit is contained in:
rating89us 2021-08-02 16:45:04 +02:00 committed by GitHub
parent 51828babbb
commit 3cbf8121d0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -41,10 +41,53 @@ Rectangle {
id: page id: page
property bool viewOnly: false property bool viewOnly: false
property int keysHeight: mainLayout.height + 100 // Ensure sufficient height for QR code, even in minimum width window case. property int keysHeight: mainLayout.height + 100 // Ensure sufficient height for QR code, even in minimum width window case.
property var seed: ""
property var walletCreationHeight: ""
property var currentWalletAddress: ""
property var secretViewKey: ""
property var publicViewKey: ""
property var secretSpendKey: ""
property var publicSpendKey: ""
color: "transparent" color: "transparent"
Clipboard { id: clipboard } Clipboard { id: clipboard }
state: "default"
states: [
State {
// normal spend wallet
name: "default";
when: typeof currentWallet != "undefined" && !page.viewOnly && !currentWallet.isHwBacked()
PropertyChanges { target: seedWarningBox; visible: true}
PropertyChanges { target: seedText; text: page.seed}
PropertyChanges { target: seedText; copyButton: true}
PropertyChanges { target: secretSpendKey; text: page.secretSpendKey}
PropertyChanges { target: secretSpendKey; copyButton: true}
PropertyChanges { target: exportWalletAsQRCodeColumn; visible: false }
}, State {
// view-only wallet
name: "viewonly";
when: typeof currentWallet != "undefined" && page.viewOnly
PropertyChanges { target: seedWarningBox; visible: false}
PropertyChanges { target: seedText; text: qsTr("(View-only wallet - No mnemonic seed available)") + translationManager.emptyString }
PropertyChanges { target: seedText; copyButton: false}
PropertyChanges { target: secretSpendKey; text: qsTr("(View-only wallet - No secret spend key available)") + translationManager.emptyString }
PropertyChanges { target: secretSpendKey; copyButton: false}
PropertyChanges { target: exportWalletAsQRCodeColumn; visible: false }
}, State {
// hardware wallet
name: "hardwarewallet";
when: typeof currentWallet != "undefined" && currentWallet.isHwBacked()
PropertyChanges { target: seedWarningBox; visible: false}
PropertyChanges { target: seedText; text: qsTr("Mnemonic seed protected by hardware device.") + translationManager.emptyString }
PropertyChanges { target: seedText; copyButton: false}
PropertyChanges { target: secretSpendKey; text: qsTr("(Hardware device wallet - No secret spend key available)") + translationManager.emptyString }
PropertyChanges { target: secretSpendKey; copyButton: false}
PropertyChanges { target: exportWalletAsQRCodeColumn; visible: false }
}
]
ColumnLayout { ColumnLayout {
id: mainLayout id: mainLayout
@ -82,6 +125,7 @@ Rectangle {
} }
MoneroComponents.WarningBox { MoneroComponents.WarningBox {
id: seedWarningBox
text: qsTr("WARNING: Copying your seed to clipboard can expose you to malicious software, which may record your seed and steal your Monero. Please write down your seed manually.") + translationManager.emptyString text: qsTr("WARNING: Copying your seed to clipboard can expose you to malicious software, which may record your seed and steal your Monero. Please write down your seed manually.") + translationManager.emptyString
} }
@ -93,6 +137,7 @@ Rectangle {
readOnly: true readOnly: true
wrapMode: Text.WordWrap wrapMode: Text.WordWrap
fontColor: MoneroComponents.Style.defaultFontColor fontColor: MoneroComponents.Style.defaultFontColor
text: page.seed
} }
} }
@ -121,6 +166,7 @@ Rectangle {
copyButton: true copyButton: true
labelText: qsTr("Block #") + translationManager.emptyString labelText: qsTr("Block #") + translationManager.emptyString
fontSize: 16 fontSize: 16
text: page.walletCreationHeight
} }
} }
@ -148,6 +194,7 @@ Rectangle {
wrapMode: Text.Wrap wrapMode: Text.Wrap
labelText: qsTr("Primary address") + translationManager.emptyString labelText: qsTr("Primary address") + translationManager.emptyString
fontSize: 16 fontSize: 16
text: page.currentWalletAddress
} }
MoneroComponents.LineEdit { MoneroComponents.LineEdit {
Layout.fillWidth: true Layout.fillWidth: true
@ -157,6 +204,7 @@ Rectangle {
copyButton: true copyButton: true
labelText: qsTr("Secret view key") + translationManager.emptyString labelText: qsTr("Secret view key") + translationManager.emptyString
fontSize: 16 fontSize: 16
text: page.secretViewKey
} }
MoneroComponents.LineEdit { MoneroComponents.LineEdit {
Layout.fillWidth: true Layout.fillWidth: true
@ -166,6 +214,7 @@ Rectangle {
copyButton: true copyButton: true
labelText: qsTr("Public view key") + translationManager.emptyString labelText: qsTr("Public view key") + translationManager.emptyString
fontSize: 16 fontSize: 16
text: page.publicViewKey
} }
MoneroComponents.LineEdit { MoneroComponents.LineEdit {
Layout.fillWidth: true Layout.fillWidth: true
@ -175,6 +224,7 @@ Rectangle {
copyButton: true copyButton: true
labelText: qsTr("Secret spend key") + translationManager.emptyString labelText: qsTr("Secret spend key") + translationManager.emptyString
fontSize: 16 fontSize: 16
text: page.secretSpendKey
} }
MoneroComponents.LineEdit { MoneroComponents.LineEdit {
Layout.fillWidth: true Layout.fillWidth: true
@ -184,10 +234,12 @@ Rectangle {
copyButton: true copyButton: true
labelText: qsTr("Public spend key") + translationManager.emptyString labelText: qsTr("Public spend key") + translationManager.emptyString
fontSize: 16 fontSize: 16
text: page.publicSpendKey
} }
} }
ColumnLayout { ColumnLayout {
id: exportWalletAsQRCodeColumn
Layout.fillWidth: true Layout.fillWidth: true
MoneroComponents.Label { MoneroComponents.Label {
@ -205,45 +257,47 @@ Rectangle {
} }
ColumnLayout { ColumnLayout {
id: walletTypeRadioButtons
Layout.bottomMargin: 30
MoneroComponents.RadioButton { MoneroComponents.RadioButton {
id: showFullQr id: showFullQr
checked: true
enabled: !this.checked enabled: !this.checked
checked: fullWalletQRCode.visible
text: qsTr("Spendable Wallet") + translationManager.emptyString text: qsTr("Spendable Wallet") + translationManager.emptyString
onClicked: { onClicked: {
viewOnlyQRCode.visible = false
showViewOnlyQr.checked = false showViewOnlyQr.checked = false
} }
} }
MoneroComponents.RadioButton { MoneroComponents.RadioButton {
enabled: !this.checked
id: showViewOnlyQr id: showViewOnlyQr
checked: viewOnlyQRCode.visible checked: false
enabled: !this.checked
text: qsTr("View Only Wallet") + translationManager.emptyString text: qsTr("View Only Wallet") + translationManager.emptyString
onClicked: { onClicked: {
viewOnlyQRCode.visible = true
showFullQr.checked = false showFullQr.checked = false
} }
} }
Layout.bottomMargin: 30
} }
Image { Image {
visible: !viewOnlyQRCode.visible
id: fullWalletQRCode id: fullWalletQRCode
visible: showFullQr.checked
Layout.fillWidth: true Layout.fillWidth: true
Layout.minimumHeight: 180 Layout.minimumHeight: 180
smooth: false smooth: false
fillMode: Image.PreserveAspectFit fillMode: Image.PreserveAspectFit
source: viewOnlyQRCode.source +"&spend_key="+page.secretSpendKey
} }
Image { Image {
visible: false
id: viewOnlyQRCode id: viewOnlyQRCode
visible: showViewOnlyQr.checked
Layout.fillWidth: true Layout.fillWidth: true
Layout.minimumHeight: 180 Layout.minimumHeight: 180
smooth: false smooth: false
fillMode: Image.PreserveAspectFit fillMode: Image.PreserveAspectFit
source: "image://qrcode/monero_wallet:" + page.currentWalletAddress + "?view_key="+page.secretViewKey+"&height="+page.walletCreationHeight
} }
MoneroComponents.TextPlain { MoneroComponents.TextPlain {
@ -254,50 +308,31 @@ Rectangle {
text: (viewOnlyQRCode.visible) ? qsTr("View Only Wallet") + translationManager.emptyString : qsTr("Spendable Wallet") + translationManager.emptyString text: (viewOnlyQRCode.visible) ? qsTr("View Only Wallet") + translationManager.emptyString : qsTr("Spendable Wallet") + translationManager.emptyString
horizontalAlignment: Text.AlignHCenter horizontalAlignment: Text.AlignHCenter
} }
}
MoneroComponents.StandardButton { MoneroComponents.StandardButton {
Layout.alignment: Qt.AlignCenter
width: 135
small: true small: true
text: qsTr("Done") + translationManager.emptyString text: qsTr("Done") + translationManager.emptyString
onClicked: { onClicked: {
loadPage("Settings") loadPage("Settings")
} }
Layout.alignment: Qt.AlignCenter
width: 135
}
} }
} }
// fires on every page load // fires on every page load
function onPageCompleted() { function onPageCompleted() {
console.log("keys page loaded"); console.log("keys page loaded");
if (appWindow.currentWallet) {
primaryAddress.text = currentWallet.address(0, 0) page.viewOnly = currentWallet.viewOnly;
walletCreationHeight.text = currentWallet.walletCreationHeight page.seed = currentWallet.seed;
secretViewKey.text = currentWallet.secretViewKey page.secretSpendKey = currentWallet.secretSpendKey;
publicViewKey.text = currentWallet.publicViewKey page.publicSpendKey = currentWallet.publicSpendKey;
secretSpendKey.text = (!currentWallet.viewOnly) ? currentWallet.secretSpendKey : "" page.secretViewKey = currentWallet.secretViewKey;
publicSpendKey.text = currentWallet.publicSpendKey page.publicViewKey = currentWallet.publicViewKey;
page.walletCreationHeight = currentWallet.walletCreationHeight;
seedText.text = currentWallet.seed === "" ? qsTr("Mnemonic seed protected by hardware device.") + translationManager.emptyString : currentWallet.seed page.currentWalletAddress = currentWallet.address(0, 0)
if(typeof currentWallet != "undefined") {
viewOnlyQRCode.source = "image://qrcode/monero_wallet:" + currentWallet.address(0, 0) + "?view_key="+currentWallet.secretViewKey+"&height="+currentWallet.walletCreationHeight
fullWalletQRCode.source = viewOnlyQRCode.source +"&spend_key="+currentWallet.secretSpendKey
if(currentWallet.viewOnly) {
viewOnlyQRCode.visible = true
showFullQr.visible = false
showViewOnlyQr.visible = false
seedText.text = qsTr("(View Only Wallet - No mnemonic seed available)") + translationManager.emptyString
secretSpendKey.text = qsTr("(View Only Wallet - No secret spend key available)") + translationManager.emptyString
}
// hardware device wallet
if(appWindow.currentWallet.isHwBacked() === true) {
showFullQr.visible = false
viewOnlyQRCode.visible = true
showViewOnlyQr.visible = false
secretSpendKey.text = qsTr("(Hardware Device Wallet - No secret spend key available)") + translationManager.emptyString
}
} }
} }