2022-03-02 15:24:39 +01:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.controls 1.0
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: modalBody
|
|
|
|
|
|
|
|
property var defaultTokenList
|
|
|
|
property var customTokenList
|
2022-04-04 14:11:39 +02:00
|
|
|
signal toggleVisibleClicked(int chainId, string address)
|
2022-03-02 15:24:39 +01:00
|
|
|
signal removeCustomTokenTriggered(int chainId, string address)
|
|
|
|
signal showTokenDetailsTriggered(int chainId, string address, string name, string symbol, string decimals)
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: tokenComponent
|
|
|
|
|
|
|
|
StatusListItem {
|
|
|
|
id: assetSymbol
|
|
|
|
title: symbol
|
|
|
|
subTitle: name || ""
|
|
|
|
image.source: Style.png("tokens/" + (hasIcon ? symbol : "DEFAULT-TOKEN@3x"))
|
|
|
|
image.height: 36
|
|
|
|
components: [StatusCheckBox {
|
|
|
|
id: assetCheck
|
|
|
|
checked: model.isVisible
|
2022-04-04 14:11:39 +02:00
|
|
|
onClicked: toggleVisibleClicked(chainId, address)
|
2022-03-02 15:24:39 +01:00
|
|
|
}]
|
|
|
|
visible: symbol && (searchBox.text == "" || name.toLowerCase().includes(searchBox.text.toLowerCase()) || symbol.toLowerCase().includes(searchBox.text.toLowerCase()))
|
|
|
|
MouseArea {
|
|
|
|
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: function (event) {
|
|
|
|
if (event.button === Qt.RightButton) {
|
|
|
|
return contextMenu.popup(mouseX, mouseY)
|
|
|
|
}
|
|
|
|
assetCheck.checked = !assetCheck.checked
|
2022-04-04 14:11:39 +02:00
|
|
|
toggleVisibleClicked(chainId, address)
|
2022-03-02 15:24:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusPopupMenu {
|
|
|
|
id: contextMenu
|
|
|
|
Action {
|
2022-04-04 14:11:39 +02:00
|
|
|
icon.name: "admin"
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Token details")
|
2022-03-02 15:24:39 +01:00
|
|
|
onTriggered: {
|
|
|
|
modalBody.showTokenDetailsTriggered(chainId, address, name, symbol, decimals);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Action {
|
2022-04-04 14:11:39 +02:00
|
|
|
icon.name: "remove"
|
2022-03-02 15:24:39 +01:00
|
|
|
icon.color: Style.current.red
|
|
|
|
enabled: isCustom
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Remove token")
|
2022-03-02 15:24:39 +01:00
|
|
|
onTriggered: removeCustomTokenTriggered(chainId, address)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SearchBox {
|
|
|
|
id: searchBox
|
2022-03-21 13:43:42 -04:00
|
|
|
input.font.pixelSize: 12
|
2022-03-02 15:24:39 +01:00
|
|
|
anchors.top: modalBody.top
|
|
|
|
anchors.topMargin: Style.current.padding
|
2022-03-21 13:43:42 -04:00
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.left: parent.left
|
2022-03-02 15:24:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ScrollView {
|
|
|
|
id: sview
|
|
|
|
clip: true
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
ScrollBar.vertical.policy: ScrollBar.AlwaysOn
|
|
|
|
|
|
|
|
contentHeight: tokenList.height
|
|
|
|
|
|
|
|
anchors.top: searchBox.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: tokenList
|
|
|
|
height: childrenRect.height
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: customTokens
|
|
|
|
spacing: Style.current.halfPadding
|
|
|
|
visible: { modalBody.customTokenList.count > 0 }
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: customLbl
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Custom")
|
2022-03-02 15:24:39 +01:00
|
|
|
font.pixelSize: 13
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
height: 20
|
|
|
|
}
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: customTokensRepeater
|
|
|
|
model: modalBody.customTokenList
|
|
|
|
delegate: tokenComponent
|
|
|
|
anchors.top: customLbl.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Column {
|
|
|
|
anchors.top: customTokens.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
id: defaultTokens
|
|
|
|
spacing: Style.current.halfPadding
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: defaultLbl
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Default")
|
2022-03-02 15:24:39 +01:00
|
|
|
font.pixelSize: 13
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
height: 20
|
|
|
|
}
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
model: modalBody.defaultTokenList
|
|
|
|
delegate: tokenComponent
|
|
|
|
anchors.top: defaultLbl.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|