2024-08-30 17:31:53 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Utils 0.1
|
|
|
|
import StatusQ.Popups.Dialog 0.1
|
|
|
|
|
|
|
|
import AppLayouts.Wallet.views 1.0
|
|
|
|
|
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
|
|
|
/**
|
|
|
|
Panel holding search field and lists of assets.
|
|
|
|
*/
|
|
|
|
Control {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
/**
|
|
|
|
Expected model structure:
|
|
|
|
|
|
|
|
tokensKey [string] - unique asset's identifier
|
|
|
|
name [string] - asset's name
|
|
|
|
symbol [string] - asset's symbol
|
|
|
|
iconSource [url] - asset's icon
|
|
|
|
currencyBalanceAsString [string] - formatted balance
|
|
|
|
balances [model] - submodel of balances per chain
|
|
|
|
balanceAsString [string] - formatted balance per chain
|
|
|
|
iconUrl [url] - chain's icon
|
2024-09-23 10:15:01 +02:00
|
|
|
sectionName (optional) [string] - text to be rendered as a section
|
2024-08-30 17:31:53 +02:00
|
|
|
**/
|
2024-09-13 13:07:09 +02:00
|
|
|
property alias model: sfpm.sourceModel
|
2024-09-11 13:42:17 +02:00
|
|
|
property string highlightedKey
|
|
|
|
property string nonInteractiveKey
|
|
|
|
|
2024-08-30 17:31:53 +02:00
|
|
|
signal selected(string key)
|
|
|
|
|
2024-09-18 13:03:36 +02:00
|
|
|
function clearSearch() {
|
|
|
|
searchBox.text = ""
|
|
|
|
}
|
|
|
|
|
2024-11-08 12:22:13 +01:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
readonly property bool validSearchResultExists: !!searchBox.text && sfpm.count > 0
|
|
|
|
}
|
|
|
|
|
2024-08-30 17:31:53 +02:00
|
|
|
SortFilterProxyModel {
|
|
|
|
id: sfpm
|
|
|
|
|
|
|
|
filters: AnyOf {
|
|
|
|
SearchFilter {
|
|
|
|
roleName: "name"
|
|
|
|
searchPhrase: searchBox.text
|
|
|
|
}
|
|
|
|
SearchFilter {
|
|
|
|
roleName: "symbol"
|
|
|
|
searchPhrase: searchBox.text
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
contentItem: ColumnLayout {
|
|
|
|
spacing: 0
|
|
|
|
|
|
|
|
TokenSearchBox {
|
|
|
|
id: searchBox
|
|
|
|
|
2024-09-18 13:03:36 +02:00
|
|
|
objectName: "searchBox"
|
|
|
|
|
2024-08-30 17:31:53 +02:00
|
|
|
Layout.fillWidth: true
|
|
|
|
placeholderText: qsTr("Search assets")
|
2024-11-08 12:22:13 +01:00
|
|
|
|
|
|
|
Keys.forwardTo: [listView]
|
2024-08-30 17:31:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusDialogDivider {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
visible: listView.count
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusListView {
|
|
|
|
id: listView
|
|
|
|
|
2024-09-11 13:42:17 +02:00
|
|
|
objectName: "assetsListView"
|
|
|
|
|
2024-08-30 17:31:53 +02:00
|
|
|
clip: true
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.preferredHeight: contentHeight
|
2024-11-08 12:22:13 +01:00
|
|
|
Layout.leftMargin: 4
|
|
|
|
Layout.rightMargin: 4
|
|
|
|
|
|
|
|
spacing: 4
|
2024-08-30 17:31:53 +02:00
|
|
|
|
|
|
|
model: sfpm
|
2024-09-23 10:15:01 +02:00
|
|
|
section.property: "sectionName"
|
2024-09-10 14:38:13 +02:00
|
|
|
|
|
|
|
section.delegate: TokenSelectorSectionDelegate {
|
|
|
|
width: ListView.view.width
|
|
|
|
text: section
|
|
|
|
}
|
|
|
|
|
2024-08-30 17:31:53 +02:00
|
|
|
delegate: TokenSelectorAssetDelegate {
|
|
|
|
required property var model
|
|
|
|
required property int index
|
|
|
|
|
2024-09-18 13:03:36 +02:00
|
|
|
width: ListView.view.width
|
|
|
|
|
|
|
|
highlighted: model.tokensKey === root.highlightedKey
|
|
|
|
enabled: model.tokensKey !== root.nonInteractiveKey
|
|
|
|
balancesListInteractive: !ListView.view.moving
|
2024-11-08 12:22:13 +01:00
|
|
|
isAutoHovered: d.validSearchResultExists && index === 0 && !listViewHoverHandler.hovered
|
2024-08-30 17:31:53 +02:00
|
|
|
|
|
|
|
name: model.name
|
|
|
|
symbol: model.symbol
|
2024-09-11 13:42:17 +02:00
|
|
|
currencyBalanceAsString: model.currencyBalanceAsString ?? ""
|
2024-08-30 17:31:53 +02:00
|
|
|
iconSource: model.iconSource
|
|
|
|
balancesModel: model.balances
|
|
|
|
|
|
|
|
onClicked: root.selected(model.tokensKey)
|
|
|
|
}
|
2024-11-08 12:22:13 +01:00
|
|
|
|
|
|
|
Keys.onReturnPressed: {
|
|
|
|
if(d.validSearchResultExists)
|
|
|
|
listView.itemAtIndex(0).clicked()
|
|
|
|
}
|
|
|
|
|
|
|
|
Keys.onEnterPressed: {
|
|
|
|
if(d.validSearchResultExists)
|
|
|
|
listView.itemAtIndex(0).clicked()
|
|
|
|
}
|
|
|
|
|
|
|
|
HoverHandler {
|
|
|
|
id: listViewHoverHandler
|
|
|
|
}
|
2024-08-30 17:31:53 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|