status-desktop/ui/app/AppLayouts/Wallet/panels/SetCurrencyModalContent.qml

88 lines
2.6 KiB
QML
Raw Normal View History

2020-06-17 15:18:31 -04:00
import QtQuick 2.13
import QtQuick.Controls 2.13
import utils 1.0
import shared 1.0
import shared.panels 1.0
import StatusQ.Controls 0.1 as StatusQControls
Item {
2020-07-22 16:40:32 -04:00
id: modalBody
property string currency: "USD"
property alias tokenListModel: tokenListView.model
2020-07-22 16:40:32 -04:00
anchors.fill: parent
ButtonGroup {
id: currencyGroup
}
2020-07-22 16:40:32 -04:00
ListView {
id: tokenListView
2020-07-22 16:40:32 -04:00
anchors.top: parent.top
anchors.left: parent.left
2020-07-22 16:40:32 -04:00
anchors.right: parent.right
anchors.bottom: parent.bottom
2020-07-22 16:40:32 -04:00
clip: true
spacing: 10
ScrollBar.vertical: ScrollBar {
active: true
policy: tokenListView.contentHeight > tokenListView.height ? ScrollBar.AlwaysOn : ScrollBar.AlwaysOff
}
boundsBehavior: Flickable.StopAtBounds
2020-07-22 16:40:32 -04:00
delegate: Component {
Rectangle {
id: wrapper
property bool hovered: false
radius: Style.current.radius
color: modalBody.currency === key ? Style.current.secondaryBackground : (hovered ? Style.current.backgroundHover: Style.current.transparent)
2020-07-22 16:40:32 -04:00
anchors.right: parent.right
anchors.rightMargin: 0
anchors.left: parent.left
anchors.leftMargin: 10
width: parent.width
height: 52
StyledText {
text: name + " (" + code + ")"
font.pixelSize: 15
anchors.verticalCenter: parent.verticalCenter
anchors.left: parent.left
anchors.leftMargin: Style.current.padding
2020-07-22 16:40:32 -04:00
}
StatusQControls.StatusRadioButton {
id: currencyRadioBtn
2020-07-22 16:40:32 -04:00
checked: currency === key
anchors.right: parent.right
anchors.rightMargin: Style.current.padding
anchors.verticalCenter: parent.verticalCenter
2020-07-22 16:40:32 -04:00
ButtonGroup.group: currencyGroup
}
MouseArea {
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
hoverEnabled: true
onEntered: {
wrapper.hovered = true
}
onExited: {
wrapper.hovered = false
}
onClicked: {
currencyRadioBtn.checked = !currencyRadioBtn.checked
modalBody.currency = key
}
}
}
}
}
}