fix: update design for signing messages in browser

This commit is contained in:
Richard Ramos 2020-11-24 16:19:20 -04:00 committed by Iuri Matias
parent 37aabf57b3
commit b996d860d1
2 changed files with 166 additions and 32 deletions

View File

@ -200,7 +200,13 @@ Rectangle {
sendDialog.open(); sendDialog.open();
walletModel.getGasPricePredictions() walletModel.getGasPricePredictions()
} else if (request.type === Constants.web3SendAsyncReadOnly && ["eth_sign", "personal_sign", "eth_signTypedData", "eth_signTypedData_v3"].indexOf(request.payload.method) > -1) { } else if (request.type === Constants.web3SendAsyncReadOnly && ["eth_sign", "personal_sign", "eth_signTypedData", "eth_signTypedData_v3"].indexOf(request.payload.method) > -1) {
const signDialog = signMessageModalComponent.createObject(browserWindow, {request}); const signDialog = signMessageModalComponent.createObject(browserWindow, {
request,
selectedAccount: {
name: walletModel.currentAccount.name,
iconColor: walletModel.currentAccount.iconColor
}
});
signDialog.web3Response = web3Response signDialog.web3Response = web3Response
signDialog.signMessage = function (enteredPassword) { signDialog.signMessage = function (enteredPassword) {
signDialog.interactedWith = true; signDialog.interactedWith = true;

View File

@ -2,16 +2,19 @@ import QtQuick 2.13
import QtQuick.Controls 2.13 import QtQuick.Controls 2.13
import QtQuick.Layouts 1.13 import QtQuick.Layouts 1.13
import QtQuick.Dialogs 1.3 import QtQuick.Dialogs 1.3
import QtGraphicalEffects 1.13
import "../../../imports" import "../../../imports"
import "../../../shared" import "../../../shared"
import "../../../shared/status" import "../../../shared/status"
ModalPopup { ModalPopup {
property var request property var request
property var selectedAccount
readonly property int bytes32Length: 66 readonly property int bytes32Length: 66
property bool interactedWith: false property bool interactedWith: false
property bool showSigningPhrase: false
property alias transactionSigner: transactionSigner property alias transactionSigner: transactionSigner
@ -19,9 +22,10 @@ ModalPopup {
property var web3Response property var web3Response
id: root id: root
title: qsTr("Signing a message") title: qsTr("Signature request")
height: 504 height: 504
onClosed: { onClosed: {
@ -36,6 +40,10 @@ ModalPopup {
} }
} }
onOpened: {
showSigningPhrase = false;
}
function displayValue(input){ function displayValue(input){
if(Utils.isHex(input) && Utils.startsWith0x(input)){ if(Utils.isHex(input) && Utils.startsWith0x(input)){
if (input.length === bytes32Length){ if (input.length === bytes32Length){
@ -46,40 +54,142 @@ ModalPopup {
return input; return input;
} }
Item { function messageToSign(){
anchors.fill: parent switch(request.payload.method){
anchors.leftMargin: Style.current.padding case Constants.personal_sign:
anchors.rightMargin: Style.current.padding return displayValue(request.payload.params[0]);
case Constants.eth_sign:
return displayValue(request.payload.params[1]);
case Constants.eth_signTypedData:
case Constants.eth_signTypedData_v3:
return JSON.stringify(request.payload.params[1]); // TODO: requires design
default:
return JSON.stringify(request.payload.params); // support for any unhandled sign method
}
}
ScrollView { TransactionSigner {
id: messageToSign id: transactionSigner
width: parent.width width: parent.width
height: 100 signingPhrase: walletModel.signingPhrase
TextArea { visible: showSigningPhrase
wrapMode: TextEdit.Wrap reset: function() {
readOnly: true signingPhrase = Qt.binding(function() { return walletModel.signingPhrase })
text: { }
switch(request.payload.method){ }
case Constants.personal_sign:
return displayValue(request.payload.params[0]); Column {
case Constants.eth_sign: id: content
return displayValue(request.payload.params[1]); anchors.left: parent.left
case Constants.eth_signTypedData: anchors.right: parent.right
case Constants.eth_signTypedData_v3: visible: !showSigningPhrase
return JSON.stringify(request.payload.params[1]); // TODO: requires design
default: LabelValueRow {
return JSON.stringify(request.payload.params); // support for any unhandled sign method //% "From"
label: qsTrId("from")
value: Item {
id: itmFromValue
anchors.fill: parent
anchors.verticalCenter: parent.verticalCenter
Row {
spacing: Style.current.halfPadding
rightPadding: 0
anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter
StyledText {
font.pixelSize: 15
height: 22
text: selectedAccount.name
elide: Text.ElideRight
anchors.verticalCenter: parent.verticalCenter
horizontalAlignment: Text.AlignRight
verticalAlignment: Text.AlignVCenter
}
SVGImage {
id: imgFromWallet
sourceSize.height: 18
sourceSize.width: 18
visible: true
horizontalAlignment: Image.AlignLeft
width: undefined
anchors.verticalCenter: parent.verticalCenter
fillMode: Image.PreserveAspectFit
source: "../../img/walletIcon.svg"
ColorOverlay {
visible: parent.visible
anchors.fill: parent
source: parent
color: selectedAccount.iconColor
}
} }
} }
} }
} }
TransactionSigner { LabelValueRow {
id: transactionSigner label: qsTr("Data")
width: parent.width value: Item {
anchors.top: messageToSign.bottom anchors.fill: parent
anchors.topMargin: Style.current.padding * 3 anchors.verticalCenter: parent.verticalCenter
signingPhrase: walletModel.signingPhrase
ModalPopup {
id: messagePopup
title: qsTr("Message")
height: 286
width: 400
Item {
anchors.fill: parent
anchors.leftMargin: Style.current.padding
anchors.rightMargin: Style.current.padding
ScrollView {
width: parent.width
height: 150
TextArea {
wrapMode: TextEdit.Wrap
readOnly: true
text: messageToSign()
}
}
}
}
Row {
spacing: Style.current.halfPadding
rightPadding: 0
anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter
StyledText {
width: 250
font.pixelSize: 15
height: 22
text: messageToSign()
anchors.verticalCenter: parent.verticalCenter
horizontalAlignment: Text.AlignRight
verticalAlignment: Text.AlignVCenter
elide: Text.ElideRight
color: Style.current.secondaryText
}
SVGImage {
width: 13
anchors.verticalCenter: parent.verticalCenter
fillMode: Image.PreserveAspectFit
source: "../../img/caret.svg"
rotation: 270
ColorOverlay {
anchors.fill: parent
source: parent
color: Style.current.secondaryText
}
}
}
MouseArea {
anchors.fill: parent
visible: true
cursorShape: Qt.PointingHandCursor
onClicked: messagePopup.open()
}
}
} }
} }
@ -88,11 +198,29 @@ ModalPopup {
anchors.top: parent.top anchors.top: parent.top
anchors.left: parent.left anchors.left: parent.left
anchors.right: parent.right anchors.right: parent.right
StatusButton {
id: btnReject
anchors.right:btnNext.left
anchors.rightMargin: Style.current.padding
text: qsTr("Reject")
color: Style.current.danger
type: "secondary"
onClicked: close()
}
StatusButton { StatusButton {
id: btnNext id: btnNext
anchors.right: parent.right anchors.right: parent.right
text: qsTr("Sign") text: showSigningPhrase ? qsTr("Sign") : qsTr("Sign with password")
onClicked: root.signMessage(transactionSigner.enteredPassword) onClicked: {
if(!showSigningPhrase){
showSigningPhrase = true;
transactionSigner.forceActiveFocus(Qt.MouseFocusReason)
} else {
root.signMessage(transactionSigner.enteredPassword)
}
}
} }
} }
} }