bitcoin/src/qt/bitcoingui.h

355 lines
12 KiB
C
Raw Normal View History

// Copyright (c) 2011-2020 The Bitcoin Core developers
2014-12-13 12:09:33 +08:00
// Distributed under the MIT software license, see the accompanying
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
2014-11-03 16:16:40 +01:00
#ifndef BITCOIN_QT_BITCOINGUI_H
#define BITCOIN_QT_BITCOINGUI_H
2011-05-07 22:13:39 +02:00
#if defined(HAVE_CONFIG_H)
#include <config/bitcoin-config.h>
#endif
#include <qt/optionsdialog.h>
#include <amount.h>
2014-04-22 15:46:19 -07:00
#include <QLabel>
2011-05-07 22:13:39 +02:00
#include <QMainWindow>
#include <QMap>
#include <QPoint>
#include <QSystemTrayIcon>
2011-05-12 20:16:42 +02:00
#ifdef Q_OS_MAC
#include <qt/macos_appnap.h>
#endif
#include <memory>
class ClientModel;
class NetworkStyle;
class Notificator;
class OptionsModel;
class PlatformStyle;
2012-04-09 21:07:25 +02:00
class RPCConsole;
class SendCoinsRecipient;
2014-07-04 16:51:25 +02:00
class UnitDisplayStatusBarControl;
2019-01-04 18:49:48 +00:00
class WalletController;
class WalletFrame;
class WalletModel;
2015-08-27 15:53:16 -04:00
class HelpMessageDialog;
2016-07-19 15:51:24 +02:00
class ModalOverlay;
enum class SynchronizationState;
2011-05-13 22:00:27 +02:00
namespace interfaces {
class Handler;
class Node;
struct BlockAndHeaderTipInfo;
}
2011-05-13 22:00:27 +02:00
QT_BEGIN_NAMESPACE
class QAction;
class QComboBox;
class QMenu;
class QProgressBar;
2014-05-23 18:04:09 +02:00
class QProgressDialog;
2011-05-13 22:00:27 +02:00
QT_END_NAMESPACE
2011-05-07 22:13:39 +02:00
namespace GUIUtil {
class ClickableLabel;
2018-06-24 16:18:22 +01:00
class ClickableProgressBar;
}
2011-11-13 11:12:33 +01: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 22:13:39 +02:00
class BitcoinGUI : public QMainWindow
{
Q_OBJECT
2011-05-07 22:13:39 +02:00
public:
static const std::string DEFAULT_UIPLATFORM;
explicit BitcoinGUI(interfaces::Node& node, const PlatformStyle *platformStyle, const NetworkStyle *networkStyle, QWidget *parent = nullptr);
~BitcoinGUI();
2011-11-13 11:12:33 +01: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 = nullptr, interfaces::BlockAndHeaderTipInfo* tip_info = nullptr);
2019-01-04 18:49:48 +00:00
#ifdef ENABLE_WALLET
void setWalletController(WalletController* wallet_controller);
#endif
#ifdef ENABLE_WALLET
2011-11-13 11:12:33 +01: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.
*/
void addWallet(WalletModel* walletModel);
void removeWallet(WalletModel* walletModel);
void removeAllWallets();
#endif // ENABLE_WALLET
bool enableWallet = false;
/** Get the tray icon status.
Some systems have not "system tray" or "notification area" available.
*/
bool hasTrayIcon() const { return trayIcon; }
/** Disconnect core signals from GUI client */
void unsubscribeFromCoreSignals();
bool isPrivacyModeActivated() const;
protected:
void changeEvent(QEvent *e) override;
void closeEvent(QCloseEvent *event) override;
void showEvent(QShowEvent *event) override;
void dragEnterEvent(QDragEnterEvent *event) override;
void dropEvent(QDropEvent *event) override;
bool eventFilter(QObject *object, QEvent *event) override;
2011-05-12 20:16:42 +02:00
private:
interfaces::Node& m_node;
2019-01-04 18:49:48 +00:00
WalletController* m_wallet_controller{nullptr};
std::unique_ptr<interfaces::Handler> m_handler_message_box;
std::unique_ptr<interfaces::Handler> m_handler_question;
ClientModel* clientModel = nullptr;
WalletFrame* walletFrame = nullptr;
UnitDisplayStatusBarControl* unitDisplayControl = nullptr;
QLabel* labelWalletEncryptionIcon = nullptr;
QLabel* labelWalletHDStatusIcon = nullptr;
GUIUtil::ClickableLabel* labelProxyIcon = nullptr;
GUIUtil::ClickableLabel* connectionsControl = nullptr;
2018-06-24 16:18:22 +01:00
GUIUtil::ClickableLabel* labelBlocksIcon = nullptr;
QLabel* progressBarLabel = nullptr;
2018-06-24 16:18:22 +01:00
GUIUtil::ClickableProgressBar* progressBar = nullptr;
QProgressDialog* progressDialog = nullptr;
QMenuBar* appMenuBar = nullptr;
QToolBar* appToolBar = nullptr;
QAction* overviewAction = nullptr;
QAction* historyAction = nullptr;
QAction* quitAction = nullptr;
QAction* sendCoinsAction = nullptr;
QAction* sendCoinsMenuAction = nullptr;
QAction* usedSendingAddressesAction = nullptr;
QAction* usedReceivingAddressesAction = nullptr;
QAction* signMessageAction = nullptr;
QAction* verifyMessageAction = nullptr;
QAction* m_load_psbt_action = nullptr;
2020-01-31 15:59:57 -08:00
QAction* m_load_psbt_clipboard_action = nullptr;
QAction* aboutAction = nullptr;
QAction* receiveCoinsAction = nullptr;
QAction* receiveCoinsMenuAction = nullptr;
QAction* optionsAction = nullptr;
QAction* toggleHideAction = nullptr;
QAction* encryptWalletAction = nullptr;
QAction* backupWalletAction = nullptr;
QAction* changePassphraseAction = nullptr;
QAction* aboutQtAction = nullptr;
QAction* openRPCConsoleAction = nullptr;
QAction* openAction = nullptr;
QAction* showHelpMessageAction = nullptr;
QAction* m_create_wallet_action{nullptr};
2019-01-12 11:40:30 +00:00
QAction* m_open_wallet_action{nullptr};
QMenu* m_open_wallet_menu{nullptr};
2019-01-18 00:22:32 +00:00
QAction* m_close_wallet_action{nullptr};
2019-01-18 01:05:45 +00:00
QAction* m_close_all_wallets_action{nullptr};
QAction* m_wallet_selector_label_action = nullptr;
QAction* m_wallet_selector_action = nullptr;
QAction* m_mask_values_action{nullptr};
QLabel *m_wallet_selector_label = nullptr;
QComboBox* m_wallet_selector = nullptr;
QSystemTrayIcon* trayIcon = nullptr;
const std::unique_ptr<QMenu> trayIconMenu;
Notificator* notificator = nullptr;
RPCConsole* rpcConsole = nullptr;
HelpMessageDialog* helpMessageDialog = nullptr;
ModalOverlay* modalOverlay = nullptr;
2011-05-12 20:16:42 +02:00
#ifdef Q_OS_MAC
CAppNapInhibitor* m_app_nap_inhibitor = nullptr;
#endif
/** Keep track of previous number of blocks, to detect progress */
int prevBlocks = 0;
int spinnerFrame = 0;
const PlatformStyle *platformStyle;
2019-01-11 23:48:58 +00:00
const NetworkStyle* const m_network_style;
2011-11-13 11:12:33 +01:00
/** Create the main UI actions. */
2015-03-03 08:42:52 +01:00
void createActions();
2012-07-26 00:48:39 +00:00
/** Create the menu bar and sub-menus. */
void createMenuBar();
2011-11-13 11:12:33 +01:00
/** Create the toolbars */
void createToolBars();
/** Create system tray icon and notification */
2019-01-11 23:48:58 +00:00
void createTrayIcon();
/** Create system tray menu (or setup the dock menu) */
void createTrayIconMenu();
2011-05-12 20:16:42 +02:00
/** Enable or disable all wallet-related actions */
void setWalletActionsEnabled(bool enabled);
/** Connect core signals to GUI client */
void subscribeToCoreSignals();
/** Update UI with latest network info from model. */
void updateNetworkState();
void updateHeadersSyncProgressLabel();
/** Open the OptionsDialog on the specified tab index */
void openOptionsDialogWithTab(OptionsDialog::Tab tab);
Q_SIGNALS:
2013-11-06 15:08:56 +01:00
/** Signal raised when a URI was entered or dragged to the GUI */
void receivedURI(const QString &uri);
/** Signal raised when RPC console shown */
void consoleShown(RPCConsole* console);
void setPrivacy(bool privacy);
2013-11-06 15:08:56 +01:00
public Q_SLOTS:
2011-11-13 11:12:33 +01:00
/** Set number of connections shown in the UI */
void setNumConnections(int count);
/** Set network state shown in the UI */
void setNetworkActive(bool networkActive);
/** Set number of blocks and last block date shown in the UI */
void setNumBlocks(int count, const QDateTime& blockDate, double nVerificationProgress, bool headers, SynchronizationState sync_state);
/** 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)
@param[in] detailed_message the text to be displayed in the details area
*/
void message(const QString& title, QString message, unsigned int style, bool* ret = nullptr, const QString& detailed_message = QString());
#ifdef ENABLE_WALLET
void setCurrentWallet(WalletModel* wallet_model);
void setCurrentWalletBySelectorIndex(int index);
/** Set the UI status indicators based on the currently selected wallet.
*/
void updateWalletStatus();
private:
/** Set the encryption status as shown in the UI.
@param[in] status current encryption status
@see WalletModel::EncryptionStatus
*/
void setEncryptionStatus(int status);
/** Set the hd-enabled status as shown in the UI.
2018-08-08 21:12:14 +02:00
@param[in] hdEnabled current hd enabled status
@see WalletModel::EncryptionStatus
*/
void setHDStatus(bool privkeyDisabled, int hdEnabled);
public Q_SLOTS:
bool handlePaymentRequest(const SendCoinsRecipient& recipient);
/** Show incoming transaction notification for new transactions. */
void incomingTransaction(const QString& date, int unit, const CAmount& amount, const QString& type, const QString& address, const QString& label, const QString& walletName);
#endif // ENABLE_WALLET
2017-10-02 17:59:32 +03:00
private:
/** Set the proxy-enabled icon as shown in the UI. */
void updateProxyIcon();
void updateWindowTitle();
2017-10-02 17:59:32 +03:00
2018-06-24 16:18:22 +01:00
public Q_SLOTS:
#ifdef ENABLE_WALLET
2011-11-13 11:12:33 +01:00
/** Switch to overview (home) page */
2011-07-07 17:33:15 +02:00
void gotoOverviewPage();
2011-11-13 11:12:33 +01:00
/** Switch to history (transactions) page */
2011-07-07 17:33:15 +02:00
void gotoHistoryPage();
2011-11-13 11:12:33 +01:00
/** Switch to receive coins page */
2011-07-07 17:33:15 +02:00
void gotoReceiveCoinsPage();
2011-11-13 11:12:33 +01:00
/** Switch to send coins page */
void gotoSendCoinsPage(QString addr = "");
2011-07-07 17:33:15 +02: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 = "");
2020-01-31 15:59:57 -08:00
/** Load Partially Signed Bitcoin Transaction from file or clipboard */
void gotoLoadPSBT(bool from_clipboard = false);
/** Show open dialog */
void openClicked();
#endif // ENABLE_WALLET
2011-11-13 11:12:33 +01:00
/** Show configuration dialog */
2011-05-10 19:03:10 +02:00
void optionsClicked();
2011-11-13 11:12:33 +01:00
/** Show about dialog */
void aboutClicked();
/** Show debug window */
void showDebugWindow();
/** Show debug window and set focus to the console */
void showDebugWindowActivateConsole();
/** Show help message dialog */
void showHelpMessageClicked();
#ifndef Q_OS_MAC
2011-11-13 11:12:33 +01:00
/** Handle tray icon clicked */
void trayIconActivated(QSystemTrayIcon::ActivationReason reason);
#else
/** Handle macOS Dock icon clicked */
void macosDockIconActivated();
#endif
2012-02-17 23:19:52 +01:00
/** Show window if hidden, unminimize when minimized, rise when obscured or show if hidden and fToggleHidden is true */
2018-06-24 16:18:22 +01:00
void showNormalIfMinimized() { showNormalIfMinimized(false); }
void showNormalIfMinimized(bool fToggleHidden);
/** Simply calls showNormalIfMinimized(true) for use in SLOT() macro */
void toggleHidden();
/** called by a timer to check if ShutdownRequested() has been set **/
void detectShutdown();
2014-05-23 18:04:09 +02:00
/** Show progress dialog e.g. for verifychain */
void showProgress(const QString &title, int nProgress);
/** When hideTrayIcon setting is changed in OptionsModel hide or show the icon accordingly. */
void setTrayIconVisible(bool);
2016-07-19 15:51:24 +02:00
void showModalOverlay();
2011-05-07 22:13:39 +02:00
};
class UnitDisplayStatusBarControl : public QLabel
{
Q_OBJECT
public:
explicit UnitDisplayStatusBarControl(const PlatformStyle *platformStyle);
/** 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) override;
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 Q_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);
};
2014-11-03 16:16:40 +01:00
#endif // BITCOIN_QT_BITCOINGUI_H