import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15 import StatusQ.Controls 0.1 /** Two-tabs panel holding searchable lists of assets (single level) and collectibles (two levels). Structure: TabBar (assets, collectibles) StackLayout (current index bound to tab bar's current index) Assets List (assets part) StackView (collectibles part) Collectibles List (top level - groups by collection/community) Collectibles List (nested level, on demand) */ Control { id: root enum Tabs { Assets = 0, Collectibles = 1 } /** Expected model structure: see SearchableAssetsPanel::model **/ property alias assetsModel: searchableAssetsPanel.model /** Expected model structure: see SearchableCollectiblesPanel::model **/ property alias collectiblesModel: searchableCollectiblesPanel.model // Index of the current tab, indexes ​​correspond to the Tabs enum values. property alias currentTab: tabBar.currentIndex signal assetSelected(string key) signal collectionSelected(string key) signal collectibleSelected(string key) property string highlightedKey: "" contentItem: ColumnLayout { StatusTabBar { id: tabBar objectName: "tokensTabBar" Layout.fillWidth: true visible: !!root.assetsModel && !!root.collectiblesModel currentIndex: !!root.assetsModel ? TokenSelectorPanel.Tabs.Assets : TokenSelectorPanel.Tabs.Collectibles StatusTabButton { objectName: "assetsTab" text: qsTr("Assets") width: implicitWidth visible: !!root.assetsModel } StatusTabButton { objectName: "collectiblesTab" text: qsTr("Collectibles") width: implicitWidth visible: !!root.collectiblesModel } } StackLayout { Layout.maximumHeight: 400 visible: !!root.assetsModel || !!root.collectiblesModel currentIndex: tabBar.currentIndex SearchableAssetsPanel { id: searchableAssetsPanel Layout.preferredHeight: visible ? implicitHeight : 0 onSelected: root.assetSelected(key) } SearchableCollectiblesPanel { id: searchableCollectiblesPanel Layout.preferredHeight: visible ? currentItem.implicitHeight : 0 onCollectibleSelected: root.collectibleSelected(key) onCollectionSelected: root.collectionSelected(key) } } } }