import QtQuick 2.13 import "./components" import "./data" import "../../../imports" import "../../../shared" Item { Tokens { id: tokenList } Component { id: transactionListItemCmp Rectangle { id: transactionListItem property bool isHovered: false property string symbol: "" anchors.right: parent.right anchors.left: parent.left height: 64 color: isHovered ? "#f0f0f0" : "white" Component.onCompleted: { for (let i = 0; i < tokenList.count; i++) { let token = tokenList.get(i) if (token.address == contract) { transactionListItem.symbol = token.symbol break; } } } MouseArea { anchors.fill: parent onClicked: transactionModal.open() cursorShape: Qt.PointingHandCursor hoverEnabled: true onEntered: { transactionListItem.isHovered = true } onExited: { transactionListItem.isHovered = false } } TransactionModal{ id: transactionModal } Item { Image { id: assetIcon width: 40 height: 40 source: "../../img/tokens/" + (transactionListItem.symbol != "" ? transactionListItem.symbol : "ETH") + ".png" anchors.left: parent.left anchors.top: parent.top anchors.topMargin: 12 onStatusChanged: { if (assetIcon.status == Image.Error) { assetIcon.source = "../../img/tokens/0-native.png" } } } StyledText { id: transferIcon anchors.topMargin: 25 anchors.top: parent.top anchors.left: assetIcon.right anchors.leftMargin: 22 height: 15 width: 15 color: to != walletModel.currentAccount.address ? "#4360DF" : "green" text: to != walletModel.currentAccount.address ? "↑" : "↓" } StyledText { id: transactionValue anchors.left: transferIcon.right anchors.leftMargin: Theme.smallPadding anchors.top: parent.top anchors.topMargin: Theme.bigPadding font.pixelSize: 15 text: value + " " + transactionListItem.symbol } } Item { anchors.right: timeInfo.left anchors.top: parent.top anchors.topMargin: Theme.bigPadding width: children[0].width + children[1].width StyledText { text: to != walletModel.currentAccount.address ? "To " : "From " anchors.right: addressValue.left color: Theme.darkGrey anchors.top: parent.top font.pixelSize: 15 font.strikeout: false } StyledText { id: addressValue text: to width: 100 elide: Text.ElideMiddle anchors.right: parent.right anchors.top: parent.top font.pixelSize: 15 } } Item { id: timeInfo anchors.right: parent.right anchors.top: parent.top anchors.topMargin: Theme.bigPadding width: children[0].width + children[1].width + children[2].width StyledText { text: "• " font.weight: Font.Bold anchors.right: timeIndicator.left color: Theme.darkGrey anchors.top: parent.top font.pixelSize: 15 } StyledText { id: timeIndicator text: "At " anchors.right: timeValue.left color: Theme.darkGrey anchors.top: parent.top font.pixelSize: 15 font.strikeout: false } StyledText { id: timeValue text: timestamp anchors.right: parent.right anchors.top: parent.top font.pixelSize: 15 } } } } ListView { anchors.topMargin: 20 anchors.fill: parent model: walletModel.transactions delegate: transactionListItemCmp } } /*##^## Designer { D{i:0;autoSize:true;height:480;width:640} } ##^##*/