bitcoin/src/qt/bitcoingui.h

240 lines
7.6 KiB
C
Raw Normal View History

// Copyright (c) 2011-2014 The Bitcoin developers
// Distributed under the MIT/X11 software license, see the accompanying
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
2011-05-08 16:23:31 -04:00
#ifndef BITCOINGUI_H
#define BITCOINGUI_H
2011-05-07 17:13:39 -03:00
#if defined(HAVE_CONFIG_H)
#include "config/bitcoin-config.h"
#endif
2014-04-22 19:46:19 -03:00
#include "amount.h"
#include <QLabel>
2011-05-07 17:13:39 -03:00
#include <QMainWindow>
#include <QMap>
#include <QMenu>
#include <QPoint>
#include <QSystemTrayIcon>
2011-05-12 14:16:42 -04:00
class ClientModel;
class NetworkStyle;
class Notificator;
class OptionsModel;
2012-04-09 16:07:25 -03:00
class RPCConsole;
class SendCoinsRecipient;
2014-07-04 10:51:25 -04:00
class UnitDisplayStatusBarControl;
class WalletFrame;
class WalletModel;
2011-05-13 16:00:27 -04:00
class CWallet;
2011-05-13 16:00:27 -04:00
QT_BEGIN_NAMESPACE
class QAction;
class QProgressBar;
2014-05-23 12:04:09 -04:00
class QProgressDialog;
2011-05-13 16:00:27 -04:00
QT_END_NAMESPACE
2011-05-07 17:13:39 -03:00
2011-11-13 07:12:33 -03:00
/**
Bitcoin GUI main class. This class represents the main window of the Bitcoin UI. It communicates with both the client and
wallet models to give the user an up-to-date view of the current core state.
*/
2011-05-07 17:13:39 -03:00
class BitcoinGUI : public QMainWindow
{
Q_OBJECT
2011-05-07 17:13:39 -03:00
public:
static const QString DEFAULT_WALLET;
explicit BitcoinGUI(const NetworkStyle *networkStyle, QWidget *parent = 0);
~BitcoinGUI();
2011-11-13 07:12:33 -03:00
/** Set the client model.
The client model represents the part of the core that communicates with the P2P network, and is wallet-agnostic.
*/
void setClientModel(ClientModel *clientModel);
#ifdef ENABLE_WALLET
2011-11-13 07:12:33 -03:00
/** Set the wallet model.
The wallet model represents a bitcoin wallet, and offers access to the list of transactions, address book and sending
functionality.
*/
bool addWallet(const QString& name, WalletModel *walletModel);
bool setCurrentWallet(const QString& name);
void removeAllWallets();
#endif
protected:
void changeEvent(QEvent *e);
void closeEvent(QCloseEvent *event);
void dragEnterEvent(QDragEnterEvent *event);
void dropEvent(QDropEvent *event);
bool eventFilter(QObject *object, QEvent *event);
2011-05-12 14:16:42 -04:00
private:
ClientModel *clientModel;
WalletFrame *walletFrame;
UnitDisplayStatusBarControl *unitDisplayControl;
QLabel *labelEncryptionIcon;
2011-06-14 15:34:51 -04:00
QLabel *labelConnectionsIcon;
QLabel *labelBlocksIcon;
QLabel *progressBarLabel;
QProgressBar *progressBar;
2014-05-23 12:04:09 -04:00
QProgressDialog *progressDialog;
2011-05-12 14:16:42 -04:00
QMenuBar *appMenuBar;
QAction *overviewAction;
QAction *historyAction;
2011-07-07 11:33:15 -04:00
QAction *quitAction;
QAction *sendCoinsAction;
2013-10-16 10:14:26 -03:00
QAction *usedSendingAddressesAction;
QAction *usedReceivingAddressesAction;
QAction *signMessageAction;
QAction *verifyMessageAction;
2011-07-07 11:33:15 -04:00
QAction *aboutAction;
QAction *receiveCoinsAction;
QAction *optionsAction;
QAction *toggleHideAction;
QAction *encryptWalletAction;
QAction *backupWalletAction;
QAction *changePassphraseAction;
QAction *aboutQtAction;
2012-04-09 16:07:25 -03:00
QAction *openRPCConsoleAction;
2013-11-06 11:08:56 -03:00
QAction *openAction;
QAction *showHelpMessageAction;
2011-05-12 14:16:42 -04:00
QSystemTrayIcon *trayIcon;
QMenu *trayIconMenu;
Notificator *notificator;
2012-04-09 16:07:25 -03:00
RPCConsole *rpcConsole;
2011-05-12 14:16:42 -04:00
/** Keep track of previous number of blocks, to detect progress */
int prevBlocks;
int spinnerFrame;
2011-11-13 07:12:33 -03:00
/** Create the main UI actions. */
void createActions(const NetworkStyle *networkStyle);
2012-07-25 20:48:39 -04:00
/** Create the menu bar and sub-menus. */
void createMenuBar();
2011-11-13 07:12:33 -03:00
/** Create the toolbars */
void createToolBars();
/** Create system tray icon and notification */
void createTrayIcon(const NetworkStyle *networkStyle);
/** Create system tray menu (or setup the dock menu) */
void createTrayIconMenu();
2011-05-12 14:16:42 -04:00
/** Enable or disable all wallet-related actions */
void setWalletActionsEnabled(bool enabled);
/** Connect core signals to GUI client */
void subscribeToCoreSignals();
/** Disconnect core signals from GUI client */
void unsubscribeFromCoreSignals();
2013-11-06 11:08:56 -03:00
signals:
/** Signal raised when a URI was entered or dragged to the GUI */
void receivedURI(const QString &uri);
public slots:
2011-11-13 07:12:33 -03:00
/** Set number of connections shown in the UI */
void setNumConnections(int count);
2011-11-13 07:12:33 -03:00
/** Set number of blocks shown in the UI */
void setNumBlocks(int count);
/** Notify the user of an event from the core network or transaction handling code.
@param[in] title the message box / notification title
@param[in] message the displayed text
@param[in] style modality and style definitions (icon and used buttons - buttons only for message boxes)
@see CClientUIInterface::MessageBoxFlags
@param[in] ret pointer to a bool that will be modified to whether Ok was clicked (modal only)
*/
void message(const QString &title, const QString &message, unsigned int style, bool *ret = NULL);
#ifdef ENABLE_WALLET
/** Set the encryption status as shown in the UI.
@param[in] status current encryption status
@see WalletModel::EncryptionStatus
*/
void setEncryptionStatus(int status);
bool handlePaymentRequest(const SendCoinsRecipient& recipient);
/** Show incoming transaction notification for new transactions. */
2014-04-22 19:46:19 -03:00
void incomingTransaction(const QString& date, int unit, const CAmount& amount, const QString& type, const QString& address);
#endif
2011-05-07 17:13:39 -03:00
private slots:
#ifdef ENABLE_WALLET
2011-11-13 07:12:33 -03:00
/** Switch to overview (home) page */
2011-07-07 11:33:15 -04:00
void gotoOverviewPage();
2011-11-13 07:12:33 -03:00
/** Switch to history (transactions) page */
2011-07-07 11:33:15 -04:00
void gotoHistoryPage();
2011-11-13 07:12:33 -03:00
/** Switch to receive coins page */
2011-07-07 11:33:15 -04:00
void gotoReceiveCoinsPage();
2011-11-13 07:12:33 -03:00
/** Switch to send coins page */
void gotoSendCoinsPage(QString addr = "");
2011-07-07 11:33:15 -04:00
/** Show Sign/Verify Message dialog and switch to sign message tab */
void gotoSignMessageTab(QString addr = "");
/** Show Sign/Verify Message dialog and switch to verify message tab */
void gotoVerifyMessageTab(QString addr = "");
/** Show open dialog */
void openClicked();
#endif
2011-11-13 07:12:33 -03:00
/** Show configuration dialog */
2011-05-10 13:03:10 -04:00
void optionsClicked();
2011-11-13 07:12:33 -03:00
/** Show about dialog */
void aboutClicked();
/** Show help message dialog */
void showHelpMessageClicked();
#ifndef Q_OS_MAC
2011-11-13 07:12:33 -03:00
/** Handle tray icon clicked */
void trayIconActivated(QSystemTrayIcon::ActivationReason reason);
#endif
2012-02-17 19:19:52 -03:00
/** Show window if hidden, unminimize when minimized, rise when obscured or show if hidden and fToggleHidden is true */
void showNormalIfMinimized(bool fToggleHidden = false);
/** Simply calls showNormalIfMinimized(true) for use in SLOT() macro */
void toggleHidden();
/** called by a timer to check if fRequestShutdown has been set **/
void detectShutdown();
2014-05-23 12:04:09 -04:00
/** Show progress dialog e.g. for verifychain */
void showProgress(const QString &title, int nProgress);
2011-05-07 17:13:39 -03:00
};
class UnitDisplayStatusBarControl : public QLabel
{
Q_OBJECT
public:
explicit UnitDisplayStatusBarControl();
/** Lets the control know about the Options Model (and its signals) */
void setOptionsModel(OptionsModel *optionsModel);
protected:
/** So that it responds to left-button clicks */
void mousePressEvent(QMouseEvent *event);
private:
OptionsModel *optionsModel;
QMenu* menu;
/** Shows context menu with Display Unit options by the mouse coordinates */
void onDisplayUnitsClicked(const QPoint& point);
/** Creates context menu, its actions, and wires up all the relevant signals for mouse events. */
void createContextMenu();
private slots:
/** When Display Units are changed on OptionsModel it will refresh the display text of the control on the status bar */
void updateDisplayUnit(int newUnits);
/** Tells underlying optionsModel to update its current display unit. */
void onMenuSelection(QAction* action);
};
#endif // BITCOINGUI_H