bb0726a8cf
- don't show QR Code context menu, when USE_QRCODE=1 was not specified when compiling the client - re-work on_showQRCode_clicked() for better readability and remove an unneeded duplicate check - re-work on_signMessage_clicked() and on_verifyMessage_clicked() to match foreach in on_showQRCode_clicked(), which seems more robust / cleaner - re-order context menu stuff to match real context menu layout - add comments for all private slots in the class
90 lines
2.6 KiB
C++
90 lines
2.6 KiB
C++
#ifndef ADDRESSBOOKPAGE_H
|
|
#define ADDRESSBOOKPAGE_H
|
|
|
|
#include <QDialog>
|
|
|
|
namespace Ui {
|
|
class AddressBookPage;
|
|
}
|
|
class AddressTableModel;
|
|
class OptionsModel;
|
|
|
|
QT_BEGIN_NAMESPACE
|
|
class QTableView;
|
|
class QItemSelection;
|
|
class QSortFilterProxyModel;
|
|
class QMenu;
|
|
class QModelIndex;
|
|
QT_END_NAMESPACE
|
|
|
|
/** Widget that shows a list of sending or receiving addresses.
|
|
*/
|
|
class AddressBookPage : public QDialog
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
enum Tabs {
|
|
SendingTab = 0,
|
|
ReceivingTab = 1
|
|
};
|
|
|
|
enum Mode {
|
|
ForSending, /**< Open address book to pick address for sending */
|
|
ForEditing /**< Open address book for editing */
|
|
};
|
|
|
|
explicit AddressBookPage(Mode mode, Tabs tab, QWidget *parent = 0);
|
|
~AddressBookPage();
|
|
|
|
void setModel(AddressTableModel *model);
|
|
void setOptionsModel(OptionsModel *optionsModel);
|
|
const QString &getReturnValue() const { return returnValue; }
|
|
|
|
public slots:
|
|
void done(int retval);
|
|
void exportClicked();
|
|
|
|
private:
|
|
Ui::AddressBookPage *ui;
|
|
AddressTableModel *model;
|
|
OptionsModel *optionsModel;
|
|
Mode mode;
|
|
Tabs tab;
|
|
QString returnValue;
|
|
QSortFilterProxyModel *proxyModel;
|
|
QMenu *contextMenu;
|
|
QAction *deleteAction; // to be able to explicitly disable it
|
|
QString newAddressToSelect;
|
|
|
|
private slots:
|
|
/** Delete currently selected address entry */
|
|
void on_deleteButton_clicked();
|
|
/** Create a new address for receiving coins and / or add a new address book entry */
|
|
void on_newAddressButton_clicked();
|
|
/** Copy address of currently selected address entry to clipboard */
|
|
void on_copyToClipboard_clicked();
|
|
/** Open the sign message tab in the Sign/Verify Message dialog with currently selected address */
|
|
void on_signMessage_clicked();
|
|
/** Open the verify message tab in the Sign/Verify Message dialog with currently selected address */
|
|
void on_verifyMessage_clicked();
|
|
/** Generate a QR Code from the currently selected address */
|
|
void on_showQRCode_clicked();
|
|
/** Copy label of currently selected address entry to clipboard (no button) */
|
|
void onCopyLabelAction();
|
|
/** Edit currently selected address entry (no button) */
|
|
void onEditAction();
|
|
|
|
/** Set button states based on selected tab and selection */
|
|
void selectionChanged();
|
|
/** Spawn contextual menu (right mouse menu) for address book entry */
|
|
void contextualMenu(const QPoint &point);
|
|
/** New entry/entries were added to address table */
|
|
void selectNewAddress(const QModelIndex &parent, int begin, int /*end*/);
|
|
|
|
signals:
|
|
void signMessage(QString addr);
|
|
void verifyMessage(QString addr);
|
|
};
|
|
|
|
#endif // ADDRESSBOOKPAGE_H
|