2022-07-21 10:40:49 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
|
2022-08-18 22:49:50 +02:00
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
2022-07-21 10:40:49 +02:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Core.Utils 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
2022-08-18 22:49:50 +02:00
|
|
|
import StatusQ.Core.Backpressure 1.0
|
|
|
|
|
|
|
|
import shared.controls 1.0
|
2022-12-14 22:06:14 +01:00
|
|
|
import utils 1.0
|
2022-07-21 10:40:49 +02:00
|
|
|
|
2022-12-16 09:50:56 +01:00
|
|
|
import "../controls"
|
|
|
|
|
2022-07-21 10:40:49 +02:00
|
|
|
Item {
|
|
|
|
id: root
|
2022-08-03 15:15:13 +03:00
|
|
|
|
2022-07-21 10:40:49 +02:00
|
|
|
property var assets
|
|
|
|
property var selectedAsset
|
2022-12-16 09:50:56 +01:00
|
|
|
property string defaultToken
|
|
|
|
property string currentCurrencySymbol
|
|
|
|
property string placeholderText
|
2023-04-18 18:05:24 +02:00
|
|
|
property var hoveredToken
|
2022-12-16 09:50:56 +01:00
|
|
|
|
2022-07-21 10:40:49 +02:00
|
|
|
property var tokenAssetSourceFn: function (symbol) {
|
|
|
|
return ""
|
|
|
|
}
|
2022-08-29 18:28:54 +02:00
|
|
|
property var searchTokenSymbolByAddressFn: function (address) {
|
2022-08-18 22:49:50 +02:00
|
|
|
return ""
|
|
|
|
}
|
2022-12-16 09:50:56 +01:00
|
|
|
property var getNetworkIcon: function(chainId){
|
|
|
|
return ""
|
|
|
|
}
|
2022-07-21 10:40:49 +02:00
|
|
|
|
|
|
|
function resetInternal() {
|
|
|
|
assets = null
|
|
|
|
selectedAsset = null
|
|
|
|
}
|
|
|
|
|
2022-11-23 18:58:22 +01:00
|
|
|
implicitWidth: comboBox.width
|
2022-08-03 15:15:13 +03:00
|
|
|
implicitHeight: comboBox.implicitHeight
|
|
|
|
|
2022-07-21 10:40:49 +02:00
|
|
|
onSelectedAssetChanged: {
|
|
|
|
if (selectedAsset && selectedAsset.symbol) {
|
2023-03-27 09:52:12 +02:00
|
|
|
d.iconSource = tokenAssetSourceFn(selectedAsset.symbol)
|
|
|
|
d.text = selectedAsset.symbol
|
2022-07-21 10:40:49 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-18 18:05:24 +02:00
|
|
|
onHoveredTokenChanged: {
|
|
|
|
if (hoveredToken && hoveredToken.symbol) {
|
|
|
|
d.iconSource = tokenAssetSourceFn(hoveredToken.symbol)
|
|
|
|
d.text = hoveredToken.symbol
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-03 15:15:13 +03:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
property string iconSource: ""
|
|
|
|
property string text: ""
|
2022-08-18 22:49:50 +02:00
|
|
|
property string searchString
|
2023-04-18 18:05:24 +02:00
|
|
|
readonly property bool isTokenSelected: !!root.selectedAsset || !!root.hoveredToken
|
2022-08-18 22:49:50 +02:00
|
|
|
|
|
|
|
readonly property var updateSearchText: Backpressure.debounce(root, 1000, function(inputText) {
|
|
|
|
d.searchString = inputText
|
|
|
|
})
|
2022-08-03 15:15:13 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusComboBox {
|
|
|
|
id: comboBox
|
2022-08-09 15:52:17 +02:00
|
|
|
objectName: "assetSelectorButton"
|
2022-12-14 22:06:14 +01:00
|
|
|
height: 34
|
2022-08-03 15:15:13 +03:00
|
|
|
|
|
|
|
control.padding: 4
|
2022-12-16 09:50:56 +01:00
|
|
|
control.popup.width: 492
|
|
|
|
control.popup.x: -root.x
|
2023-04-18 18:05:24 +02:00
|
|
|
control.popup.verticalPadding: 0
|
2023-02-02 16:28:39 +01:00
|
|
|
|
2022-08-09 15:52:17 +02:00
|
|
|
popupContentItemObjectName: "assetSelectorList"
|
2022-08-03 15:15:13 +03:00
|
|
|
|
2022-08-18 22:49:50 +02:00
|
|
|
model : SortFilterProxyModel {
|
|
|
|
sourceModel: root.assets
|
|
|
|
filters: [
|
|
|
|
ExpressionFilter {
|
|
|
|
expression: {
|
2022-08-29 18:28:54 +02:00
|
|
|
var tokenSymbolByAddress = searchTokenSymbolByAddressFn(d.searchString)
|
2022-12-06 10:49:57 +01:00
|
|
|
return visibleForNetwork && (
|
2022-11-03 15:11:13 +01:00
|
|
|
symbol.startsWith(d.searchString.toUpperCase()) || name.toUpperCase().startsWith(d.searchString.toUpperCase()) || (tokenSymbolByAddress!=="" && symbol.startsWith(tokenSymbolByAddress))
|
|
|
|
)
|
2022-08-18 22:49:50 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
2022-08-03 15:15:13 +03:00
|
|
|
|
|
|
|
control.background: Rectangle {
|
2022-08-03 15:41:24 +02:00
|
|
|
color: "transparent"
|
2022-12-14 22:06:14 +01:00
|
|
|
border.width: d.isTokenSelected ? 0 : 1
|
|
|
|
border.color: d.isTokenSelected ? "transparent" : Theme.palette.directColor7
|
|
|
|
radius: 12
|
2022-08-03 15:15:13 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
contentItem: RowLayout {
|
2022-11-23 18:58:22 +01:00
|
|
|
id: rowLayout
|
2022-08-03 15:15:13 +03:00
|
|
|
StatusRoundedImage {
|
2022-12-14 22:06:14 +01:00
|
|
|
Layout.preferredWidth: 21
|
|
|
|
Layout.preferredHeight: 21
|
|
|
|
Layout.alignment: Qt.AlignVCenter | Qt.AlignLeft
|
2022-11-23 18:58:22 +01:00
|
|
|
visible: !!d.iconSource
|
2022-08-03 15:15:13 +03:00
|
|
|
image.source: d.iconSource
|
|
|
|
image.onStatusChanged: {
|
|
|
|
if (image.status === Image.Error) {
|
|
|
|
image.source = defaultToken
|
2022-07-21 10:40:49 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-12-14 22:06:14 +01:00
|
|
|
StatusBaseText {
|
|
|
|
Layout.alignment: Qt.AlignVCenter
|
|
|
|
font.pixelSize: 28
|
|
|
|
elide: Text.ElideRight
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
color: Theme.palette.miscColor1
|
|
|
|
text: d.text
|
|
|
|
visible: d.isTokenSelected
|
|
|
|
}
|
|
|
|
StatusIcon {
|
|
|
|
Layout.leftMargin: -3
|
|
|
|
Layout.alignment: Qt.AlignVCenter
|
|
|
|
icon: "chevron-down"
|
|
|
|
width: 16
|
|
|
|
height: 16
|
|
|
|
color: Theme.palette.miscColor1
|
|
|
|
visible: d.isTokenSelected
|
|
|
|
}
|
|
|
|
StatusBaseText {
|
|
|
|
Layout.alignment: Qt.AlignCenter
|
|
|
|
visible: !d.isTokenSelected
|
|
|
|
font.pixelSize: 15
|
|
|
|
font.weight: Font.Medium
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
elide: Qt.ElideRight
|
|
|
|
text: placeholderText
|
2022-11-23 18:58:22 +01:00
|
|
|
}
|
2022-07-21 10:40:49 +02:00
|
|
|
}
|
|
|
|
|
2022-08-03 15:41:24 +02:00
|
|
|
control.indicator: null
|
|
|
|
|
2022-12-16 09:50:56 +01:00
|
|
|
delegate: TokenBalancePerChainDelegate {
|
2022-08-18 13:51:18 -04:00
|
|
|
objectName: "AssetSelector_ItemDelegate_" + symbol
|
2022-12-16 09:50:56 +01:00
|
|
|
width: comboBox.control.popup.width
|
|
|
|
getNetworkIcon: root.getNetworkIcon
|
|
|
|
onTokenSelected: {
|
|
|
|
selectedAsset = selectedToken
|
|
|
|
comboBox.control.popup.close()
|
2022-07-21 10:40:49 +02:00
|
|
|
}
|
|
|
|
}
|
2022-08-18 22:49:50 +02:00
|
|
|
|
|
|
|
Component.onCompleted: {
|
|
|
|
control.currentIndex = -1
|
|
|
|
control.popup.contentItem.header = searchBox
|
|
|
|
}
|
|
|
|
|
|
|
|
control.popup.onOpened: {
|
|
|
|
control.currentIndex = -1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: searchBox
|
|
|
|
StatusInput {
|
|
|
|
width: parent.width
|
|
|
|
input.showBackground: false
|
|
|
|
placeholderText: qsTr("Search for token or enter token address")
|
|
|
|
onTextChanged: Qt.callLater(d.updateSearchText, text)
|
|
|
|
input.clearable: true
|
2023-04-18 18:05:24 +02:00
|
|
|
input.implicitHeight: 56
|
|
|
|
input.rightComponent: StatusFlatRoundButton {
|
|
|
|
icon.name: "search"
|
|
|
|
type: StatusFlatRoundButton.Type.Secondary
|
|
|
|
enabled: false
|
2022-08-18 22:49:50 +02:00
|
|
|
}
|
|
|
|
Rectangle {
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
height: 1
|
|
|
|
width: parent.width
|
|
|
|
color: Theme.palette.baseColor2
|
|
|
|
}
|
|
|
|
}
|
2022-07-21 10:40:49 +02:00
|
|
|
}
|
|
|
|
}
|