87 lines
2.3 KiB
QML
87 lines
2.3 KiB
QML
|
import QtQuick 2.13
|
||
|
import QtQuick.Controls 2.13
|
||
|
import QtQuick.Layouts 1.13
|
||
|
import "../imports"
|
||
|
import "./status"
|
||
|
import "./"
|
||
|
|
||
|
|
||
|
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 double ethValue: {
|
||
|
if (!gasLimit) {
|
||
|
return 0
|
||
|
}
|
||
|
return getGasEthValue(price, gasLimit)
|
||
|
}
|
||
|
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()
|
||
|
}
|
||
|
}
|