qt: GUI for conflicted transactions
- Exclamation mark icon for conflicted transactions - Show mouseover status for conflicted transactions as "conflicted" - Don't show inactive transactions on overview page overview
This commit is contained in:
parent
2b72d46f42
commit
9a3d936fc2
10 changed files with 37 additions and 6 deletions
|
@ -243,6 +243,7 @@ RES_ICONS = \
|
||||||
res/icons/toolbar_testnet.png \
|
res/icons/toolbar_testnet.png \
|
||||||
res/icons/transaction0.png \
|
res/icons/transaction0.png \
|
||||||
res/icons/transaction2.png \
|
res/icons/transaction2.png \
|
||||||
|
res/icons/transaction_conflicted.png \
|
||||||
res/icons/tx_inout.png \
|
res/icons/tx_inout.png \
|
||||||
res/icons/tx_input.png \
|
res/icons/tx_input.png \
|
||||||
res/icons/tx_output.png \
|
res/icons/tx_output.png \
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
<file alias="connect_4">res/icons/connect4_16.png</file>
|
<file alias="connect_4">res/icons/connect4_16.png</file>
|
||||||
<file alias="transaction_0">res/icons/transaction0.png</file>
|
<file alias="transaction_0">res/icons/transaction0.png</file>
|
||||||
<file alias="transaction_confirmed">res/icons/transaction2.png</file>
|
<file alias="transaction_confirmed">res/icons/transaction2.png</file>
|
||||||
|
<file alias="transaction_conflicted">res/icons/transaction_conflicted.png</file>
|
||||||
<file alias="transaction_1">res/icons/clock1.png</file>
|
<file alias="transaction_1">res/icons/clock1.png</file>
|
||||||
<file alias="transaction_2">res/icons/clock2.png</file>
|
<file alias="transaction_2">res/icons/clock2.png</file>
|
||||||
<file alias="transaction_3">res/icons/clock3.png</file>
|
<file alias="transaction_3">res/icons/clock3.png</file>
|
||||||
|
|
|
@ -175,6 +175,7 @@ void OverviewPage::setWalletModel(WalletModel *model)
|
||||||
filter->setLimit(NUM_ITEMS);
|
filter->setLimit(NUM_ITEMS);
|
||||||
filter->setDynamicSortFilter(true);
|
filter->setDynamicSortFilter(true);
|
||||||
filter->setSortRole(Qt::EditRole);
|
filter->setSortRole(Qt::EditRole);
|
||||||
|
filter->setShowInactive(false);
|
||||||
filter->sort(TransactionTableModel::Status, Qt::DescendingOrder);
|
filter->sort(TransactionTableModel::Status, Qt::DescendingOrder);
|
||||||
|
|
||||||
ui->listTransactions->setModel(filter);
|
ui->listTransactions->setModel(filter);
|
||||||
|
|
BIN
src/qt/res/icons/transaction_conflicted.png
Normal file
BIN
src/qt/res/icons/transaction_conflicted.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 474 B |
|
@ -5,6 +5,7 @@
|
||||||
#include "transactionfilterproxy.h"
|
#include "transactionfilterproxy.h"
|
||||||
|
|
||||||
#include "transactiontablemodel.h"
|
#include "transactiontablemodel.h"
|
||||||
|
#include "transactionrecord.h"
|
||||||
|
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
|
||||||
|
@ -22,7 +23,8 @@ TransactionFilterProxy::TransactionFilterProxy(QObject *parent) :
|
||||||
addrPrefix(),
|
addrPrefix(),
|
||||||
typeFilter(ALL_TYPES),
|
typeFilter(ALL_TYPES),
|
||||||
minAmount(0),
|
minAmount(0),
|
||||||
limitRows(-1)
|
limitRows(-1),
|
||||||
|
showInactive(true)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,7 +37,10 @@ bool TransactionFilterProxy::filterAcceptsRow(int sourceRow, const QModelIndex &
|
||||||
QString address = index.data(TransactionTableModel::AddressRole).toString();
|
QString address = index.data(TransactionTableModel::AddressRole).toString();
|
||||||
QString label = index.data(TransactionTableModel::LabelRole).toString();
|
QString label = index.data(TransactionTableModel::LabelRole).toString();
|
||||||
qint64 amount = llabs(index.data(TransactionTableModel::AmountRole).toLongLong());
|
qint64 amount = llabs(index.data(TransactionTableModel::AmountRole).toLongLong());
|
||||||
|
int status = index.data(TransactionTableModel::StatusRole).toInt();
|
||||||
|
|
||||||
|
if(!showInactive && status == TransactionStatus::Conflicted)
|
||||||
|
return false;
|
||||||
if(!(TYPE(type) & typeFilter))
|
if(!(TYPE(type) & typeFilter))
|
||||||
return false;
|
return false;
|
||||||
if(datetime < dateFrom || datetime > dateTo)
|
if(datetime < dateFrom || datetime > dateTo)
|
||||||
|
@ -78,6 +83,12 @@ void TransactionFilterProxy::setLimit(int limit)
|
||||||
this->limitRows = limit;
|
this->limitRows = limit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TransactionFilterProxy::setShowInactive(bool showInactive)
|
||||||
|
{
|
||||||
|
this->showInactive = showInactive;
|
||||||
|
invalidateFilter();
|
||||||
|
}
|
||||||
|
|
||||||
int TransactionFilterProxy::rowCount(const QModelIndex &parent) const
|
int TransactionFilterProxy::rowCount(const QModelIndex &parent) const
|
||||||
{
|
{
|
||||||
if(limitRows != -1)
|
if(limitRows != -1)
|
||||||
|
|
|
@ -36,6 +36,9 @@ public:
|
||||||
/** Set maximum number of rows returned, -1 if unlimited. */
|
/** Set maximum number of rows returned, -1 if unlimited. */
|
||||||
void setLimit(int limit);
|
void setLimit(int limit);
|
||||||
|
|
||||||
|
/** Set whether to show conflicted transactions. */
|
||||||
|
void setShowInactive(bool showInactive);
|
||||||
|
|
||||||
int rowCount(const QModelIndex &parent = QModelIndex()) const;
|
int rowCount(const QModelIndex &parent = QModelIndex()) const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -48,6 +51,7 @@ private:
|
||||||
quint32 typeFilter;
|
quint32 typeFilter;
|
||||||
qint64 minAmount;
|
qint64 minAmount;
|
||||||
int limitRows;
|
int limitRows;
|
||||||
|
bool showInactive;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // TRANSACTIONFILTERPROXY_H
|
#endif // TRANSACTIONFILTERPROXY_H
|
||||||
|
|
|
@ -183,7 +183,11 @@ void TransactionRecord::updateStatus(const CWalletTx &wtx)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (GetAdjustedTime() - wtx.nTimeReceived > 2 * 60 && wtx.GetRequestCount() == 0)
|
if (status.depth < 0)
|
||||||
|
{
|
||||||
|
status.status = TransactionStatus::Conflicted;
|
||||||
|
}
|
||||||
|
else if (GetAdjustedTime() - wtx.nTimeReceived > 2 * 60 && wtx.GetRequestCount() == 0)
|
||||||
{
|
{
|
||||||
status.status = TransactionStatus::Offline;
|
status.status = TransactionStatus::Offline;
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,8 @@ public:
|
||||||
OpenUntilBlock,
|
OpenUntilBlock,
|
||||||
Offline,
|
Offline,
|
||||||
Unconfirmed,
|
Unconfirmed,
|
||||||
HaveConfirmations
|
HaveConfirmations,
|
||||||
|
Conflicted
|
||||||
};
|
};
|
||||||
|
|
||||||
bool confirmed;
|
bool confirmed;
|
||||||
|
|
|
@ -312,7 +312,7 @@ QString TransactionTableModel::formatTxStatus(const TransactionRecord *wtx) cons
|
||||||
status = tr("Open until %1").arg(GUIUtil::dateTimeStr(wtx->status.open_for));
|
status = tr("Open until %1").arg(GUIUtil::dateTimeStr(wtx->status.open_for));
|
||||||
break;
|
break;
|
||||||
case TransactionStatus::Offline:
|
case TransactionStatus::Offline:
|
||||||
status = tr("Offline (%1 confirmations)").arg(wtx->status.depth);
|
status = tr("Offline");
|
||||||
break;
|
break;
|
||||||
case TransactionStatus::Unconfirmed:
|
case TransactionStatus::Unconfirmed:
|
||||||
status = tr("Unconfirmed (%1 of %2 confirmations)").arg(wtx->status.depth).arg(TransactionRecord::NumConfirmations);
|
status = tr("Unconfirmed (%1 of %2 confirmations)").arg(wtx->status.depth).arg(TransactionRecord::NumConfirmations);
|
||||||
|
@ -320,6 +320,9 @@ QString TransactionTableModel::formatTxStatus(const TransactionRecord *wtx) cons
|
||||||
case TransactionStatus::HaveConfirmations:
|
case TransactionStatus::HaveConfirmations:
|
||||||
status = tr("Confirmed (%1 confirmations)").arg(wtx->status.depth);
|
status = tr("Confirmed (%1 confirmations)").arg(wtx->status.depth);
|
||||||
break;
|
break;
|
||||||
|
case TransactionStatus::Conflicted:
|
||||||
|
status = tr("Conflicted");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -471,7 +474,6 @@ QVariant TransactionTableModel::txStatusDecoration(const TransactionRecord *wtx)
|
||||||
case TransactionStatus::OpenUntilBlock:
|
case TransactionStatus::OpenUntilBlock:
|
||||||
case TransactionStatus::OpenUntilDate:
|
case TransactionStatus::OpenUntilDate:
|
||||||
return QColor(64,64,255);
|
return QColor(64,64,255);
|
||||||
break;
|
|
||||||
case TransactionStatus::Offline:
|
case TransactionStatus::Offline:
|
||||||
return QColor(192,192,192);
|
return QColor(192,192,192);
|
||||||
case TransactionStatus::Unconfirmed:
|
case TransactionStatus::Unconfirmed:
|
||||||
|
@ -486,6 +488,8 @@ QVariant TransactionTableModel::txStatusDecoration(const TransactionRecord *wtx)
|
||||||
};
|
};
|
||||||
case TransactionStatus::HaveConfirmations:
|
case TransactionStatus::HaveConfirmations:
|
||||||
return QIcon(":/icons/transaction_confirmed");
|
return QIcon(":/icons/transaction_confirmed");
|
||||||
|
case TransactionStatus::Conflicted:
|
||||||
|
return QIcon(":/icons/transaction_conflicted");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return QColor(0,0,0);
|
return QColor(0,0,0);
|
||||||
|
@ -587,6 +591,8 @@ QVariant TransactionTableModel::data(const QModelIndex &index, int role) const
|
||||||
rec->status.maturity != TransactionStatus::Mature);
|
rec->status.maturity != TransactionStatus::Mature);
|
||||||
case FormattedAmountRole:
|
case FormattedAmountRole:
|
||||||
return formatTxAmount(rec, false);
|
return formatTxAmount(rec, false);
|
||||||
|
case StatusRole:
|
||||||
|
return rec->status.status;
|
||||||
}
|
}
|
||||||
return QVariant();
|
return QVariant();
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,7 +53,9 @@ public:
|
||||||
/** Is transaction confirmed? */
|
/** Is transaction confirmed? */
|
||||||
ConfirmedRole,
|
ConfirmedRole,
|
||||||
/** Formatted amount, without brackets when unconfirmed */
|
/** Formatted amount, without brackets when unconfirmed */
|
||||||
FormattedAmountRole
|
FormattedAmountRole,
|
||||||
|
/** Transaction status (TransactionRecord::Status) */
|
||||||
|
StatusRole
|
||||||
};
|
};
|
||||||
|
|
||||||
int rowCount(const QModelIndex &parent) const;
|
int rowCount(const QModelIndex &parent) const;
|
||||||
|
|
Loading…
Add table
Reference in a new issue