import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15 import StatusQ.Core 0.1 import StatusQ.Components 0.1 import StatusQ.Controls 0.1 import StatusQ.Core.Theme 0.1 import StatusQ.Models 0.1 import utils 1.0 import AppLayouts.Wallet.controls 1.0 Control { id: root required property var controller readonly property bool dirty: root.controller.dirty readonly property bool hasSettings: root.controller.hasSettings property var getCurrencyAmount: function (balance, symbol) {} property var getCurrentCurrencyAmount: function(balance){} background: null function saveSettings() { root.controller.saveSettings(); } function revert() { root.controller.revert(); } function clearSettings() { root.controller.clearSettings(); } contentItem: ColumnLayout { spacing: Style.current.padding StatusListView { Layout.fillWidth: true model: root.controller.regularTokensModel implicitHeight: contentHeight interactive: false displaced: Transition { NumberAnimation { properties: "x,y"; easing.type: Easing.OutQuad } } delegate: ManageTokensDelegate { controller: root.controller dragParent: root count: root.controller.regularTokensModel.count dragEnabled: count > 1 getCurrencyAmount: function (balance, symbol) { return root.getCurrencyAmount(balance, symbol) } getCurrentCurrencyAmount: function (balance) { return root.getCurrentCurrencyAmount(balance) } } } RowLayout { Layout.fillWidth: true Layout.topMargin: Style.current.padding visible: root.controller.communityTokensModel.count StatusBaseText { Layout.fillWidth: true text: qsTr("Community") } StatusSwitch { LayoutMirroring.enabled: true LayoutMirroring.childrenInherit: true id: switchArrangeByCommunity textColor: Theme.palette.baseColor1 font.pixelSize: 13 text: qsTr("Arrange by community") checked: root.controller.arrangeByCommunity onToggled: root.controller.arrangeByCommunity = checked } } Loader { Layout.fillWidth: true active: root.controller.communityTokensModel.count visible: active sourceComponent: switchArrangeByCommunity.checked ? cmpCommunityTokenGroups : cmpCommunityTokens } } Component { id: cmpCommunityTokens StatusListView { model: root.controller.communityTokensModel implicitHeight: contentHeight interactive: false displaced: Transition { NumberAnimation { properties: "x,y"; easing.type: Easing.OutQuad } } delegate: ManageTokensDelegate { controller: root.controller dragParent: root count: root.controller.communityTokensModel.count dragEnabled: count > 1 getCurrencyAmount: function (balance, symbol) { return root.getCurrencyAmount(balance, symbol) } getCurrentCurrencyAmount: function (balance) { return root.getCurrentCurrencyAmount(balance) } } } } Component { id: cmpCommunityTokenGroups StatusListView { model: root.controller.communityTokenGroupsModel implicitHeight: contentHeight interactive: false displaced: Transition { NumberAnimation { properties: "x,y"; easing.type: Easing.OutQuad } } delegate: ManageTokensGroupDelegate { controller: root.controller dragParent: root dragEnabled: root.controller.communityTokenGroupsModel.count > 1 getCurrencyAmount: function (balance, symbol) { return root.getCurrencyAmount(balance, symbol) } getCurrentCurrencyAmount: function (balance) { return root.getCurrentCurrencyAmount(balance) } } } } }