mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-28 15:26:10 +00:00
f2482ab003
teach the model about the special cased self-collections containing just one single collectible item; we need that for the "Arrange by collection" token mgmt feature but in all other cases it shouldn't be treated as a collection/group Fixes #13281
177 lines
6.8 KiB
QML
177 lines
6.8 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
|
|
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
|
|
|
|
StatusFlatButton {
|
|
id: root
|
|
|
|
property int currentIndex
|
|
property int count
|
|
|
|
property bool inHidden
|
|
property bool isGroup
|
|
property bool isCollection
|
|
property string groupId
|
|
property bool isCommunityToken
|
|
property bool isCollectible
|
|
|
|
readonly property bool hideEnabled: model.symbol !== "ETH"
|
|
readonly property bool menuVisible: menuLoader.active
|
|
|
|
signal moveRequested(int from, int to)
|
|
signal showHideRequested(string symbol, bool flag)
|
|
signal showHideGroupRequested(string groupId, bool flag)
|
|
|
|
icon.name: "more"
|
|
horizontalPadding: 4
|
|
verticalPadding: 4
|
|
textColor: hovered || highlighted ? Theme.palette.directColor1 : Theme.palette.baseColor1
|
|
highlighted: menuLoader.item && menuLoader.item.opened
|
|
|
|
onClicked: {
|
|
menuLoader.active = true
|
|
menuLoader.item.popup(width - menuLoader.item.width, height)
|
|
}
|
|
|
|
Loader {
|
|
id: menuLoader
|
|
objectName: "manageTokensContextMenuLoader"
|
|
active: false
|
|
sourceComponent: StatusMenu {
|
|
onClosed: menuLoader.active = false
|
|
|
|
StatusAction {
|
|
objectName: "miMoveToTop"
|
|
enabled: !root.inHidden && root.currentIndex !== 0
|
|
icon.name: "arrow-top"
|
|
text: qsTr("Move to top")
|
|
onTriggered: root.moveRequested(root.currentIndex, 0)
|
|
}
|
|
StatusAction {
|
|
objectName: "miMoveUp"
|
|
enabled: !root.inHidden && root.currentIndex !== 0
|
|
icon.name: "arrow-up"
|
|
text: qsTr("Move up")
|
|
onTriggered: root.moveRequested(root.currentIndex, root.currentIndex - 1)
|
|
}
|
|
StatusAction {
|
|
objectName: "miMoveDown"
|
|
enabled: !root.inHidden && root.currentIndex < root.count - 1
|
|
icon.name: "arrow-down"
|
|
text: qsTr("Move down")
|
|
onTriggered: root.moveRequested(root.currentIndex, root.currentIndex + 1)
|
|
}
|
|
StatusAction {
|
|
objectName: "miMoveToBottom"
|
|
enabled: !root.inHidden && root.currentIndex < root.count - 1
|
|
icon.name: "arrow-bottom"
|
|
text: qsTr("Move to bottom")
|
|
onTriggered: root.moveRequested(root.currentIndex, root.count - 1)
|
|
}
|
|
|
|
StatusMenuSeparator { enabled: !root.inHidden && root.hideEnabled }
|
|
|
|
// any token
|
|
StatusAction {
|
|
objectName: "miHideToken"
|
|
enabled: !root.inHidden && root.hideEnabled && !root.isGroup && !root.isCommunityToken && !root.groupId
|
|
type: StatusAction.Type.Danger
|
|
icon.name: "hide"
|
|
text: root.isCollectible ? qsTr("Hide collectible") : qsTr("Hide asset")
|
|
onTriggered: root.showHideRequested(model.symbol, false)
|
|
}
|
|
StatusAction {
|
|
objectName: "miShowToken"
|
|
enabled: root.inHidden && !root.isGroup
|
|
icon.name: "show"
|
|
text: root.isCollectible ? qsTr("Show collectible") : qsTr("Show asset")
|
|
onTriggered: root.showHideRequested(model.symbol, true)
|
|
}
|
|
|
|
// (hide) community tokens
|
|
StatusMenu {
|
|
id: communitySubmenu
|
|
enabled: !root.inHidden && root.isCommunityToken
|
|
title: qsTr("Hide")
|
|
assetSettings.name: "hide"
|
|
type: StatusAction.Type.Danger
|
|
|
|
StatusAction {
|
|
objectName: "miHideCommunityToken"
|
|
text: root.isCollectible ? qsTr("This collectible") : qsTr("This asset")
|
|
onTriggered: {
|
|
root.showHideRequested(model.symbol, false)
|
|
communitySubmenu.dismiss()
|
|
}
|
|
}
|
|
StatusAction {
|
|
objectName: "miHideAllCommunityTokens"
|
|
text: root.isCollectible ? qsTr("All collectibles from this community") : qsTr("All assets from this community")
|
|
onTriggered: {
|
|
root.showHideGroupRequested(root.groupId, false)
|
|
communitySubmenu.dismiss()
|
|
}
|
|
}
|
|
}
|
|
|
|
// (hide) collection tokens
|
|
StatusMenu {
|
|
id: collectionSubmenu
|
|
enabled: !root.inHidden && root.isCollectible && !root.isCommunityToken && !root.isGroup && root.groupId
|
|
title: qsTr("Hide")
|
|
assetSettings.name: "hide"
|
|
type: StatusAction.Type.Danger
|
|
|
|
StatusAction {
|
|
objectName: "miHideCollectionToken"
|
|
text: qsTr("This collectible")
|
|
onTriggered: {
|
|
root.showHideRequested(model.symbol, false)
|
|
communitySubmenu.dismiss()
|
|
}
|
|
}
|
|
StatusAction {
|
|
objectName: "miHideAllCollectionTokens"
|
|
text: qsTr("All collectibles from this collection")
|
|
onTriggered: {
|
|
root.showHideGroupRequested(root.groupId, false)
|
|
communitySubmenu.dismiss()
|
|
}
|
|
}
|
|
}
|
|
|
|
// token group
|
|
StatusAction {
|
|
objectName: "miHideTokenGroup"
|
|
enabled: !root.inHidden && root.isGroup
|
|
type: StatusAction.Type.Danger
|
|
icon.name: "hide"
|
|
text: {
|
|
if (root.isCollection)
|
|
return qsTr("Hide all collectibles from this collection")
|
|
return root.isCollectible ? qsTr("Hide all collectibles from this community")
|
|
: qsTr("Hide all assets from this community")
|
|
}
|
|
onTriggered: root.showHideGroupRequested(root.groupId, false)
|
|
}
|
|
StatusAction {
|
|
objectName: "miShowTokenGroup"
|
|
enabled: root.inHidden && root.groupId
|
|
icon.name: "show"
|
|
text: {
|
|
if (root.isCollection)
|
|
return qsTr("Show all collectibles from this collection")
|
|
return root.isCollectible ? qsTr("Show all collectibles from this community")
|
|
: qsTr("Show all assets from this community")
|
|
}
|
|
onTriggered: root.showHideGroupRequested(root.groupId, true)
|
|
}
|
|
}
|
|
}
|
|
}
|