2018-01-07 06:20:45 +01:00
// Copyright (c) 2014-2018, The Monero Project
2017-08-07 10:48:13 +02:00
//
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without modification, are
// permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice, this list of
// conditions and the following disclaimer.
//
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
// of conditions and the following disclaimer in the documentation and/or other
// materials provided with the distribution.
//
// 3. Neither the name of the copyright holder nor the names of its contributors may be
// used to endorse or promote products derived from this software without specific
// prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
import QtQuick 2.0
import QtQuick . Controls 1.4
import QtQuick . Controls . Styles 1.4
import QtQuick . Layouts 1.1
import QtQuick . Dialogs 1.2
2018-01-28 00:14:42 +01:00
import moneroComponents . Clipboard 1.0
2017-08-07 10:48:13 +02:00
import "../version.js" as Version
import "../components"
2018-01-28 00:14:42 +01:00
import "." 1.0
2017-08-07 10:48:13 +02:00
Rectangle {
property bool viewOnly: false
id: page
2018-11-29 09:42:13 +01:00
property int keysHeight: mainLayout . height + 100 * scaleRatio // Ensure sufficient height for QR code, even in minimum width window case.
2017-08-07 10:48:13 +02:00
2018-01-28 00:14:42 +01:00
color: "transparent"
2017-08-07 10:48:13 +02:00
Clipboard { id: clipboard }
ColumnLayout {
id: mainLayout
2018-01-28 00:14:42 +01:00
2017-08-07 10:48:13 +02:00
anchors.left: parent . left
anchors.top: parent . top
anchors.right: parent . right
2018-01-28 00:14:42 +01:00
anchors.margins: ( isMobile ) ? 17 : 20
anchors.topMargin: 40 * scaleRatio
spacing: 30 * scaleRatio
2017-08-07 10:48:13 +02:00
Layout.fillWidth: true
2018-03-31 14:57:00 +02:00
RowLayout {
// TODO: Move the warning box to its own component, so it can be used in multiple places
visible: warningText . text !== ""
Rectangle {
id: statusRect
Layout.preferredHeight: warningText . height + 26
Layout.fillWidth: true
radius: 2
border.color: Qt . rgba ( 255 , 255 , 255 , 0.25 )
border.width: 1
color: "transparent"
GridLayout {
Layout.fillWidth: true
Layout.preferredHeight: warningText . height + 40
Image {
Layout.alignment: Qt . AlignVCenter
Layout.preferredHeight: 33
Layout.preferredWidth: 33
Layout.leftMargin: 10
Layout.topMargin: 10
source: "../images/warning.png"
}
Text {
id: warningText
Layout.topMargin: 12 * scaleRatio
Layout.preferredWidth: statusRect . width - 80
Layout.leftMargin: 6
2018-06-26 12:28:31 +02:00
text: qsTr ( "WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key reuse mitigations built in. Doing so will harm your privacy." ) + translationManager . emptyString
2018-03-31 14:57:00 +02:00
wrapMode: Text . Wrap
font.family: Style . fontRegular . name
font.pixelSize: 15 * scaleRatio
color: Style . defaultFontColor
textFormat: Text . RichText
onLinkActivated: {
appWindow . startDaemon ( appWindow . persistentSettings . daemonFlags ) ;
}
}
}
}
}
2017-08-07 10:48:13 +02:00
//! Manage wallet
ColumnLayout {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
2017-08-07 10:48:13 +02:00
Label {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
fontSize: 22 * scaleRatio
Layout.topMargin: 10 * scaleRatio
2017-08-07 10:48:13 +02:00
text: qsTr ( "Mnemonic seed" ) + translationManager . emptyString
}
Rectangle {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
height: 2
color: Style . dividerColor
opacity: Style . dividerOpacity
Layout.bottomMargin: 10 * scaleRatio
2017-08-07 10:48:13 +02:00
}
2018-01-28 00:14:42 +01:00
LineEditMulti {
2017-08-07 10:48:13 +02:00
id: seedText
2018-01-28 00:14:42 +01:00
spacing: 0
copyButton: true
addressValidation: false
2017-08-07 10:48:13 +02:00
readOnly: true
2018-07-18 15:00:53 +02:00
wrapMode: Text . WordWrap
fontColor: "white"
2017-08-07 10:48:13 +02:00
}
}
ColumnLayout {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
2017-08-07 10:48:13 +02:00
Label {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
fontSize: 22 * scaleRatio
Layout.topMargin: 10 * scaleRatio
2017-08-07 10:48:13 +02:00
text: qsTr ( "Keys" ) + translationManager . emptyString
}
Rectangle {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
height: 2
color: Style . dividerColor
opacity: Style . dividerOpacity
Layout.bottomMargin: 10 * scaleRatio
2017-08-07 10:48:13 +02:00
}
2018-06-19 05:58:30 +02:00
LineEdit {
Layout.fillWidth: true
id: secretViewKey
2017-08-07 10:48:13 +02:00
readOnly: true
2018-06-19 05:58:30 +02:00
copyButton: true
labelText: qsTr ( "Secret view key" ) + translationManager . emptyString
fontSize: 16 * scaleRatio
}
LineEdit {
Layout.fillWidth: true
Layout.topMargin: 25 * scaleRatio
id: publicViewKey
readOnly: true
copyButton: true
labelText: qsTr ( "Public view key" ) + translationManager . emptyString
fontSize: 16 * scaleRatio
}
LineEdit {
Layout.fillWidth: true
Layout.topMargin: 25 * scaleRatio
id: secretSpendKey
readOnly: true
copyButton: true
labelText: qsTr ( "Secret spend key" ) + translationManager . emptyString
fontSize: 16 * scaleRatio
}
LineEdit {
Layout.fillWidth: true
Layout.topMargin: 25 * scaleRatio
id: publicSpendKey
readOnly: true
copyButton: true
labelText: qsTr ( "Public spend key" ) + translationManager . emptyString
fontSize: 16 * scaleRatio
2017-08-07 10:48:13 +02:00
}
}
ColumnLayout {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
2017-08-07 10:48:13 +02:00
Label {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
fontSize: 22 * scaleRatio
Layout.topMargin: 10 * scaleRatio
2017-08-07 10:48:13 +02:00
text: qsTr ( "Export wallet" ) + translationManager . emptyString
}
Rectangle {
Layout.fillWidth: true
2018-01-28 00:14:42 +01:00
height: 2
color: Style . dividerColor
opacity: Style . dividerOpacity
Layout.bottomMargin: 10 * scaleRatio
2017-08-07 10:48:13 +02:00
}
2018-06-06 23:01:30 +02:00
ColumnLayout {
RadioButton {
2017-08-07 10:48:13 +02:00
id: showFullQr
2018-06-06 23:01:30 +02:00
enabled: ! this . checked
checked: fullWalletQRCode . visible
2017-08-07 10:48:13 +02:00
text: qsTr ( "Spendable Wallet" ) + translationManager . emptyString
onClicked: {
viewOnlyQRCode . visible = false
2018-06-06 23:01:30 +02:00
showViewOnlyQr . checked = false
2017-08-07 10:48:13 +02:00
}
}
2018-06-06 23:01:30 +02:00
RadioButton {
enabled: ! this . checked
2017-08-07 10:48:13 +02:00
id: showViewOnlyQr
2018-06-06 23:01:30 +02:00
checked: viewOnlyQRCode . visible
2017-08-07 10:48:13 +02:00
text: qsTr ( "View Only Wallet" ) + translationManager . emptyString
onClicked: {
viewOnlyQRCode . visible = true
2018-06-06 23:01:30 +02:00
showFullQr . checked = false
2017-08-07 10:48:13 +02:00
}
}
Layout.bottomMargin: 30 * scaleRatio
}
Image {
visible: ! viewOnlyQRCode . visible
id: fullWalletQRCode
Layout.fillWidth: true
Layout.minimumHeight: 180 * scaleRatio
smooth: false
fillMode: Image . PreserveAspectFit
}
Image {
visible: false
id: viewOnlyQRCode
Layout.fillWidth: true
Layout.minimumHeight: 180 * scaleRatio
smooth: false
fillMode: Image . PreserveAspectFit
}
Text {
Layout.fillWidth: true
font.bold: true
font.pixelSize: 16 * scaleRatio
2018-03-21 23:58:51 +01:00
color: Style . defaultFontColor
2017-08-07 10:48:13 +02:00
text: ( viewOnlyQRCode . visible ) ? qsTr ( "View Only Wallet" ) + translationManager.emptyString : qsTr ( "Spendable Wallet" ) + translationManager . emptyString
horizontalAlignment: Text . AlignHCenter
}
}
}
// fires on every page load
function onPageCompleted ( ) {
console . log ( "keys page loaded" ) ;
2018-06-19 05:58:30 +02:00
secretViewKey . text = currentWallet . secretViewKey
publicViewKey . text = currentWallet . publicViewKey
secretSpendKey . text = ( ! currentWallet . viewOnly ) ? currentWallet.secretSpendKey : ""
publicSpendKey . text = currentWallet . publicSpendKey
2017-08-07 10:48:13 +02:00
seedText . text = currentWallet . seed
if ( typeof currentWallet != "undefined" ) {
2018-11-29 02:17:15 +01:00
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
2017-08-07 10:48:13 +02:00
if ( currentWallet . viewOnly ) {
viewOnlyQRCode . visible = true
showFullQr . visible = false
showViewOnlyQr . visible = false
seedText . text = qsTr ( "(View Only Wallet - No mnemonic seed available)" ) + translationManager . emptyString
}
}
}
// fires only once
Component.onCompleted: {
}
}