240 lines
7.5 KiB
QML
240 lines
7.5 KiB
QML
|
import QtQuick 2.15
|
|||
|
import QtQuick.Controls 2.15
|
|||
|
import QtQuick.Layouts 1.15
|
|||
|
|
|||
|
import StatusQ 0.1
|
|||
|
import StatusQ.Core 0.1
|
|||
|
import StatusQ.Components 0.1
|
|||
|
import StatusQ.Controls 0.1
|
|||
|
import StatusQ.Core.Theme 0.1
|
|||
|
import StatusQ.Popups 0.1
|
|||
|
import StatusQ.Models 0.1
|
|||
|
|
|||
|
import utils 1.0
|
|||
|
import shared.controls 1.0
|
|||
|
|
|||
|
import AppLayouts.Wallet.controls 1.0
|
|||
|
|
|||
|
Control {
|
|||
|
id: root
|
|||
|
|
|||
|
required property var baseModel
|
|||
|
|
|||
|
readonly property bool dirty: d.controller.dirty
|
|||
|
|
|||
|
background: null
|
|||
|
|
|||
|
function saveSettings() {
|
|||
|
d.controller.saveSettings();
|
|||
|
}
|
|||
|
|
|||
|
function revert() {
|
|||
|
d.controller.revert();
|
|||
|
}
|
|||
|
|
|||
|
function clearSettings() {
|
|||
|
d.controller.clearSettings();
|
|||
|
}
|
|||
|
|
|||
|
QtObject {
|
|||
|
id: d
|
|||
|
|
|||
|
property bool collectionGroupsExpanded: true
|
|||
|
property bool communityGroupsExpanded: true
|
|||
|
|
|||
|
readonly property var renamedModel: RolesRenamingModel {
|
|||
|
sourceModel: root.baseModel
|
|||
|
|
|||
|
mapping: [
|
|||
|
RoleRename {
|
|||
|
from: "uid"
|
|||
|
to: "symbol"
|
|||
|
}
|
|||
|
]
|
|||
|
}
|
|||
|
|
|||
|
readonly property var controller: ManageTokensController {
|
|||
|
sourceModel: d.renamedModel
|
|||
|
arrangeByCommunity: switchArrangeByCommunity.checked
|
|||
|
settingsKey: "WalletCollectibles"
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
contentItem: ColumnLayout {
|
|||
|
spacing: Style.current.padding
|
|||
|
|
|||
|
ShapeRectangle {
|
|||
|
Layout.fillWidth: true
|
|||
|
Layout.margins: 2
|
|||
|
visible: !d.controller.regularTokensModel.count
|
|||
|
text: qsTr("You’ll be able to manage the display of your collectibles here")
|
|||
|
}
|
|||
|
|
|||
|
// TODO https://github.com/status-im/status-desktop/issues/12703
|
|||
|
// StatusSwitch {
|
|||
|
// Layout.alignment: Qt.AlignTrailing
|
|||
|
// LayoutMirroring.enabled: true
|
|||
|
// LayoutMirroring.childrenInherit: true
|
|||
|
// id: switchArrangeByCollection
|
|||
|
// textColor: Theme.palette.baseColor1
|
|||
|
// text: qsTr("Arrange by collection (TODO)")
|
|||
|
// visible: d.controller.regularTokensModel.count
|
|||
|
// }
|
|||
|
|
|||
|
// StatusModalDivider {
|
|||
|
// Layout.fillWidth: true
|
|||
|
// Layout.topMargin: -Style.current.halfPadding
|
|||
|
// visible: switchArrangeByCollection.visible && switchArrangeByCollection.checked
|
|||
|
// }
|
|||
|
|
|||
|
// StatusLinkText {
|
|||
|
// Layout.alignment: Qt.AlignTrailing
|
|||
|
// visible: switchArrangeByCollection.visible && switchArrangeByCollection.checked
|
|||
|
// text: d.collectionGroupsExpanded ? qsTr("Collapse all") : qsTr("Expand all")
|
|||
|
// normalColor: linkColor
|
|||
|
// font.weight: Font.Normal
|
|||
|
// onClicked: d.collectionGroupsExpanded = !d.collectionGroupsExpanded
|
|||
|
// }
|
|||
|
|
|||
|
StatusListView {
|
|||
|
objectName: "lvRegularTokens"
|
|||
|
Layout.fillWidth: true
|
|||
|
model: d.controller.regularTokensModel
|
|||
|
implicitHeight: contentHeight
|
|||
|
interactive: false
|
|||
|
|
|||
|
displaced: Transition {
|
|||
|
NumberAnimation { properties: "x,y"; easing.type: Easing.OutQuad }
|
|||
|
}
|
|||
|
|
|||
|
delegate: ManageTokensDelegate {
|
|||
|
isCollectible: true
|
|||
|
controller: d.controller
|
|||
|
dragParent: root
|
|||
|
count: d.controller.regularTokensModel.count
|
|||
|
dragEnabled: count > 1
|
|||
|
keys: ["x-status-draggable-token-item"]
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
RowLayout {
|
|||
|
id: communityTokensHeader
|
|||
|
Layout.fillWidth: true
|
|||
|
Layout.topMargin: Style.current.padding
|
|||
|
visible: d.controller.communityTokensModel.count
|
|||
|
StatusBaseText {
|
|||
|
color: Theme.palette.baseColor1
|
|||
|
text: qsTr("Community")
|
|||
|
}
|
|||
|
Item { Layout.fillWidth: true }
|
|||
|
StatusSwitch {
|
|||
|
objectName: "switchArrangeByCommunity"
|
|||
|
LayoutMirroring.enabled: true
|
|||
|
LayoutMirroring.childrenInherit: true
|
|||
|
id: switchArrangeByCommunity
|
|||
|
textColor: Theme.palette.baseColor1
|
|||
|
text: qsTr("Arrange by community")
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
StatusModalDivider {
|
|||
|
Layout.fillWidth: true
|
|||
|
Layout.topMargin: -Style.current.halfPadding
|
|||
|
visible: communityTokensHeader.visible && switchArrangeByCommunity.checked
|
|||
|
}
|
|||
|
|
|||
|
StatusLinkText {
|
|||
|
objectName: "switchCollapseCommunityGroups"
|
|||
|
Layout.alignment: Qt.AlignTrailing
|
|||
|
visible: communityTokensHeader.visible && switchArrangeByCommunity.checked
|
|||
|
text: d.communityGroupsExpanded ? qsTr("Collapse all") : qsTr("Expand all")
|
|||
|
normalColor: linkColor
|
|||
|
font.weight: Font.Normal
|
|||
|
onClicked: d.communityGroupsExpanded = !d.communityGroupsExpanded
|
|||
|
}
|
|||
|
|
|||
|
Loader {
|
|||
|
objectName: "loaderCommunityTokens"
|
|||
|
Layout.fillWidth: true
|
|||
|
active: d.controller.communityTokensModel.count
|
|||
|
visible: active
|
|||
|
sourceComponent: switchArrangeByCommunity.checked ? cmpCommunityTokenGroups : cmpCommunityTokens
|
|||
|
}
|
|||
|
|
|||
|
StatusBaseText {
|
|||
|
Layout.fillWidth: true
|
|||
|
Layout.topMargin: Style.current.padding
|
|||
|
color: Theme.palette.baseColor1
|
|||
|
text: qsTr("Hidden")
|
|||
|
visible: d.controller.hiddenTokensModel.count
|
|||
|
}
|
|||
|
|
|||
|
StatusListView {
|
|||
|
objectName: "lvHiddenTokens"
|
|||
|
Layout.fillWidth: true
|
|||
|
model: d.controller.hiddenTokensModel
|
|||
|
implicitHeight: contentHeight
|
|||
|
interactive: false
|
|||
|
|
|||
|
displaced: Transition {
|
|||
|
NumberAnimation { properties: "x,y"; easing.type: Easing.OutQuad }
|
|||
|
}
|
|||
|
|
|||
|
delegate: ManageTokensDelegate {
|
|||
|
isCollectible: true
|
|||
|
controller: d.controller
|
|||
|
dragParent: root
|
|||
|
dragEnabled: false
|
|||
|
keys: ["x-status-draggable-none"]
|
|||
|
isHidden: true
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
Component {
|
|||
|
id: cmpCommunityTokens
|
|||
|
StatusListView {
|
|||
|
objectName: "lvCommunityTokens"
|
|||
|
model: d.controller.communityTokensModel
|
|||
|
implicitHeight: contentHeight
|
|||
|
interactive: false
|
|||
|
|
|||
|
displaced: Transition {
|
|||
|
NumberAnimation { properties: "x,y"; easing.type: Easing.OutQuad }
|
|||
|
}
|
|||
|
|
|||
|
delegate: ManageTokensDelegate {
|
|||
|
isCollectible: true
|
|||
|
controller: d.controller
|
|||
|
dragParent: root
|
|||
|
count: d.controller.communityTokensModel.count
|
|||
|
dragEnabled: count > 1
|
|||
|
keys: ["x-status-draggable-community-token-item"]
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
Component {
|
|||
|
id: cmpCommunityTokenGroups
|
|||
|
StatusListView {
|
|||
|
objectName: "lvCommunityTokenGroups"
|
|||
|
model: d.controller.communityTokenGroupsModel
|
|||
|
implicitHeight: contentHeight
|
|||
|
interactive: false
|
|||
|
spacing: Style.current.halfPadding
|
|||
|
|
|||
|
displaced: Transition {
|
|||
|
NumberAnimation { properties: "x,y"; easing.type: Easing.OutQuad }
|
|||
|
}
|
|||
|
|
|||
|
delegate: ManageTokensGroupDelegate {
|
|||
|
isCollectible: true
|
|||
|
controller: d.controller
|
|||
|
dragParent: root
|
|||
|
dragEnabled: d.controller.communityTokenGroupsModel.count > 1
|
|||
|
communityGroupsExpanded: d.communityGroupsExpanded
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|