mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-09 13:56:10 +00:00
53ee992c25
Fixes #9019
271 lines
6.8 KiB
QML
271 lines
6.8 KiB
QML
import QtQuick 2.13
|
|
|
|
import utils 1.0
|
|
import shared 1.0
|
|
import shared.panels 1.0
|
|
import shared.popups 1.0
|
|
import "../stores"
|
|
|
|
// TODO: replace with StatusModal
|
|
ModalPopup {
|
|
id: popup
|
|
|
|
property var transaction
|
|
title: qsTr("Transaction Details")
|
|
|
|
readonly property bool isTransactionValid: transaction !== undefined
|
|
|
|
Item {
|
|
id: confirmations
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
anchors.top: parent.top
|
|
anchors.topMargin: Style.current.smallPadding
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: Style.current.smallPadding
|
|
height: children[0].height + children[1].height + Style.current.smallPadding
|
|
|
|
StyledText {
|
|
id: confirmationsCount
|
|
text: {
|
|
if(popup.isTransactionValid)
|
|
return RootStore.getLatestBlockNumber() - RootStore.hex2Dec(transaction.blockNumber) + qsTr(" confirmation(s)")
|
|
else
|
|
return ""
|
|
}
|
|
font.pixelSize: 14
|
|
}
|
|
|
|
StyledText {
|
|
id: confirmationsInfo
|
|
text: qsTr("When the transaction has 12 confirmations you can consider it settled.")
|
|
wrapMode: Text.WordWrap
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
anchors.top: confirmationsCount.bottom
|
|
anchors.topMargin: Style.current.smallPadding
|
|
width: parent.width
|
|
}
|
|
}
|
|
|
|
Separator {
|
|
id: separator
|
|
anchors.top: confirmations.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: -Style.current.padding
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: -Style.current.padding
|
|
}
|
|
|
|
Item {
|
|
id: block
|
|
anchors.top: separator.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelBlock
|
|
text: qsTr("Block")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
StyledText {
|
|
id: valueBlock
|
|
text: popup.isTransactionValid ? RootStore.hex2Dec(transaction.blockNumber) : ""
|
|
font.pixelSize: 14
|
|
anchors.left: labelBlock.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: hash
|
|
anchors.top: block.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelHash
|
|
text: qsTr("Hash")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
Address {
|
|
id: valueHash
|
|
text: popup.isTransactionValid ? transaction.id : ""
|
|
width: 160
|
|
maxWidth: parent.width - labelHash.width - Style.current.padding
|
|
color: Style.current.textColor
|
|
font.pixelSize: 14
|
|
anchors.left: labelHash.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: from
|
|
anchors.top: hash.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelFrom
|
|
text: qsTr("From")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
Address {
|
|
id: valueFrom
|
|
text: popup.isTransactionValid ? transaction.from: ""
|
|
color: Style.current.textColor
|
|
width: 160
|
|
font.pixelSize: 14
|
|
anchors.left: labelFrom.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: toItem
|
|
anchors.top: from.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelTo
|
|
text: qsTr("To")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
Address {
|
|
id: valueTo
|
|
text: popup.isTransactionValid ? transaction.to: ""
|
|
color: Style.current.textColor
|
|
width: 160
|
|
font.pixelSize: 14
|
|
anchors.left: labelTo.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: gasLimitItem
|
|
anchors.top: toItem.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelGasLimit
|
|
text: qsTr("Gas limit")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
StyledText {
|
|
id: valueGasLimit
|
|
text: popup.isTransactionValid ? LocaleUtils.currencyAmountToLocaleString(transaction.gasLimit): ""
|
|
font.pixelSize: 14
|
|
anchors.left: labelGasLimit.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: gasPriceItem
|
|
anchors.top: gasLimitItem.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelGasPrice
|
|
text: qsTr("Gas price")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
StyledText {
|
|
id: valueGasPrice
|
|
text: popup.isTransactionValid ? LocaleUtils.currencyAmountToLocaleString(transaction.gasPrice): ""
|
|
font.pixelSize: 14
|
|
anchors.left: labelGasPrice.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: gasUsedItem
|
|
anchors.top: gasPriceItem.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelGasUsed
|
|
text: qsTr("Gas used")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
StyledText {
|
|
id: valueGasUsed
|
|
text: popup.isTransactionValid ? LocaleUtils.currencyAmountToLocaleString(transaction.gasUsed): ""
|
|
font.pixelSize: 14
|
|
anchors.left: labelGasUsed.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
|
|
Item {
|
|
id: nonceItem
|
|
anchors.top: gasUsedItem.bottom
|
|
anchors.topMargin: Style.current.padding
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
height: children[0].height
|
|
|
|
StyledText {
|
|
id: labelNonce
|
|
text: qsTr("Nonce")
|
|
font.pixelSize: 14
|
|
font.weight: Font.Medium
|
|
color: Style.current.secondaryText
|
|
}
|
|
|
|
StyledText {
|
|
id: valueNonce
|
|
text: popup.isTransactionValid ? RootStore.hex2Dec(transaction.nonce) : ""
|
|
font.pixelSize: 14
|
|
anchors.left: labelNonce.right
|
|
anchors.leftMargin: Style.current.padding
|
|
}
|
|
}
|
|
}
|