2024-09-02 11:35:18 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Core.Utils 0.1
|
|
|
|
|
|
|
|
import AppLayouts.Wallet.panels 1.0
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
Control {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
/** Expected model structure: see SearchableAssetsPanel::model **/
|
2024-09-10 14:56:19 +02:00
|
|
|
property alias model: searchableAssetsPanel.model
|
2024-09-11 13:42:17 +02:00
|
|
|
property alias nonInteractiveKey: searchableAssetsPanel.nonInteractiveKey
|
2024-09-02 11:35:18 +02:00
|
|
|
|
2024-09-10 14:56:19 +02:00
|
|
|
readonly property bool isSelected: button.selected
|
2024-09-02 11:35:18 +02:00
|
|
|
|
2024-09-10 14:56:19 +02:00
|
|
|
signal selected(string key)
|
2024-09-02 11:35:18 +02:00
|
|
|
|
2024-09-23 10:15:01 +02:00
|
|
|
function setSelection(name: string, icon: url, key: string) {
|
2024-09-10 14:56:19 +02:00
|
|
|
button.name = name
|
|
|
|
button.icon = icon
|
|
|
|
button.selected = true
|
2024-09-02 11:35:18 +02:00
|
|
|
|
2024-09-10 14:56:19 +02:00
|
|
|
searchableAssetsPanel.highlightedKey = key ?? ""
|
2024-09-02 11:35:18 +02:00
|
|
|
}
|
|
|
|
|
2024-09-11 13:42:17 +02:00
|
|
|
function reset() {
|
|
|
|
button.selected = false
|
2024-09-18 13:03:36 +02:00
|
|
|
searchableAssetsPanel.highlightedKey = ""
|
2024-09-11 13:42:17 +02:00
|
|
|
}
|
|
|
|
|
2024-09-02 11:35:18 +02:00
|
|
|
contentItem: TokenSelectorButton {
|
2024-09-10 14:56:19 +02:00
|
|
|
id: button
|
2024-09-02 11:35:18 +02:00
|
|
|
|
|
|
|
forceHovered: dropdown.opened
|
|
|
|
text: qsTr("Select asset")
|
|
|
|
|
|
|
|
onClicked: dropdown.opened ? dropdown.close() : dropdown.open()
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusDropdown {
|
|
|
|
id: dropdown
|
|
|
|
|
2024-09-18 13:03:36 +02:00
|
|
|
y: root.height + 4
|
|
|
|
x: root.width - width
|
|
|
|
|
|
|
|
width: 448
|
2024-09-02 11:35:18 +02:00
|
|
|
|
2024-09-10 14:56:19 +02:00
|
|
|
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
2024-09-02 11:35:18 +02:00
|
|
|
padding: 0
|
|
|
|
|
|
|
|
contentItem: SearchableAssetsPanel {
|
|
|
|
id: searchableAssetsPanel
|
|
|
|
|
2024-09-18 13:03:36 +02:00
|
|
|
objectName: "searchableAssetsPanel"
|
|
|
|
|
2024-09-02 11:35:18 +02:00
|
|
|
function setCurrentAndClose(name, icon) {
|
2024-09-10 14:56:19 +02:00
|
|
|
button.name = name
|
|
|
|
button.icon = icon
|
|
|
|
button.selected = true
|
2024-09-02 11:35:18 +02:00
|
|
|
dropdown.close()
|
|
|
|
}
|
|
|
|
|
|
|
|
onSelected: {
|
2024-09-10 14:56:19 +02:00
|
|
|
const entry = ModelUtils.getByKey(root.model, "tokensKey", key)
|
2024-09-02 11:35:18 +02:00
|
|
|
highlightedKey = key
|
|
|
|
|
|
|
|
setCurrentAndClose(entry.symbol, entry.iconSource)
|
2024-09-10 14:56:19 +02:00
|
|
|
root.selected(key)
|
2024-09-02 11:35:18 +02:00
|
|
|
}
|
|
|
|
}
|
2024-09-18 13:03:36 +02:00
|
|
|
|
|
|
|
onClosed: searchableAssetsPanel.clearSearch()
|
2024-09-02 11:35:18 +02:00
|
|
|
}
|
|
|
|
}
|