96 lines
2.6 KiB
QML
96 lines
2.6 KiB
QML
import QtQuick 2.13
|
|
import QtQuick.Controls 2.13
|
|
import QtQuick.Layouts 1.13
|
|
import StatusQ.Controls 0.1
|
|
|
|
import utils 1.0
|
|
import shared.panels 1.0
|
|
import shared.controls 1.0
|
|
|
|
// TODO: use StatusQ components
|
|
Rectangle {
|
|
property var buttonGroup
|
|
property string text: qsTr("Low")
|
|
property string gasLimit
|
|
property double price: 1
|
|
property string defaultCurrency: "USD"
|
|
property bool hovered: false
|
|
property bool checkedByDefault: false
|
|
property var getGasEthValue: function () {}
|
|
property var getFiatValue: function () {}
|
|
|
|
property alias gasRadioBtn: gasRadioBtn
|
|
|
|
function formatDec(num, dec){
|
|
return Math.round((num + Number.EPSILON) * Math.pow(10, dec)) / Math.pow(10, dec)
|
|
}
|
|
|
|
property double ethValue: {
|
|
if (!gasLimit) {
|
|
return 0
|
|
}
|
|
return formatDec(parseFloat(getGasEthValue(gasRectangle.price, gasLimit)), 6)
|
|
}
|
|
property double fiatValue: getFiatValue(ethValue, "ETH", defaultCurrency)
|
|
signal checked()
|
|
|
|
id: gasRectangle
|
|
border.color: hovered || gasRadioBtn.checked ? Style.current.primary : Style.current.border
|
|
border.width: 1
|
|
color: Style.current.transparent
|
|
width: 130
|
|
height: 120
|
|
clip: true
|
|
radius: Style.current.radius
|
|
|
|
StatusRadioButton {
|
|
id: gasRadioBtn
|
|
ButtonGroup.group: buttonGroup
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
anchors.top: parent.top
|
|
anchors.topMargin: 14
|
|
checked: gasRectangle.checkedByDefault
|
|
onCheckedChanged: {
|
|
if (checked) {
|
|
gasRectangle.checked()
|
|
}
|
|
}
|
|
}
|
|
|
|
StyledText {
|
|
id: gasText
|
|
text: gasRectangle.text
|
|
font.pixelSize: 15
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
anchors.top: gasRadioBtn.bottom
|
|
anchors.topMargin: 6
|
|
}
|
|
|
|
StyledText {
|
|
id: ethText
|
|
text: gasRectangle.ethValue + " ETH"
|
|
font.pixelSize: 13
|
|
color: Style.current.secondaryText
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
anchors.top: gasText.bottom
|
|
anchors.topMargin: 4
|
|
}
|
|
|
|
StyledText {
|
|
id: fiatText
|
|
text: `${gasRectangle.fiatValue} ${gasRectangle.defaultCurrency}`
|
|
font.pixelSize: 13
|
|
color: Style.current.secondaryText
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
anchors.top: ethText.bottom
|
|
}
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
hoverEnabled: true
|
|
onEntered: gasRectangle.hovered = true
|
|
onExited: gasRectangle.hovered = false
|
|
onClicked: gasRadioBtn.toggle()
|
|
}
|
|
}
|