aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWladimir J. van der Laan <laanwj@gmail.com>2011-06-01 15:50:09 +0200
committerWladimir J. van der Laan <laanwj@gmail.com>2011-06-01 17:15:43 +0200
commitf96681c5e440e1ebbcb8c79d868a14c2c51c5298 (patch)
tree1bc91e066bcf067408b010a65f769b03fe20005a
parentc51f051257e678b3fd26efdd84a89329420c96f5 (diff)
downloadbitcoin-f96681c5e440e1ebbcb8c79d868a14c2c51c5298.tar.xz
beginning of address model
-rw-r--r--gui/include/addresstablemodel.h9
-rw-r--r--gui/src/addresstablemodel.cpp124
2 files changed, 112 insertions, 21 deletions
diff --git a/gui/include/addresstablemodel.h b/gui/include/addresstablemodel.h
index 97780c5428..81fad6db25 100644
--- a/gui/include/addresstablemodel.h
+++ b/gui/include/addresstablemodel.h
@@ -2,12 +2,16 @@
#define ADDRESSTABLEMODEL_H
#include <QAbstractTableModel>
+#include <QStringList>
+
+class AddressTablePriv;
class AddressTableModel : public QAbstractTableModel
{
Q_OBJECT
public:
explicit AddressTableModel(QObject *parent = 0);
+ ~AddressTableModel();
enum {
Label = 0, /* User specified label */
@@ -25,7 +29,10 @@ public:
int columnCount(const QModelIndex &parent) const;
QVariant data(const QModelIndex &index, int role) const;
QVariant headerData(int section, Qt::Orientation orientation, int role) const;
- Qt::ItemFlags flags(const QModelIndex &index) const;
+ QModelIndex index ( int row, int column, const QModelIndex & parent ) const;
+private:
+ AddressTablePriv *priv;
+ QStringList columns;
signals:
public slots:
diff --git a/gui/src/addresstablemodel.cpp b/gui/src/addresstablemodel.cpp
index aec29fa202..d1f1a9c848 100644
--- a/gui/src/addresstablemodel.cpp
+++ b/gui/src/addresstablemodel.cpp
@@ -4,26 +4,90 @@
const QString AddressTableModel::Send = "S";
const QString AddressTableModel::Receive = "R";
+struct AddressTableEntry
+{
+ enum Type {
+ Sending,
+ Receiving
+ };
+ Type type;
+ QString label;
+ QString address;
+
+ AddressTableEntry() {}
+ AddressTableEntry(Type type, const QString &label, const QString &address):
+ type(type), label(label), address(address) {}
+};
+
+/* Private implementation */
+struct AddressTablePriv
+{
+ QList<AddressTableEntry> cachedAddressTable;
+
+ void refreshAddressTable()
+ {
+ cachedAddressTable.clear();
+
+ }
+
+ void updateAddressTable()
+ {
+ CRITICAL_BLOCK(cs_mapKeys)
+ CRITICAL_BLOCK(cs_mapAddressBook)
+ {
+ BOOST_FOREACH(const PAIRTYPE(std::string, std::string)& item, mapAddressBook)
+ {
+ std::string strAddress = item.first;
+ std::string strName = item.second;
+ uint160 hash160;
+ bool fMine = (AddressToHash160(strAddress, hash160) && mapPubKeys.count(hash160));
+ cachedAddressTable.append(AddressTableEntry(fMine ? AddressTableEntry::Receiving : AddressTableEntry::Sending,
+ QString::fromStdString(strName),
+ QString::fromStdString(strAddress)));
+ }
+ }
+ }
+
+
+ int size()
+ {
+ return cachedAddressTable.size();
+ }
+
+ AddressTableEntry *index(int idx)
+ {
+ if(idx >= 0 && idx < cachedAddressTable.size())
+ {
+ return &cachedAddressTable[idx];
+ } else {
+ return 0;
+ }
+ }
+};
+
AddressTableModel::AddressTableModel(QObject *parent) :
- QAbstractTableModel(parent)
+ QAbstractTableModel(parent),priv(0)
{
+ columns << tr("Label") << tr("Address");
+ priv = new AddressTablePriv();
+ priv->refreshAddressTable();
+}
+AddressTableModel::~AddressTableModel()
+{
+ delete priv;
}
int AddressTableModel::rowCount(const QModelIndex &parent) const
{
Q_UNUSED(parent);
- int retval = 0;
- CRITICAL_BLOCK(cs_mapAddressBook)
- {
- retval = mapAddressBook.size();
- }
- return retval;
+ return priv->size();
}
int AddressTableModel::columnCount(const QModelIndex &parent) const
{
- return 2;
+ Q_UNUSED(parent);
+ return columns.length();
}
QVariant AddressTableModel::data(const QModelIndex &index, int role) const
@@ -31,20 +95,28 @@ QVariant AddressTableModel::data(const QModelIndex &index, int role) const
if(!index.isValid())
return QVariant();
+ AddressTableEntry *rec = static_cast<AddressTableEntry*>(index.internalPointer());
+
if(role == Qt::DisplayRole)
{
/* index.row(), index.column() */
/* Return QString */
- if(index.column() == Address)
- return "1PC9aZC4hNX2rmmrt7uHTfYAS3hRbph4UN" + QString::number(index.row());
- else
- return "Description";
+ switch(index.column())
+ {
+ case Label:
+ return rec->label;
+ case Address:
+ return rec->address;
+ }
} else if (role == TypeRole)
{
- switch(index.row() % 2)
+ switch(rec->type)
{
- case 0: return Send;
- case 1: return Receive;
+ case AddressTableEntry::Sending:
+ return Send;
+ case AddressTableEntry::Receiving:
+ return Receive;
+ default: break;
}
}
return QVariant();
@@ -52,13 +124,25 @@ QVariant AddressTableModel::data(const QModelIndex &index, int role) const
QVariant AddressTableModel::headerData(int section, Qt::Orientation orientation, int role) const
{
+ if(orientation == Qt::Horizontal)
+ {
+ if(role == Qt::DisplayRole)
+ {
+ return columns[section];
+ }
+ }
return QVariant();
}
-Qt::ItemFlags AddressTableModel::flags(const QModelIndex &index) const
+QModelIndex AddressTableModel::index ( int row, int column, const QModelIndex & parent ) const
{
- if (!index.isValid())
- return Qt::ItemIsEnabled;
-
- return QAbstractTableModel::flags(index);
+ Q_UNUSED(parent);
+ AddressTableEntry *data = priv->index(row);
+ if(data)
+ {
+ return createIndex(row, column, priv->index(row));
+ } else {
+ return QModelIndex();
+ }
}
+