mirror of
https://github.com/dashpay/dash.git
synced 2024-12-26 12:32:48 +01:00
qt: Decouple transaction label updates from transaction status updates (#3994)
* qt: Decouple tx label updates from tx status updates * Update src/qt/transactionrecord.cpp Co-authored-by: dustinface <35775977+xdustinface@users.noreply.github.com> Co-authored-by: dustinface <35775977+xdustinface@users.noreply.github.com>
This commit is contained in:
parent
6ec8b9a5c8
commit
ebea362d06
@ -26,7 +26,7 @@ bool TransactionRecord::showTransaction()
|
|||||||
/*
|
/*
|
||||||
* Decompose CWallet transaction to model transaction records.
|
* Decompose CWallet transaction to model transaction records.
|
||||||
*/
|
*/
|
||||||
QList<TransactionRecord> TransactionRecord::decomposeTransaction(const interfaces::WalletTx& wtx)
|
QList<TransactionRecord> TransactionRecord::decomposeTransaction(interfaces::Wallet& wallet, const interfaces::WalletTx& wtx)
|
||||||
{
|
{
|
||||||
QList<TransactionRecord> parts;
|
QList<TransactionRecord> parts;
|
||||||
int64_t nTime = wtx.time;
|
int64_t nTime = wtx.time;
|
||||||
@ -59,6 +59,7 @@ QList<TransactionRecord> TransactionRecord::decomposeTransaction(const interface
|
|||||||
sub.type = TransactionRecord::RecvWithAddress;
|
sub.type = TransactionRecord::RecvWithAddress;
|
||||||
sub.strAddress = EncodeDestination(wtx.txout_address[i]);
|
sub.strAddress = EncodeDestination(wtx.txout_address[i]);
|
||||||
sub.txDest = wtx.txout_address[i];
|
sub.txDest = wtx.txout_address[i];
|
||||||
|
sub.updateLabel(wallet);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -118,6 +119,7 @@ QList<TransactionRecord> TransactionRecord::decomposeTransaction(const interface
|
|||||||
// Sent to Dash Address
|
// Sent to Dash Address
|
||||||
sub.strAddress = EncodeDestination(address);
|
sub.strAddress = EncodeDestination(address);
|
||||||
sub.txDest = address;
|
sub.txDest = address;
|
||||||
|
sub.updateLabel(wallet);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -210,6 +212,7 @@ QList<TransactionRecord> TransactionRecord::decomposeTransaction(const interface
|
|||||||
sub.type = TransactionRecord::SendToAddress;
|
sub.type = TransactionRecord::SendToAddress;
|
||||||
sub.strAddress = EncodeDestination(wtx.txout_address[nOut]);
|
sub.strAddress = EncodeDestination(wtx.txout_address[nOut]);
|
||||||
sub.txDest = wtx.txout_address[nOut];
|
sub.txDest = wtx.txout_address[nOut];
|
||||||
|
sub.updateLabel(wallet);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -330,6 +333,18 @@ bool TransactionRecord::statusUpdateNeeded(int numBlocks, int chainLockHeight) c
|
|||||||
|| (!status.lockedByChainLocks && status.cachedChainLockHeight != chainLockHeight);
|
|| (!status.lockedByChainLocks && status.cachedChainLockHeight != chainLockHeight);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TransactionRecord::updateLabel(interfaces::Wallet& wallet)
|
||||||
|
{
|
||||||
|
if (IsValidDestination(txDest)) {
|
||||||
|
std::string name;
|
||||||
|
if (wallet.getAddress(txDest, &name)) {
|
||||||
|
label = QString::fromStdString(name);
|
||||||
|
} else {
|
||||||
|
label = "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
QString TransactionRecord::getTxHash() const
|
QString TransactionRecord::getTxHash() const
|
||||||
{
|
{
|
||||||
return QString::fromStdString(hash.ToString());
|
return QString::fromStdString(hash.ToString());
|
||||||
|
@ -52,8 +52,6 @@ public:
|
|||||||
bool lockedByChainLocks;
|
bool lockedByChainLocks;
|
||||||
/// Sorting key based on status
|
/// Sorting key based on status
|
||||||
std::string sortKey;
|
std::string sortKey;
|
||||||
/// Label
|
|
||||||
QString label;
|
|
||||||
|
|
||||||
/** @name Generated (mined) transactions
|
/** @name Generated (mined) transactions
|
||||||
@{*/
|
@{*/
|
||||||
@ -129,7 +127,7 @@ public:
|
|||||||
/** Decompose CWallet transaction to model transaction records.
|
/** Decompose CWallet transaction to model transaction records.
|
||||||
*/
|
*/
|
||||||
static bool showTransaction();
|
static bool showTransaction();
|
||||||
static QList<TransactionRecord> decomposeTransaction(const interfaces::WalletTx& wtx);
|
static QList<TransactionRecord> decomposeTransaction(interfaces::Wallet& wallet, const interfaces::WalletTx& wtx);
|
||||||
|
|
||||||
/** @name Immutable transaction attributes
|
/** @name Immutable transaction attributes
|
||||||
@{*/
|
@{*/
|
||||||
@ -152,6 +150,9 @@ public:
|
|||||||
/** Whether the transaction was sent/received with a watch-only address */
|
/** Whether the transaction was sent/received with a watch-only address */
|
||||||
bool involvesWatchAddress;
|
bool involvesWatchAddress;
|
||||||
|
|
||||||
|
/// Label
|
||||||
|
QString label;
|
||||||
|
|
||||||
/** Return the unique identifier for this transaction (part) */
|
/** Return the unique identifier for this transaction (part) */
|
||||||
QString getTxHash() const;
|
QString getTxHash() const;
|
||||||
|
|
||||||
@ -165,6 +166,10 @@ public:
|
|||||||
/** Return whether a status update is needed.
|
/** Return whether a status update is needed.
|
||||||
*/
|
*/
|
||||||
bool statusUpdateNeeded(int numBlocks, int chainLockHeight) const;
|
bool statusUpdateNeeded(int numBlocks, int chainLockHeight) const;
|
||||||
|
|
||||||
|
/** Update label from address book.
|
||||||
|
*/
|
||||||
|
void updateLabel(interfaces::Wallet& wallet);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // BITCOIN_QT_TRANSACTIONRECORD_H
|
#endif // BITCOIN_QT_TRANSACTIONRECORD_H
|
||||||
|
@ -77,7 +77,7 @@ public:
|
|||||||
{
|
{
|
||||||
for (const auto& wtx : wallet.getWalletTxs()) {
|
for (const auto& wtx : wallet.getWalletTxs()) {
|
||||||
if (TransactionRecord::showTransaction()) {
|
if (TransactionRecord::showTransaction()) {
|
||||||
cachedWallet.append(TransactionRecord::decomposeTransaction(wtx));
|
cachedWallet.append(TransactionRecord::decomposeTransaction(wallet, wtx));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -132,7 +132,7 @@ public:
|
|||||||
}
|
}
|
||||||
// Added -- insert at the right position
|
// Added -- insert at the right position
|
||||||
QList<TransactionRecord> toInsert =
|
QList<TransactionRecord> toInsert =
|
||||||
TransactionRecord::decomposeTransaction(wtx);
|
TransactionRecord::decomposeTransaction(wallet, wtx);
|
||||||
if(!toInsert.isEmpty()) /* only if something to insert */
|
if(!toInsert.isEmpty()) /* only if something to insert */
|
||||||
{
|
{
|
||||||
parent->beginInsertRows(QModelIndex(), lowerIndex, lowerIndex+toInsert.size()-1);
|
parent->beginInsertRows(QModelIndex(), lowerIndex, lowerIndex+toInsert.size()-1);
|
||||||
@ -169,13 +169,13 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void updateAddressBook(const QString& address, const QString& label, bool isMine, const QString& purpose, int status)
|
void updateAddressBook(interfaces::Wallet& wallet, const QString& address, const QString& label, bool isMine, const QString& purpose, int status)
|
||||||
{
|
{
|
||||||
std::string address2 = address.toStdString();
|
std::string address2 = address.toStdString();
|
||||||
int index = 0;
|
int index = 0;
|
||||||
for (auto& rec : cachedWallet) {
|
for (auto& rec : cachedWallet) {
|
||||||
if (rec.strAddress == address2) {
|
if (rec.strAddress == address2) {
|
||||||
rec.status.needsUpdate = true;
|
rec.updateLabel(wallet);
|
||||||
Q_EMIT parent->dataChanged(parent->index(index, TransactionTableModel::ToAddress), parent->index(index, TransactionTableModel::ToAddress));
|
Q_EMIT parent->dataChanged(parent->index(index, TransactionTableModel::ToAddress), parent->index(index, TransactionTableModel::ToAddress));
|
||||||
}
|
}
|
||||||
index++;
|
index++;
|
||||||
@ -204,15 +204,6 @@ public:
|
|||||||
int64_t adjustedTime;
|
int64_t adjustedTime;
|
||||||
if (rec->statusUpdateNeeded(numBlocks, parent->getChainLockHeight()) && wallet.tryGetTxStatus(rec->hash, wtx, adjustedTime)) {
|
if (rec->statusUpdateNeeded(numBlocks, parent->getChainLockHeight()) && wallet.tryGetTxStatus(rec->hash, wtx, adjustedTime)) {
|
||||||
rec->updateStatus(wtx, numBlocks, adjustedTime, parent->getChainLockHeight());
|
rec->updateStatus(wtx, numBlocks, adjustedTime, parent->getChainLockHeight());
|
||||||
// Update label
|
|
||||||
if (IsValidDestination(rec->txDest)) {
|
|
||||||
std::string name;
|
|
||||||
if (wallet.getAddress(rec->txDest, &name)) {
|
|
||||||
rec->status.label = QString::fromStdString(name);
|
|
||||||
} else {
|
|
||||||
rec->status.label = "";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return rec;
|
return rec;
|
||||||
}
|
}
|
||||||
@ -274,7 +265,7 @@ void TransactionTableModel::updateTransaction(const QString &hash, int status, b
|
|||||||
void TransactionTableModel::updateAddressBook(const QString& address, const QString& label, bool isMine,
|
void TransactionTableModel::updateAddressBook(const QString& address, const QString& label, bool isMine,
|
||||||
const QString& purpose, int status)
|
const QString& purpose, int status)
|
||||||
{
|
{
|
||||||
priv->updateAddressBook(address, label, isMine, purpose, status);
|
priv->updateAddressBook(walletModel->wallet(), address, label, isMine, purpose, status);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransactionTableModel::updateConfirmations()
|
void TransactionTableModel::updateConfirmations()
|
||||||
@ -439,7 +430,7 @@ QString TransactionTableModel::formatTxToAddress(const TransactionRecord *wtx, b
|
|||||||
case TransactionRecord::SendToAddress:
|
case TransactionRecord::SendToAddress:
|
||||||
case TransactionRecord::Generated:
|
case TransactionRecord::Generated:
|
||||||
case TransactionRecord::PrivateSend:
|
case TransactionRecord::PrivateSend:
|
||||||
return formatAddressLabel(wtx->strAddress, wtx->status.label, tooltip) + watchAddress;
|
return formatAddressLabel(wtx->strAddress, wtx->label, tooltip) + watchAddress;
|
||||||
case TransactionRecord::SendToOther:
|
case TransactionRecord::SendToOther:
|
||||||
return QString::fromStdString(wtx->strAddress) + watchAddress;
|
return QString::fromStdString(wtx->strAddress) + watchAddress;
|
||||||
case TransactionRecord::SendToSelf:
|
case TransactionRecord::SendToSelf:
|
||||||
@ -459,7 +450,7 @@ QVariant TransactionTableModel::addressColor(const TransactionRecord *wtx) const
|
|||||||
case TransactionRecord::PrivateSend:
|
case TransactionRecord::PrivateSend:
|
||||||
case TransactionRecord::RecvWithPrivateSend:
|
case TransactionRecord::RecvWithPrivateSend:
|
||||||
{
|
{
|
||||||
if (wtx->status.label.isEmpty()) {
|
if (wtx->label.isEmpty()) {
|
||||||
return GUIUtil::getThemedQColor(GUIUtil::ThemedColor::BAREADDRESS);
|
return GUIUtil::getThemedQColor(GUIUtil::ThemedColor::BAREADDRESS);
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
@ -653,7 +644,7 @@ QVariant TransactionTableModel::data(const QModelIndex &index, int role) const
|
|||||||
case AddressRole:
|
case AddressRole:
|
||||||
return QString::fromStdString(rec->strAddress);
|
return QString::fromStdString(rec->strAddress);
|
||||||
case LabelRole:
|
case LabelRole:
|
||||||
return rec->status.label;
|
return rec->label;
|
||||||
case AmountRole:
|
case AmountRole:
|
||||||
return qint64(rec->credit + rec->debit);
|
return qint64(rec->credit + rec->debit);
|
||||||
case TxHashRole:
|
case TxHashRole:
|
||||||
@ -663,7 +654,7 @@ QVariant TransactionTableModel::data(const QModelIndex &index, int role) const
|
|||||||
case TxPlainTextRole:
|
case TxPlainTextRole:
|
||||||
{
|
{
|
||||||
QString details;
|
QString details;
|
||||||
QString txLabel = rec->status.label;
|
QString txLabel = rec->label;
|
||||||
|
|
||||||
details.append(formatTxDate(rec));
|
details.append(formatTxDate(rec));
|
||||||
details.append(" ");
|
details.append(" ");
|
||||||
|
Loading…
Reference in New Issue
Block a user