2023-08-17 15:58:04 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
|
|
|
import QtQml.Models 2.15
|
2023-03-31 13:26:50 +02:00
|
|
|
|
|
|
|
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-08-10 12:39:52 +03:00
|
|
|
property string chainName
|
2024-07-22 09:52:44 -04:00
|
|
|
property string networkThatIsNotActive
|
2023-08-10 12:39:52 +03:00
|
|
|
|
|
|
|
// Fees related properties:
|
|
|
|
property bool isFeeLoading
|
|
|
|
property string feeText: ""
|
|
|
|
property string feeErrorText: ""
|
|
|
|
property string feeLabel: qsTr("Remotely destruct %1 token on %2").arg(root.collectibleName).arg(root.chainName)
|
2023-03-31 13:26:50 +02:00
|
|
|
|
2023-08-17 15:58:04 +02:00
|
|
|
readonly property alias tokenCount: d.tokenCount
|
2023-09-01 12:27:44 +03:00
|
|
|
readonly property string selectedAccount: d.accountAddress
|
|
|
|
readonly property var selectedWalletsAndAmounts: {
|
|
|
|
//depedency
|
|
|
|
d.tokenCount
|
|
|
|
return ModelUtils.modelToArray(d.walletsAndAmountsList)
|
|
|
|
}
|
2023-08-17 15:58:04 +02:00
|
|
|
|
2023-08-10 12:39:52 +03:00
|
|
|
// Account expected roles: address, name, color, emoji, walletType
|
|
|
|
property var accounts
|
2023-09-01 12:27:44 +03:00
|
|
|
|
2023-08-17 15:58:04 +02:00
|
|
|
signal remotelyDestructClicked(var walletsAndAmounts, string accountAddress)
|
2024-07-22 09:52:44 -04:00
|
|
|
signal enableNetwork
|
2023-08-10 12:39:52 +03:00
|
|
|
|
2023-03-31 13:26:50 +02:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
2023-08-10 12:39:52 +03:00
|
|
|
property string accountAddress
|
2023-03-31 13:26:50 +02:00
|
|
|
readonly property int maxHeight: 560 // by design
|
|
|
|
property int tokenCount: 0
|
2023-08-17 15:58:04 +02:00
|
|
|
readonly property ListModel walletsAndAmountsList: ListModel {}
|
2023-08-10 12:39:52 +03:00
|
|
|
readonly property bool isFeeError: root.feeErrorText !== ""
|
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) {
|
2023-08-17 15:58:04 +02:00
|
|
|
const index = ModelUtils.indexOf(d.walletsAndAmountsList,
|
|
|
|
"walletAddress", walletAddress)
|
|
|
|
|
|
|
|
if (index !== -1)
|
|
|
|
d.walletsAndAmountsList.setProperty(index, "amount", amount)
|
|
|
|
else
|
|
|
|
d.walletsAndAmountsList.append({ walletAddress, amount })
|
2023-04-27 12:12:09 +02:00
|
|
|
|
|
|
|
updateTokensCount()
|
2023-03-31 13:26:50 +02:00
|
|
|
}
|
2023-04-27 12:12:09 +02:00
|
|
|
|
2023-08-17 15:58:04 +02:00
|
|
|
function clearTokensToDestruct(walletAddress) {
|
|
|
|
const index = ModelUtils.indexOf(d.walletsAndAmountsList,
|
|
|
|
"walletAddress", walletAddress)
|
|
|
|
d.walletsAndAmountsList.remove(index)
|
2023-04-27 12:12:09 +02:00
|
|
|
updateTokensCount()
|
|
|
|
}
|
|
|
|
|
2023-08-17 15:58:04 +02:00
|
|
|
function updateTokensCount() {
|
|
|
|
const amounts = ModelUtils.modelToFlatArray(
|
|
|
|
d.walletsAndAmountsList, "amount")
|
|
|
|
const sum = amounts.reduce((a, b) => a + b, 0)
|
|
|
|
d.tokenCount = sum
|
|
|
|
}
|
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-08-10 12:39:52 +03:00
|
|
|
contentItem: ColumnLayout {
|
2024-10-15 21:26:12 +02:00
|
|
|
spacing: Theme.padding
|
2023-08-10 12:39:52 +03:00
|
|
|
TokenHoldersPanel {
|
|
|
|
id: tokenHoldersPanel
|
|
|
|
tokenName: root.collectibleName
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
isSelectorMode: true
|
|
|
|
onSelfDestructAmountChanged: d.updateTokensToDestruct(walletAddress, amount)
|
2023-08-17 15:58:04 +02:00
|
|
|
onSelfDestructRemoved: d.clearTokensToDestruct(walletAddress)
|
2023-08-10 12:39:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
FeesBox {
|
|
|
|
id: feesBox
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
2024-07-22 09:52:44 -04:00
|
|
|
Layout.bottomMargin: networkWarningPanel.visible ? 0 : 16
|
2023-08-10 12:39:52 +03:00
|
|
|
Layout.leftMargin: 16
|
|
|
|
Layout.rightMargin: 16
|
|
|
|
|
|
|
|
implicitWidth: 0
|
|
|
|
accountErrorText: root.feeErrorText
|
|
|
|
placeholderText: qsTr("Select a hodler to see remote destruction gas fees")
|
|
|
|
showAccountsSelector: true
|
2023-08-17 15:58:04 +02:00
|
|
|
model: d.tokenCount > 0 ? singleFeeModel : undefined
|
2023-08-10 12:39:52 +03:00
|
|
|
accountsSelector.model: root.accounts
|
|
|
|
|
2024-06-07 15:27:56 +03:00
|
|
|
Binding {
|
|
|
|
target: d
|
|
|
|
property: "accountAddress"
|
|
|
|
value: feesBox.accountsSelector.currentAccountAddress
|
2023-08-10 12:39:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: singleFeeModel
|
|
|
|
|
|
|
|
readonly property string title: root.feeLabel
|
|
|
|
readonly property string feeText: root.isFeeLoading ?
|
|
|
|
"" : root.feeText
|
|
|
|
readonly property bool error: d.isFeeError
|
|
|
|
}
|
|
|
|
}
|
2024-07-22 09:52:44 -04:00
|
|
|
|
|
|
|
NetworkWarningPanel {
|
|
|
|
id: networkWarningPanel
|
|
|
|
|
|
|
|
visible: !!root.networkThatIsNotActive
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.bottomMargin: 16
|
|
|
|
Layout.leftMargin: 18
|
|
|
|
Layout.rightMargin: 18
|
|
|
|
|
|
|
|
networkThatIsNotActive: root.chainName
|
|
|
|
onEnableNetwork: root.enableNetwork()
|
|
|
|
}
|
2023-03-31 13:26:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
footer: StatusDialogFooter {
|
2024-10-15 21:26:12 +02:00
|
|
|
spacing: Theme.padding
|
2023-03-31 13:26:50 +02:00
|
|
|
rightButtons: ObjectModel {
|
2023-07-05 18:17:51 +03:00
|
|
|
StatusFlatButton {
|
|
|
|
text: qsTr("Cancel")
|
|
|
|
onClicked: {
|
|
|
|
root.close()
|
|
|
|
}
|
|
|
|
}
|
2023-03-31 13:26:50 +02:00
|
|
|
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-08-17 15:58:04 +02:00
|
|
|
|
|
|
|
onClicked: {
|
|
|
|
const walletsAndAmounts = ModelUtils.modelToArray(
|
|
|
|
d.walletsAndAmountsList)
|
|
|
|
|
|
|
|
root.remotelyDestructClicked(walletsAndAmounts,
|
|
|
|
d.accountAddress)
|
|
|
|
}
|
2023-03-31 13:26:50 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|