2024-01-27 19:12:09 +00:00
// Copyright (c) 2014-2024, 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
2019-07-01 09:44:33 +00:00
property alias password: passwordInput1 . text
2016-11-26 14:46:42 +00:00
property string walletName
2020-09-24 14:08:33 +00:00
property var okButtonText
property string okButtonIcon
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 ) {
capsLockTextLabel . visible = oshelper . isCapsLock ( ) ;
2020-04-28 12:15:18 +00:00
passwordInput1 . reset ( ) ;
passwordInput2 . reset ( ) ;
2020-07-14 14:52:40 +00:00
if ( ! appWindow . currentWallet || appWindow . active )
2020-07-07 13:33:54 +00:00
passwordInput1 . input . forceActiveFocus ( ) ;
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
}
2020-09-24 14:08:33 +00:00
function open ( walletName , errorText , okButtonText , okButtonIcon ) {
2019-07-01 09:44:33 +00:00
passwordDialogMode = true ;
passphraseDialogMode = false ;
newPasswordDialogMode = false ;
2020-09-24 14:08:33 +00:00
root . okButtonText = okButtonText ;
root . okButtonIcon = okButtonIcon ? okButtonIcon : "" ;
2019-07-01 09:44:33 +00:00
_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 ( ) {
leftPanel . enabled = true
middlePanel . enabled = true
2019-07-01 09:44:33 +00:00
wizard . enabled = true
2021-11-28 12:39:45 +00:00
if ( rootItem . state == "wizard" ) {
titleBar . state = "essentials"
} else {
titleBar . state = "default"
}
2019-04-11 01:17:29 +00:00
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
}
2020-04-28 12:15:18 +00:00
function onOk ( ) {
if ( ! passwordDialogMode && passwordInput1 . text !== passwordInput2 . text ) {
return ;
}
root . close ( )
if ( passwordDialogMode ) {
root . accepted ( )
} else if ( newPasswordDialogMode ) {
root . acceptedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . acceptedPassphrase ( )
}
}
function onCancel ( ) {
root . close ( )
if ( passwordDialogMode ) {
root . rejected ( )
} else if ( newPasswordDialogMode ) {
root . rejectedNewPassword ( )
} else if ( passphraseDialogMode ) {
root . rejectedPassphrase ( )
}
2019-07-01 09:44:33 +00:00
}
2016-08-17 12:14:43 +00:00
ColumnLayout {
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
}
2020-04-28 12:15:18 +00:00
MoneroComponents . LineEdit {
2019-07-01 09:44:33 +00:00
id: passwordInput1
2020-04-28 12:15:18 +00:00
password: true
2018-03-22 04:06:11 +00:00
Layout.topMargin: 6
2016-11-01 12:01:24 +00:00
Layout.fillWidth: true
2019-07-01 09:44:33 +00:00
KeyNavigation.tab: {
if ( passwordDialogMode ) {
return okButton
} else {
return passwordInput2
}
}
onTextChanged: capsLockTextLabel . visible = oshelper . isCapsLock ( ) ;
2018-12-14 02:49:55 +00:00
2018-07-28 09:00:41 +00:00
Keys.enabled: root . visible
2020-04-28 12:15:18 +00:00
Keys.onEnterPressed: root . onOk ( )
Keys.onReturnPressed: root . onOk ( )
Keys.onEscapePressed: root . onCancel ( )
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
}
2020-04-28 12:15:18 +00:00
MoneroComponents . LineEdit {
2019-07-01 09:44:33 +00:00
id: passwordInput2
2020-04-28 12:15:18 +00:00
passwordLinked: passwordInput1
2019-07-01 09:44:33 +00:00
visible: ! passwordDialogMode
Layout.topMargin: 6
Layout.fillWidth: true
KeyNavigation.tab: okButton
onTextChanged: capsLockTextLabel . visible = oshelper . isCapsLock ( ) ;
2019-12-10 01:48:03 +00:00
Keys.enabled: root . visible
2020-04-28 12:15:18 +00:00
Keys.onEnterPressed: root . onOk ( )
Keys.onReturnPressed: root . onOk ( )
Keys.onEscapePressed: root . onCancel ( )
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
2020-09-24 14:08:33 +00:00
primary: false
2018-03-22 02:51:57 +00:00
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
2020-04-28 12:15:18 +00:00
onClicked: onCancel ( )
2016-11-01 12:01:24 +00:00
}
2018-03-22 02:51:57 +00:00
MoneroComponents . StandardButton {
id: okButton
2020-09-24 14:08:33 +00:00
fontAwesomeIcon: true
rightIcon: okButtonIcon
2018-03-22 02:51:57 +00:00
small: true
2020-09-24 14:08:33 +00:00
text: okButtonText ? okButtonText : 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
2020-04-28 12:15:18 +00:00
onClicked: onOk ( )
2016-11-01 12:01:24 +00:00
}
2016-08-17 12:14:43 +00:00
}
}
}
2016-08-16 20:21:46 +00:00
}