mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-22 12:29:37 +00:00
fix: update design for signing messages in browser
This commit is contained in:
parent
37aabf57b3
commit
b996d860d1
@ -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;
|
||||||
|
@ -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)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user