mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-10 14:26:34 +00:00
464af7a04d
- filter out plain tokens from the adaptor's if already present in the output model - add a corresponding regression test Fixes #15412
209 lines
6.8 KiB
QML
209 lines
6.8 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
import QtQuick.Layouts 1.15
|
|
import QtQuick.Window 2.15
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import Storybook 1.0
|
|
import Models 1.0
|
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
import AppLayouts.Wallet.controls 1.0
|
|
import AppLayouts.Wallet.stores 1.0
|
|
import AppLayouts.Wallet.adaptors 1.0
|
|
|
|
import shared.stores 1.0
|
|
import utils 1.0
|
|
|
|
SplitView {
|
|
id: root
|
|
orientation: Qt.Vertical
|
|
|
|
Logs { id: logs }
|
|
|
|
ListModel {
|
|
id: plainTokensModel
|
|
ListElement {
|
|
key: "aave"
|
|
name: "Aave"
|
|
symbol: "AAVE"
|
|
image: "https://cryptologos.cc/logos/aave-aave-logo.png"
|
|
communityId: ""
|
|
}
|
|
ListElement {
|
|
key: "usdc"
|
|
name: "USDC"
|
|
symbol: "USDC"
|
|
image: ""
|
|
communityId: ""
|
|
}
|
|
ListElement {
|
|
key: "hst"
|
|
name: "Decision Token"
|
|
symbol: "HST"
|
|
image: "https://etherscan.io/token/images/horizonstate2_28.png"
|
|
communityId: ""
|
|
}
|
|
// DAI should be filtered out
|
|
ListElement {
|
|
key: "DAI"
|
|
name: "Dai Stablecoin"
|
|
symbol: "DAI"
|
|
image: ""
|
|
communityId: ""
|
|
}
|
|
}
|
|
|
|
QtObject {
|
|
id: d
|
|
|
|
readonly property var flatNetworks: NetworksModel.flatNetworks
|
|
readonly property var currencyStore: CurrenciesStore {}
|
|
readonly property var assetsStore: WalletAssetsStore {
|
|
id: thisWalletAssetStore
|
|
walletTokensStore: TokensStore {
|
|
plainTokensBySymbolModel: TokensBySymbolModel {}
|
|
}
|
|
readonly property var baseGroupedAccountAssetModel: GroupedAccountsAssetsModel {}
|
|
assetsWithFilteredBalances: thisWalletAssetStore.groupedAccountsAssetsModel
|
|
}
|
|
|
|
readonly property var walletAccountsModel: WalletAccountsModel {}
|
|
|
|
readonly property var adaptor: TokenSelectorViewAdaptor {
|
|
assetsModel: d.assetsStore.groupedAccountAssetsModel
|
|
plainTokensBySymbolModel: plainTokensModel
|
|
flatNetworksModel: d.flatNetworks
|
|
currentCurrency: d.currencyStore.currentCurrency
|
|
|
|
showAllTokens: ctrlShowAllTokens.checked
|
|
enabledChainIds: ctrlNetwork.currentValue ? [ctrlNetwork.currentValue] : []
|
|
accountAddress: ctrlAccount.currentValue ?? ""
|
|
showCommunityAssets: ctrlShowCommunityAssets.checked
|
|
searchString: tokenSelector.searchString
|
|
}
|
|
}
|
|
|
|
Pane {
|
|
SplitView.fillWidth: true
|
|
SplitView.fillHeight: true
|
|
|
|
background: Rectangle {
|
|
color: Theme.palette.baseColor3
|
|
}
|
|
|
|
TokenSelector {
|
|
id: tokenSelector
|
|
anchors.centerIn: parent
|
|
|
|
nonInteractiveDelegateKey: ctrlNonInteractiveDelegateKey.text
|
|
|
|
model: d.adaptor.outputAssetsModel
|
|
onTokenSelected: (tokensKey) => {
|
|
console.warn("!!! TOKEN SELECTED:", tokensKey)
|
|
logs.logEvent("TokenSelector::onTokenSelected", ["tokensKey"], arguments)
|
|
}
|
|
onActivated: ctrlSelectedAsset.currentIndex = ctrlSelectedAsset.indexOfValue(currentTokensKey)
|
|
}
|
|
}
|
|
|
|
LogsAndControlsPanel {
|
|
SplitView.minimumHeight: 340
|
|
SplitView.preferredHeight: 340
|
|
|
|
logsView.logText: logs.logText
|
|
|
|
RowLayout {
|
|
anchors.fill: parent
|
|
|
|
ColumnLayout {
|
|
RowLayout {
|
|
Layout.fillWidth: true
|
|
Label { text: "Selected asset:" }
|
|
ComboBox {
|
|
Layout.fillWidth: true
|
|
id: ctrlSelectedAsset
|
|
model: d.assetsStore.groupedAccountAssetsModel
|
|
textRole: "name"
|
|
valueRole: "tokensKey"
|
|
displayText: currentText || "N/A"
|
|
onActivated: tokenSelector.selectToken(currentValue)
|
|
}
|
|
TextField {
|
|
id: ctrlNonInteractiveDelegateKey
|
|
placeholderText: "Non interactive delegate token key"
|
|
}
|
|
}
|
|
|
|
Button {
|
|
text: "Reset"
|
|
onClicked: {
|
|
tokenSelector.reset()
|
|
ctrlSelectedAsset.currentIndex = -1
|
|
ctrlNonInteractiveDelegateKey.clear()
|
|
}
|
|
}
|
|
|
|
Switch {
|
|
id: ctrlShowAllTokens
|
|
text: "Show all tokens"
|
|
onToggled: {
|
|
// NB: ComboBox doesn't like changing models at runtime
|
|
tokenSelector.model = null
|
|
tokenSelector.model = d.adaptor.outputAssetsModel
|
|
}
|
|
}
|
|
Switch {
|
|
id: ctrlShowCommunityAssets
|
|
text: "Show community assets"
|
|
}
|
|
RowLayout {
|
|
Layout.fillWidth: true
|
|
Label { text: "Network:" }
|
|
ComboBox {
|
|
Layout.fillWidth: true
|
|
id: ctrlNetwork
|
|
textRole: "chainName"
|
|
valueRole: "chainId"
|
|
displayText: currentText || "All networks"
|
|
model: d.flatNetworks
|
|
currentIndex: -1
|
|
}
|
|
}
|
|
Label {
|
|
Layout.alignment: Qt.AlignRight
|
|
text: "Selected: %1".arg(ctrlNetwork.currentValue ? ctrlNetwork.currentValue.toString() : "All")
|
|
}
|
|
RowLayout {
|
|
Layout.fillWidth: true
|
|
Label { text: "Account:" }
|
|
ComboBox {
|
|
Layout.fillWidth: true
|
|
id: ctrlAccount
|
|
textRole: "name"
|
|
valueRole: "address"
|
|
displayText: currentText || "All accounts"
|
|
model: SortFilterProxyModel {
|
|
sourceModel: d.walletAccountsModel
|
|
sorters: RoleSorter { roleName: "position" }
|
|
}
|
|
currentIndex: -1
|
|
}
|
|
}
|
|
Label {
|
|
Layout.alignment: Qt.AlignRight
|
|
text: "Selected: %1".arg(ctrlAccount.currentValue ?? "all")
|
|
}
|
|
|
|
Item { Layout.fillHeight: true }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// category: Controls
|
|
|
|
// https://www.figma.com/design/TS0eQX9dAZXqZtELiwKIoK/Swap---Milestone-1?node-id=3406-231273&t=Ncl9lN1umbGEMxOn-0
|