2019-04-11 22:03:00 +00:00
// Copyright (c) 2014-2019, The Monero Project
2016-08-23 08:55:51 +00: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.
2019-04-11 01:17:29 +00:00
import QtQuick 2.9
2018-03-22 02:51:57 +00:00
import QtQuick . Controls 2.0
2016-08-17 12:14:43 +00:00
import QtQuick . Dialogs 1.2
import QtQuick . Layouts 1.1
import QtQuick . Controls . Styles 1.4
2016-11-01 12:01:24 +00:00
import QtQuick . Window 2.0
2019-04-29 08:34:58 +00:00
import FontAwesome 1.0
2016-08-16 20:21:46 +00:00
2019-04-11 01:17:29 +00:00
import "." as MoneroComponents
import "effects/" as MoneroEffects
2018-12-14 02:49:55 +00:00
import "../js/Utils.js" as Utils
2016-08-16 20:21:46 +00:00
2017-08-08 08:40:28 +00:00
Item {
2016-08-17 12:14:43 +00:00
id: root
2017-08-08 08:40:28 +00:00
visible: false
2018-04-21 19:58:00 +00:00
z: parent . z + 2
2017-08-08 08:40:28 +00:00
2018-12-07 18:00:41 +00:00
property bool isHidden: true
2019-07-01 09:44:33 +00:00
property alias password: passwordInput1 . text
2016-11-26 14:46:42 +00:00
property string walletName
2018-10-24 03:50:56 +00:00
property string errorText
2019-07-01 09:44:33 +00:00
property bool passwordDialogMode
property bool passphraseDialogMode
property bool newPasswordDialogMode
2016-11-01 12:01:24 +00:00
// same signals as Dialog has
signal accepted ( )
2019-07-01 09:44:33 +00:00
signal acceptedNewPassword ( )
signal acceptedPassphrase ( )
2016-11-01 12:01:24 +00:00
signal rejected ( )
2019-07-01 09:44:33 +00:00
signal rejectedNewPassword ( )
signal rejectedPassphrase ( )
2017-08-08 08:40:28 +00:00
signal closeCallback ( )
2016-11-01 12:01:24 +00:00
2019-07-01 09:44:33 +00:00
function _openInit ( walletName , errorText ) {
2019-04-24 12:14:36 +00:00
isHidden = true
2019-07-01 09:44:33 +00:00
capsLockTextLabel . visible = oshelper . isCapsLock ( ) ;
passwordInput1 . echoMode = TextInput . Password
passwordInput2 . echoMode = TextInput . Password
passwordInput1 . text = ""
passwordInput2 . text = ""
passwordInput1 . forceActiveFocus ( ) ;
2018-04-21 19:58:00 +00:00
inactiveOverlay . visible = true // draw appwindow inactive
2016-11-26 14:46:42 +00:00
root . walletName = walletName ? walletName : ""
2018-12-14 02:49:55 +00:00
errorTextLabel . text = errorText ? errorText : "" ;
2017-08-08 08:40:28 +00:00
leftPanel . enabled = false
middlePanel . enabled = false
2019-07-01 09:44:33 +00:00
wizard . enabled = false
2019-04-11 01:17:29 +00:00
titleBar . state = "essentials"
2017-08-08 08:40:28 +00:00
root . visible = true ;
2018-12-15 04:02:01 +00:00
appWindow . hideBalanceForced = true ;
appWindow . updateBalance ( ) ;
2016-11-01 12:01:24 +00:00
}
2019-07-01 09:44:33 +00:00
function open ( walletName , errorText ) {
passwordDialogMode = true ;
passphraseDialogMode = false ;
newPasswordDialogMode = false ;
_openInit ( walletName , errorText ) ;
}
function openPassphraseDialog ( ) {
passwordDialogMode = false ;
passphraseDialogMode = true ;
newPasswordDialogMode = false ;
_openInit ( "" , "" ) ;
}
function openNewPasswordDialog ( ) {
passwordDialogMode = false ;
passphraseDialogMode = false ;
newPasswordDialogMode = true ;
_openInit ( "" , "" ) ;
}
2018-10-24 03:50:56 +00:00
function showError ( errorText ) {
open ( root . walletName , errorText ) ;
}
2017-08-08 08:40:28 +00:00
function close ( ) {
2018-04-21 19:58:00 +00:00
inactiveOverlay . visible = false
2017-08-08 08:40:28 +00:00
leftPanel . enabled = true
middlePanel . enabled = true
2019-07-01 09:44:33 +00:00
wizard . enabled = true
2019-04-11 01:17:29 +00:00
titleBar . state = "default"
2017-08-08 08:40:28 +00:00
root . visible = false ;
2018-12-15 04:02:01 +00:00
appWindow . hideBalanceForced = false ;
appWindow . updateBalance ( ) ;
2017-08-08 08:40:28 +00:00
closeCallback ( ) ;
2017-05-03 09:08:59 +00:00
}
2019-07-01 09:44:33 +00:00
function toggleIsHidden ( ) {
passwordInput1 . echoMode = isHidden ? TextInput.Normal : TextInput . Password ;
passwordInput2 . echoMode = isHidden ? TextInput.Normal : TextInput . Password ;
isHidden = ! isHidden ;
}
2016-08-17 12:14:43 +00:00
ColumnLayout {
2018-04-28 16:50:07 +00:00
z: inactiveOverlay . z + 1
2016-11-01 12:01:24 +00:00
id: mainLayout
spacing: 10
2019-04-25 19:09:23 +00:00
anchors { fill: parent ; margins: 35 }
2016-11-01 12:01:24 +00:00
ColumnLayout {
id: column
2018-03-23 20:51:28 +00:00
2018-03-22 02:51:57 +00:00
Layout.fillWidth: true
2016-11-01 12:01:24 +00:00
Layout.alignment: Qt . AlignHCenter
2019-04-25 19:09:23 +00:00
Layout.maximumWidth: 400
2016-11-01 12:01:24 +00:00
Label {
2019-07-01 09:44:33 +00:00
text: {
2019-07-16 12:08:22 +00:00
if ( newPasswordDialogMode ) {
return qsTr ( "Please enter new wallet password" ) + translationManager . emptyString ;
} else {
var device = passwordDialogMode ? qsTr ( "wallet password" ) : qsTr ( "wallet device passphrase" ) ;
return ( root . walletName . length > 0 ? qsTr ( "Please enter %1 for: " ) . arg ( device ) + root.walletName : qsTr ( "Please enter %1" ) . arg ( device ) ) + translationManager . emptyString ;
}
2019-07-01 09:44:33 +00:00
}
2016-11-01 12:01:24 +00:00
Layout.fillWidth: true
2018-03-22 02:51:57 +00:00
2019-04-25 19:09:23 +00:00
font.pixelSize: 16
2018-03-31 01:25:20 +00:00
font.family: MoneroComponents . Style . fontLight . name
2018-03-22 02:51:57 +00:00
2018-03-31 01:25:20 +00:00
color: MoneroComponents . Style . defaultFontColor
2016-11-01 12:01:24 +00:00
}
2019-07-01 09:44:33 +00:00
Label {
text: qsTr ( "Warning: passphrase entry on host is a security risk as it can be captured by malware. It is advised to prefer device-based passphrase entry." ) + translationManager . emptyString
visible: passphraseDialogMode
Layout.fillWidth: true
wrapMode: Text . Wrap
font.pixelSize: 14
font.family: MoneroComponents . Style . fontLight . name
color: MoneroComponents . Style . warningColor
}
2018-10-24 03:50:56 +00:00
Label {
2018-12-14 02:49:55 +00:00
id: errorTextLabel
visible: root . errorText || text !== ""
2019-07-01 09:44:33 +00:00
color: MoneroComponents . Style . errorColor
font.pixelSize: 16
font.family: MoneroComponents . Style . fontLight . name
Layout.fillWidth: true
wrapMode: Text . Wrap
}
2018-10-24 03:50:56 +00:00
2019-07-01 09:44:33 +00:00
Label {
id: capsLockTextLabel
visible: false
2018-10-24 03:50:56 +00:00
color: MoneroComponents . Style . errorColor
2019-04-25 19:09:23 +00:00
font.pixelSize: 16
2019-07-01 09:44:33 +00:00
font.family: MoneroComponents . Style . fontLight . name
2018-10-24 03:50:56 +00:00
Layout.fillWidth: true
wrapMode: Text . Wrap
2019-07-01 09:44:33 +00:00
text: qsTr ( "CAPSLOCKS IS ON." ) + translationManager . emptyString ;
2018-10-24 03:50:56 +00:00
}
2019-11-08 00:56:10 +00:00
MoneroComponents . Input {
2019-07-01 09:44:33 +00:00
id: passwordInput1
2018-03-22 04:06:11 +00:00
Layout.topMargin: 6
2016-11-01 12:01:24 +00:00
Layout.fillWidth: true
2018-03-22 02:51:57 +00:00
horizontalAlignment: TextInput . AlignLeft
2016-11-01 12:01:24 +00:00
verticalAlignment: TextInput . AlignVCenter
2018-03-31 01:25:20 +00:00
font.family: MoneroComponents . Style . fontLight . name
2019-04-25 19:09:23 +00:00
font.pixelSize: 24
2016-11-01 12:01:24 +00:00
echoMode: TextInput . Password
2019-07-01 09:44:33 +00:00
KeyNavigation.tab: {
if ( passwordDialogMode ) {
return okButton
} else {
return passwordInput2
}
}
2019-11-26 16:08:31 +00:00
implicitHeight: 50
2018-03-22 02:51:57 +00:00
bottomPadding: 10
leftPadding: 10
topPadding: 10
2018-03-31 01:25:20 +00:00
color: MoneroComponents . Style . defaultFontColor
2019-04-11 01:17:29 +00:00
selectionColor: MoneroComponents . Style . textSelectionColor
selectedTextColor: MoneroComponents . Style . textSelectedColor
2019-07-01 09:44:33 +00:00
onTextChanged: capsLockTextLabel . visible = oshelper . isCapsLock ( ) ;
2018-12-14 02:49:55 +00:00
2018-03-22 02:51:57 +00:00
background: Rectangle {
radius: 2
2019-04-11 01:17:29 +00:00
color: MoneroComponents . Style . blackTheme ? "black" : "#A9FFFFFF"
border.color: MoneroComponents . Style . inputBorderColorInActive
2018-03-22 02:51:57 +00:00
border.width: 1
2019-04-11 01:17:29 +00:00
MoneroEffects . ColorTransition {
targetObj: parent
blackColor: "black"
whiteColor: "#A9FFFFFF"
}
2018-03-22 02:51:57 +00:00
2019-04-29 08:34:58 +00:00
MoneroComponents . Label {
fontSize: 20
text: isHidden ? FontAwesome.eye : FontAwesome . eyeSlash
2018-12-07 18:00:41 +00:00
opacity: 0.7
2019-04-29 08:34:58 +00:00
fontFamily: FontAwesome . fontFamily
2018-03-22 02:51:57 +00:00
anchors.right: parent . right
2019-04-29 08:34:58 +00:00
anchors.rightMargin: 15
anchors.verticalCenter: parent . verticalCenter
anchors.verticalCenterOffset: 1
2019-04-11 01:17:29 +00:00
2018-12-07 18:00:41 +00:00
MouseArea {
anchors.fill: parent
cursorShape: Qt . PointingHandCursor
hoverEnabled: true
onClicked: {
2019-07-01 09:44:33 +00:00
toggleIsHidden ( ) ;
2018-12-07 18:00:41 +00:00
}
onEntered: {
parent . opacity = 0.9
2019-04-29 08:34:58 +00:00
parent . fontSize = 24
2018-12-07 18:00:41 +00:00
}
onExited: {
parent . opacity = 0.7
2019-04-29 08:34:58 +00:00
parent . fontSize = 20
2018-12-07 18:00:41 +00:00
}
}
2016-11-01 12:01:24 +00:00
}
}
2018-03-22 02:51:57 +00:00
2018-07-28 09:00:41 +00:00
Keys.enabled: root . visible
2019-12-10 01:48:03 +00:00
Keys.onEnterPressed: Keys . onReturnPressed ( event )
2016-11-02 13:26:07 +00:00
Keys.onReturnPressed: {
root . close ( )
2019-07-01 09:44:33 +00:00
if ( passwordDialogMode ) {
root . accepted ( )
} else if ( newPasswordDialogMode ) {
root . acceptedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . acceptedPassphrase ( )
}
2016-11-02 13:26:07 +00:00
}
Keys.onEscapePressed: {
root . close ( )
2019-07-01 09:44:33 +00:00
if ( passwordDialogMode ) {
root . rejected ( )
} else if ( newPasswordDialogMode ) {
root . rejectedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . rejectedPassphrase ( )
2018-12-14 02:49:55 +00:00
}
2019-07-01 09:44:33 +00:00
}
}
// padding
Rectangle {
visible: ! passwordDialogMode
Layout.fillWidth: true
Layout.alignment: Qt . AlignHCenter
height: 10
opacity: 0
color: "black"
}
Label {
visible: ! passwordDialogMode
2019-07-16 12:08:22 +00:00
text: newPasswordDialogMode ? qsTr ( "Please confirm new password" ) : qsTr ( "Please confirm wallet device passphrase" ) + translationManager . emptyString
2019-07-01 09:44:33 +00:00
Layout.fillWidth: true
font.pixelSize: 16
font.family: MoneroComponents . Style . fontLight . name
color: MoneroComponents . Style . defaultFontColor
}
2019-11-08 00:56:10 +00:00
MoneroComponents . Input {
2019-07-01 09:44:33 +00:00
id: passwordInput2
visible: ! passwordDialogMode
Layout.topMargin: 6
Layout.fillWidth: true
horizontalAlignment: TextInput . AlignLeft
verticalAlignment: TextInput . AlignVCenter
font.family: MoneroComponents . Style . fontLight . name
font.pixelSize: 24
echoMode: TextInput . Password
KeyNavigation.tab: okButton
2019-11-26 16:08:31 +00:00
implicitHeight: 50
2019-07-01 09:44:33 +00:00
bottomPadding: 10
leftPadding: 10
topPadding: 10
color: MoneroComponents . Style . defaultFontColor
selectionColor: MoneroComponents . Style . textSelectionColor
selectedTextColor: MoneroComponents . Style . textSelectedColor
onTextChanged: capsLockTextLabel . visible = oshelper . isCapsLock ( ) ;
background: Rectangle {
radius: 2
border.color: MoneroComponents . Style . inputBorderColorInActive
border.width: 1
color: MoneroComponents . Style . blackTheme ? "black" : "#A9FFFFFF"
MoneroComponents . Label {
fontSize: 20
text: isHidden ? FontAwesome.eye : FontAwesome . eyeSlash
opacity: 0.7
fontFamily: FontAwesome . fontFamily
anchors.right: parent . right
anchors.rightMargin: 15
anchors.verticalCenter: parent . verticalCenter
anchors.verticalCenterOffset: 1
MouseArea {
anchors.fill: parent
cursorShape: Qt . PointingHandCursor
hoverEnabled: true
onClicked: {
toggleIsHidden ( )
}
onEntered: {
parent . opacity = 0.9
parent . fontSize = 24
}
onExited: {
parent . opacity = 0.7
parent . fontSize = 20
}
}
2018-12-14 02:49:55 +00:00
}
}
2019-07-01 09:44:33 +00:00
2019-12-10 01:48:03 +00:00
Keys.enabled: root . visible
Keys.onEnterPressed: Keys . onReturnPressed ( event )
2019-07-01 09:44:33 +00:00
Keys.onReturnPressed: {
if ( passwordInput1 . text === passwordInput2 . text ) {
root . close ( )
if ( newPasswordDialogMode ) {
root . acceptedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . acceptedPassphrase ( )
}
2018-12-14 02:49:55 +00:00
}
2019-07-01 09:44:33 +00:00
}
Keys.onEscapePressed: {
root . close ( )
if ( newPasswordDialogMode ) {
root . rejectedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . rejectedPassphrase ( )
2018-12-14 02:49:55 +00:00
}
2016-11-02 13:26:07 +00:00
}
2016-11-01 12:01:24 +00:00
}
2019-07-01 09:44:33 +00:00
// padding
Rectangle {
visible: ! passwordDialogMode
Layout.fillWidth: true
Layout.alignment: Qt . AlignHCenter
height: 10
opacity: 0
color: "black"
}
2018-03-22 02:51:57 +00:00
// Ok/Cancel buttons
RowLayout {
id: buttons
2019-04-25 19:09:23 +00:00
spacing: 16
2018-03-22 02:51:57 +00:00
Layout.topMargin: 16
Layout.alignment: Qt . AlignRight
MoneroComponents . StandardButton {
id: cancelButton
small: true
2019-07-18 15:02:53 +00:00
text: qsTr ( "Cancel" ) + translationManager . emptyString
2019-07-01 09:44:33 +00:00
KeyNavigation.tab: passwordInput1
2018-03-22 02:51:57 +00:00
onClicked: {
root . close ( )
2019-07-01 09:44:33 +00:00
if ( passwordDialogMode ) {
root . rejected ( )
} else if ( newPasswordDialogMode ) {
root . rejectedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . rejectedPassphrase ( )
}
2018-03-22 02:51:57 +00:00
}
2016-11-01 12:01:24 +00:00
}
2018-03-22 02:51:57 +00:00
MoneroComponents . StandardButton {
id: okButton
small: true
2019-07-18 15:02:53 +00:00
text: qsTr ( "Ok" ) + translationManager . emptyString
2018-03-22 02:51:57 +00:00
KeyNavigation.tab: cancelButton
2019-07-01 09:44:33 +00:00
enabled: ( passwordDialogMode == true ) ? true : passwordInput1 . text === passwordInput2 . text
2018-03-22 02:51:57 +00:00
onClicked: {
root . close ( )
2019-07-01 09:44:33 +00:00
if ( passwordDialogMode ) {
root . accepted ( )
} else if ( newPasswordDialogMode ) {
root . acceptedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . acceptedPassphrase ( )
}
2018-03-22 02:51:57 +00:00
}
2016-11-01 12:01:24 +00:00
}
2016-08-17 12:14:43 +00:00
}
}
}
2016-08-16 20:21:46 +00:00
}