2023-03-31 13:26:50 +02:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
import QtQml.Models 2.14
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Popups.Dialog 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
2023-04-13 10:09:06 +02:00
|
|
|
import StatusQ.Core.Utils 0.1
|
2023-03-31 13:26:50 +02:00
|
|
|
|
2023-06-23 08:17:04 +02:00
|
|
|
import AppLayouts.Communities.panels 1.0
|
2023-03-31 13:26:50 +02:00
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
StatusDialog {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property alias model: tokenHoldersPanel.model
|
|
|
|
|
|
|
|
property string collectibleName
|
|
|
|
|
2023-06-01 12:38:56 +02:00
|
|
|
signal remotelyDestructClicked(int tokenCount, var remotelyDestructTokensList)
|
2023-03-31 13:26:50 +02:00
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
|
|
|
readonly property int maxHeight: 560 // by design
|
|
|
|
property int tokenCount: 0
|
2023-04-27 12:12:09 +02:00
|
|
|
readonly property ListModel selfDestructTokensList: ListModel {}
|
2023-03-31 13:26:50 +02:00
|
|
|
|
|
|
|
function getVerticalPadding() {
|
|
|
|
return root.topPadding + root.bottomPadding
|
|
|
|
}
|
|
|
|
|
|
|
|
function getHorizontalPadding() {
|
|
|
|
return root.leftPadding + root.rightPadding
|
|
|
|
}
|
|
|
|
|
2023-04-27 12:12:09 +02:00
|
|
|
function updateTokensToDestruct(walletAddress, amount) {
|
|
|
|
if(ModelUtils.contains(d.selfDestructTokensList, "walletAddress", walletAddress))
|
|
|
|
clearTokensToDesctruct(walletAddress)
|
|
|
|
|
|
|
|
d.selfDestructTokensList.append({"walletAddress": walletAddress,
|
|
|
|
"amount": amount})
|
|
|
|
updateTokensCount()
|
2023-03-31 13:26:50 +02:00
|
|
|
}
|
2023-04-27 12:12:09 +02:00
|
|
|
|
|
|
|
function clearTokensToDesctruct(walletAddress) {
|
|
|
|
var index = ModelUtils.indexOf(d.selfDestructTokensList, "walletAddress", walletAddress)
|
|
|
|
d.selfDestructTokensList.remove(index)
|
|
|
|
updateTokensCount()
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateTokensCount() {
|
|
|
|
d.tokenCount = 0
|
|
|
|
for(var i = 0; i < d.selfDestructTokensList.count; i ++)
|
|
|
|
d.tokenCount += ModelUtils.get(d.selfDestructTokensList, i, "amount")
|
|
|
|
}
|
2023-03-31 13:26:50 +02:00
|
|
|
}
|
|
|
|
|
2023-05-15 16:52:50 +02:00
|
|
|
title: qsTr("Remotely destruct %1 token").arg(root.collectibleName)
|
2023-03-31 13:26:50 +02:00
|
|
|
implicitWidth: 600 // by design
|
2023-05-31 23:58:23 +03:00
|
|
|
padding: 0
|
2023-03-31 13:26:50 +02:00
|
|
|
|
2023-05-31 23:58:23 +03:00
|
|
|
TokenHoldersPanel {
|
|
|
|
id: tokenHoldersPanel
|
2023-03-31 13:26:50 +02:00
|
|
|
|
2023-05-31 23:58:23 +03:00
|
|
|
anchors.fill: parent
|
|
|
|
padding: 16
|
|
|
|
tokenName: root.collectibleName
|
|
|
|
isSelectorMode: true
|
2023-03-31 13:26:50 +02:00
|
|
|
|
2023-05-31 23:58:23 +03:00
|
|
|
onSelfDestructAmountChanged: d.updateTokensToDestruct(walletAddress, amount)
|
|
|
|
onSelfDestructRemoved: d.clearTokensToDesctruct(walletAddress)
|
2023-03-31 13:26:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
footer: StatusDialogFooter {
|
|
|
|
spacing: Style.current.padding
|
|
|
|
rightButtons: ObjectModel {
|
|
|
|
StatusButton {
|
|
|
|
enabled: d.tokenCount > 0
|
2023-05-15 16:52:50 +02:00
|
|
|
text: qsTr("Remotely destruct %n token(s)", "", d.tokenCount)
|
2023-03-31 13:26:50 +02:00
|
|
|
type: StatusBaseButton.Type.Danger
|
2023-05-15 16:52:50 +02:00
|
|
|
onClicked: root.remotelyDestructClicked(d.tokenCount,
|
2023-04-27 12:12:09 +02:00
|
|
|
ModelUtils.modelToArray(d.selfDestructTokensList,
|
|
|
|
["walletAddress", "amount"]))
|
2023-03-31 13:26:50 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|