Merge pull request #6487
eec7757
qt: Introduce PlatformStyle (Wladimir J. van der Laan)
This commit is contained in:
commit
9848d4297b
37 changed files with 462 additions and 318 deletions
|
@ -185,13 +185,13 @@ BITCOIN_QT_H = \
|
|||
qt/paymentrequestplus.h \
|
||||
qt/paymentserver.h \
|
||||
qt/peertablemodel.h \
|
||||
qt/platformstyle.h \
|
||||
qt/qvalidatedlineedit.h \
|
||||
qt/qvaluecombobox.h \
|
||||
qt/receivecoinsdialog.h \
|
||||
qt/receiverequestdialog.h \
|
||||
qt/recentrequeststablemodel.h \
|
||||
qt/rpcconsole.h \
|
||||
qt/scicon.h \
|
||||
qt/sendcoinsdialog.h \
|
||||
qt/sendcoinsentry.h \
|
||||
qt/signverifymessagedialog.h \
|
||||
|
@ -273,10 +273,10 @@ BITCOIN_QT_CPP = \
|
|||
qt/optionsdialog.cpp \
|
||||
qt/optionsmodel.cpp \
|
||||
qt/peertablemodel.cpp \
|
||||
qt/platformstyle.cpp \
|
||||
qt/qvalidatedlineedit.cpp \
|
||||
qt/qvaluecombobox.cpp \
|
||||
qt/rpcconsole.cpp \
|
||||
qt/scicon.cpp \
|
||||
qt/splashscreen.cpp \
|
||||
qt/trafficgraphwidget.cpp \
|
||||
qt/utilitydialog.cpp
|
||||
|
|
|
@ -441,6 +441,9 @@ std::string HelpMessage(HelpMessageMode mode)
|
|||
strUsage += HelpMessageOpt("-min", _("Start minimized"));
|
||||
strUsage += HelpMessageOpt("-rootcertificates=<file>", _("Set SSL root certificates for payment request (default: -system-)"));
|
||||
strUsage += HelpMessageOpt("-splash", _("Show splash screen on startup (default: 1)"));
|
||||
if (showDebug) {
|
||||
strUsage += HelpMessageOpt("-uiplatform", "Select platform to customize UI for (one of windows, macosx, other; default: platform compiled on)");
|
||||
}
|
||||
}
|
||||
|
||||
return strUsage;
|
||||
|
|
|
@ -14,14 +14,14 @@
|
|||
#include "csvmodelwriter.h"
|
||||
#include "editaddressdialog.h"
|
||||
#include "guiutil.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
|
||||
#include <QIcon>
|
||||
#include <QMenu>
|
||||
#include <QMessageBox>
|
||||
#include <QSortFilterProxyModel>
|
||||
|
||||
AddressBookPage::AddressBookPage(Mode mode, Tabs tab, QWidget *parent) :
|
||||
AddressBookPage::AddressBookPage(const PlatformStyle *platformStyle, Mode mode, Tabs tab, QWidget *parent) :
|
||||
QDialog(parent),
|
||||
ui(new Ui::AddressBookPage),
|
||||
model(0),
|
||||
|
@ -30,17 +30,17 @@ AddressBookPage::AddressBookPage(Mode mode, Tabs tab, QWidget *parent) :
|
|||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
#ifdef Q_OS_MAC // Icons on push buttons are very uncommon on Mac
|
||||
ui->newAddress->setIcon(QIcon());
|
||||
ui->copyAddress->setIcon(QIcon());
|
||||
ui->deleteAddress->setIcon(QIcon());
|
||||
ui->exportButton->setIcon(QIcon());
|
||||
#else
|
||||
ui->newAddress->setIcon(SingleColorIcon(":/icons/add"));
|
||||
ui->copyAddress->setIcon(SingleColorIcon(":/icons/editcopy"));
|
||||
ui->deleteAddress->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->exportButton->setIcon(SingleColorIcon(":/icons/export"));
|
||||
#endif
|
||||
if (!platformStyle->getImagesOnButtons()) {
|
||||
ui->newAddress->setIcon(QIcon());
|
||||
ui->copyAddress->setIcon(QIcon());
|
||||
ui->deleteAddress->setIcon(QIcon());
|
||||
ui->exportButton->setIcon(QIcon());
|
||||
} else {
|
||||
ui->newAddress->setIcon(platformStyle->SingleColorIcon(":/icons/add"));
|
||||
ui->copyAddress->setIcon(platformStyle->SingleColorIcon(":/icons/editcopy"));
|
||||
ui->deleteAddress->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
ui->exportButton->setIcon(platformStyle->SingleColorIcon(":/icons/export"));
|
||||
}
|
||||
|
||||
switch(mode)
|
||||
{
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
|
||||
class AddressTableModel;
|
||||
class OptionsModel;
|
||||
class PlatformStyle;
|
||||
|
||||
namespace Ui {
|
||||
class AddressBookPage;
|
||||
|
@ -39,7 +40,7 @@ public:
|
|||
ForEditing /**< Open address book for editing */
|
||||
};
|
||||
|
||||
explicit AddressBookPage(Mode mode, Tabs tab, QWidget *parent);
|
||||
explicit AddressBookPage(const PlatformStyle *platformStyle, Mode mode, Tabs tab, QWidget *parent);
|
||||
~AddressBookPage();
|
||||
|
||||
void setModel(AddressTableModel *model);
|
||||
|
|
|
@ -15,6 +15,7 @@
|
|||
#include "intro.h"
|
||||
#include "networkstyle.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "platformstyle.h"
|
||||
#include "splashscreen.h"
|
||||
#include "utilitydialog.h"
|
||||
#include "winshutdownmonitor.h"
|
||||
|
@ -241,6 +242,7 @@ private:
|
|||
WalletModel *walletModel;
|
||||
#endif
|
||||
int returnValue;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
void startThread();
|
||||
};
|
||||
|
@ -310,6 +312,22 @@ BitcoinApplication::BitcoinApplication(int &argc, char **argv):
|
|||
returnValue(0)
|
||||
{
|
||||
setQuitOnLastWindowClosed(false);
|
||||
|
||||
// UI per-platform customization
|
||||
// This must be done inside the BitcoinApplication constructor, or after it, because
|
||||
// PlatformStyle::instantiate requires a QApplication
|
||||
#if defined(Q_OS_MAC)
|
||||
std::string platformName = "macosx";
|
||||
#elif defined(Q_OS_WIN)
|
||||
std::string platformName = "windows";
|
||||
#else
|
||||
std::string platformName = "other";
|
||||
#endif
|
||||
platformName = GetArg("-uiplatform", platformName);
|
||||
platformStyle = PlatformStyle::instantiate(QString::fromStdString(platformName));
|
||||
if (!platformStyle) // Fall back to "other" if specified name not found
|
||||
platformStyle = PlatformStyle::instantiate("other");
|
||||
assert(platformStyle);
|
||||
}
|
||||
|
||||
BitcoinApplication::~BitcoinApplication()
|
||||
|
@ -330,6 +348,8 @@ BitcoinApplication::~BitcoinApplication()
|
|||
#endif
|
||||
delete optionsModel;
|
||||
optionsModel = 0;
|
||||
delete platformStyle;
|
||||
platformStyle = 0;
|
||||
}
|
||||
|
||||
#ifdef ENABLE_WALLET
|
||||
|
@ -346,7 +366,7 @@ void BitcoinApplication::createOptionsModel()
|
|||
|
||||
void BitcoinApplication::createWindow(const NetworkStyle *networkStyle)
|
||||
{
|
||||
window = new BitcoinGUI(networkStyle, 0);
|
||||
window = new BitcoinGUI(platformStyle, networkStyle, 0);
|
||||
|
||||
pollShutdownTimer = new QTimer(window);
|
||||
connect(pollShutdownTimer, SIGNAL(timeout()), window, SLOT(detectShutdown()));
|
||||
|
@ -421,6 +441,8 @@ void BitcoinApplication::initializeResult(int retval)
|
|||
returnValue = retval ? 0 : 1;
|
||||
if(retval)
|
||||
{
|
||||
// Log this only after AppInit2 finishes, as then logging setup is guaranteed complete
|
||||
qWarning() << "Platform customization:" << platformStyle->getName();
|
||||
#ifdef ENABLE_WALLET
|
||||
PaymentServer::LoadRootCAs();
|
||||
paymentServer->setOptionsModel(optionsModel);
|
||||
|
@ -432,7 +454,7 @@ void BitcoinApplication::initializeResult(int retval)
|
|||
#ifdef ENABLE_WALLET
|
||||
if(pwalletMain)
|
||||
{
|
||||
walletModel = new WalletModel(pwalletMain, optionsModel);
|
||||
walletModel = new WalletModel(platformStyle, pwalletMain, optionsModel);
|
||||
|
||||
window->addWallet(BitcoinGUI::DEFAULT_WALLET, walletModel);
|
||||
window->setCurrentWallet(BitcoinGUI::DEFAULT_WALLET);
|
||||
|
|
|
@ -13,8 +13,8 @@
|
|||
#include "openuridialog.h"
|
||||
#include "optionsdialog.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "platformstyle.h"
|
||||
#include "rpcconsole.h"
|
||||
#include "scicon.h"
|
||||
#include "utilitydialog.h"
|
||||
|
||||
#ifdef ENABLE_WALLET
|
||||
|
@ -60,7 +60,7 @@
|
|||
|
||||
const QString BitcoinGUI::DEFAULT_WALLET = "~Default";
|
||||
|
||||
BitcoinGUI::BitcoinGUI(const NetworkStyle *networkStyle, QWidget *parent) :
|
||||
BitcoinGUI::BitcoinGUI(const PlatformStyle *platformStyle, const NetworkStyle *networkStyle, QWidget *parent) :
|
||||
QMainWindow(parent),
|
||||
clientModel(0),
|
||||
walletFrame(0),
|
||||
|
@ -98,7 +98,8 @@ BitcoinGUI::BitcoinGUI(const NetworkStyle *networkStyle, QWidget *parent) :
|
|||
notificator(0),
|
||||
rpcConsole(0),
|
||||
prevBlocks(0),
|
||||
spinnerFrame(0)
|
||||
spinnerFrame(0),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
GUIUtil::restoreWindowGeometry("nWindow", QSize(850, 550), this);
|
||||
|
||||
|
@ -130,12 +131,12 @@ BitcoinGUI::BitcoinGUI(const NetworkStyle *networkStyle, QWidget *parent) :
|
|||
setUnifiedTitleAndToolBarOnMac(true);
|
||||
#endif
|
||||
|
||||
rpcConsole = new RPCConsole(0);
|
||||
rpcConsole = new RPCConsole(platformStyle, 0);
|
||||
#ifdef ENABLE_WALLET
|
||||
if(enableWallet)
|
||||
{
|
||||
/** Create wallet frame and make it the central widget */
|
||||
walletFrame = new WalletFrame(this);
|
||||
walletFrame = new WalletFrame(platformStyle, this);
|
||||
setCentralWidget(walletFrame);
|
||||
} else
|
||||
#endif // ENABLE_WALLET
|
||||
|
@ -175,7 +176,7 @@ BitcoinGUI::BitcoinGUI(const NetworkStyle *networkStyle, QWidget *parent) :
|
|||
QHBoxLayout *frameBlocksLayout = new QHBoxLayout(frameBlocks);
|
||||
frameBlocksLayout->setContentsMargins(3,0,3,0);
|
||||
frameBlocksLayout->setSpacing(3);
|
||||
unitDisplayControl = new UnitDisplayStatusBarControl();
|
||||
unitDisplayControl = new UnitDisplayStatusBarControl(platformStyle);
|
||||
labelEncryptionIcon = new QLabel();
|
||||
labelConnectionsIcon = new QLabel();
|
||||
labelBlocksIcon = new QLabel();
|
||||
|
@ -247,36 +248,36 @@ void BitcoinGUI::createActions()
|
|||
{
|
||||
QActionGroup *tabGroup = new QActionGroup(this);
|
||||
|
||||
overviewAction = new QAction(SingleColorIcon(":/icons/overview"), tr("&Overview"), this);
|
||||
overviewAction = new QAction(platformStyle->SingleColorIcon(":/icons/overview"), tr("&Overview"), this);
|
||||
overviewAction->setStatusTip(tr("Show general overview of wallet"));
|
||||
overviewAction->setToolTip(overviewAction->statusTip());
|
||||
overviewAction->setCheckable(true);
|
||||
overviewAction->setShortcut(QKeySequence(Qt::ALT + Qt::Key_1));
|
||||
tabGroup->addAction(overviewAction);
|
||||
|
||||
sendCoinsAction = new QAction(SingleColorIcon(":/icons/send"), tr("&Send"), this);
|
||||
sendCoinsAction = new QAction(platformStyle->SingleColorIcon(":/icons/send"), tr("&Send"), this);
|
||||
sendCoinsAction->setStatusTip(tr("Send coins to a Bitcoin address"));
|
||||
sendCoinsAction->setToolTip(sendCoinsAction->statusTip());
|
||||
sendCoinsAction->setCheckable(true);
|
||||
sendCoinsAction->setShortcut(QKeySequence(Qt::ALT + Qt::Key_2));
|
||||
tabGroup->addAction(sendCoinsAction);
|
||||
|
||||
sendCoinsMenuAction = new QAction(TextColorIcon(":/icons/send"), sendCoinsAction->text(), this);
|
||||
sendCoinsMenuAction = new QAction(platformStyle->TextColorIcon(":/icons/send"), sendCoinsAction->text(), this);
|
||||
sendCoinsMenuAction->setStatusTip(sendCoinsAction->statusTip());
|
||||
sendCoinsMenuAction->setToolTip(sendCoinsMenuAction->statusTip());
|
||||
|
||||
receiveCoinsAction = new QAction(SingleColorIcon(":/icons/receiving_addresses"), tr("&Receive"), this);
|
||||
receiveCoinsAction = new QAction(platformStyle->SingleColorIcon(":/icons/receiving_addresses"), tr("&Receive"), this);
|
||||
receiveCoinsAction->setStatusTip(tr("Request payments (generates QR codes and bitcoin: URIs)"));
|
||||
receiveCoinsAction->setToolTip(receiveCoinsAction->statusTip());
|
||||
receiveCoinsAction->setCheckable(true);
|
||||
receiveCoinsAction->setShortcut(QKeySequence(Qt::ALT + Qt::Key_3));
|
||||
tabGroup->addAction(receiveCoinsAction);
|
||||
|
||||
receiveCoinsMenuAction = new QAction(TextColorIcon(":/icons/receiving_addresses"), receiveCoinsAction->text(), this);
|
||||
receiveCoinsMenuAction = new QAction(platformStyle->TextColorIcon(":/icons/receiving_addresses"), receiveCoinsAction->text(), this);
|
||||
receiveCoinsMenuAction->setStatusTip(receiveCoinsAction->statusTip());
|
||||
receiveCoinsMenuAction->setToolTip(receiveCoinsMenuAction->statusTip());
|
||||
|
||||
historyAction = new QAction(SingleColorIcon(":/icons/history"), tr("&Transactions"), this);
|
||||
historyAction = new QAction(platformStyle->SingleColorIcon(":/icons/history"), tr("&Transactions"), this);
|
||||
historyAction->setStatusTip(tr("Browse transaction history"));
|
||||
historyAction->setToolTip(historyAction->statusTip());
|
||||
historyAction->setCheckable(true);
|
||||
|
@ -300,46 +301,46 @@ void BitcoinGUI::createActions()
|
|||
connect(historyAction, SIGNAL(triggered()), this, SLOT(gotoHistoryPage()));
|
||||
#endif // ENABLE_WALLET
|
||||
|
||||
quitAction = new QAction(TextColorIcon(":/icons/quit"), tr("E&xit"), this);
|
||||
quitAction = new QAction(platformStyle->TextColorIcon(":/icons/quit"), tr("E&xit"), this);
|
||||
quitAction->setStatusTip(tr("Quit application"));
|
||||
quitAction->setShortcut(QKeySequence(Qt::CTRL + Qt::Key_Q));
|
||||
quitAction->setMenuRole(QAction::QuitRole);
|
||||
aboutAction = new QAction(TextColorIcon(":/icons/about"), tr("&About Bitcoin Core"), this);
|
||||
aboutAction = new QAction(platformStyle->TextColorIcon(":/icons/about"), tr("&About Bitcoin Core"), this);
|
||||
aboutAction->setStatusTip(tr("Show information about Bitcoin Core"));
|
||||
aboutAction->setMenuRole(QAction::AboutRole);
|
||||
aboutQtAction = new QAction(TextColorIcon(":/icons/about_qt"), tr("About &Qt"), this);
|
||||
aboutQtAction = new QAction(platformStyle->TextColorIcon(":/icons/about_qt"), tr("About &Qt"), this);
|
||||
aboutQtAction->setStatusTip(tr("Show information about Qt"));
|
||||
aboutQtAction->setMenuRole(QAction::AboutQtRole);
|
||||
optionsAction = new QAction(TextColorIcon(":/icons/options"), tr("&Options..."), this);
|
||||
optionsAction = new QAction(platformStyle->TextColorIcon(":/icons/options"), tr("&Options..."), this);
|
||||
optionsAction->setStatusTip(tr("Modify configuration options for Bitcoin Core"));
|
||||
optionsAction->setMenuRole(QAction::PreferencesRole);
|
||||
toggleHideAction = new QAction(TextColorIcon(":/icons/about"), tr("&Show / Hide"), this);
|
||||
toggleHideAction = new QAction(platformStyle->TextColorIcon(":/icons/about"), tr("&Show / Hide"), this);
|
||||
toggleHideAction->setStatusTip(tr("Show or hide the main Window"));
|
||||
|
||||
encryptWalletAction = new QAction(TextColorIcon(":/icons/lock_closed"), tr("&Encrypt Wallet..."), this);
|
||||
encryptWalletAction = new QAction(platformStyle->TextColorIcon(":/icons/lock_closed"), tr("&Encrypt Wallet..."), this);
|
||||
encryptWalletAction->setStatusTip(tr("Encrypt the private keys that belong to your wallet"));
|
||||
encryptWalletAction->setCheckable(true);
|
||||
backupWalletAction = new QAction(TextColorIcon(":/icons/filesave"), tr("&Backup Wallet..."), this);
|
||||
backupWalletAction = new QAction(platformStyle->TextColorIcon(":/icons/filesave"), tr("&Backup Wallet..."), this);
|
||||
backupWalletAction->setStatusTip(tr("Backup wallet to another location"));
|
||||
changePassphraseAction = new QAction(TextColorIcon(":/icons/key"), tr("&Change Passphrase..."), this);
|
||||
changePassphraseAction = new QAction(platformStyle->TextColorIcon(":/icons/key"), tr("&Change Passphrase..."), this);
|
||||
changePassphraseAction->setStatusTip(tr("Change the passphrase used for wallet encryption"));
|
||||
signMessageAction = new QAction(TextColorIcon(":/icons/edit"), tr("Sign &message..."), this);
|
||||
signMessageAction = new QAction(platformStyle->TextColorIcon(":/icons/edit"), tr("Sign &message..."), this);
|
||||
signMessageAction->setStatusTip(tr("Sign messages with your Bitcoin addresses to prove you own them"));
|
||||
verifyMessageAction = new QAction(TextColorIcon(":/icons/verify"), tr("&Verify message..."), this);
|
||||
verifyMessageAction = new QAction(platformStyle->TextColorIcon(":/icons/verify"), tr("&Verify message..."), this);
|
||||
verifyMessageAction->setStatusTip(tr("Verify messages to ensure they were signed with specified Bitcoin addresses"));
|
||||
|
||||
openRPCConsoleAction = new QAction(TextColorIcon(":/icons/debugwindow"), tr("&Debug window"), this);
|
||||
openRPCConsoleAction = new QAction(platformStyle->TextColorIcon(":/icons/debugwindow"), tr("&Debug window"), this);
|
||||
openRPCConsoleAction->setStatusTip(tr("Open debugging and diagnostic console"));
|
||||
|
||||
usedSendingAddressesAction = new QAction(TextColorIcon(":/icons/address-book"), tr("&Sending addresses..."), this);
|
||||
usedSendingAddressesAction = new QAction(platformStyle->TextColorIcon(":/icons/address-book"), tr("&Sending addresses..."), this);
|
||||
usedSendingAddressesAction->setStatusTip(tr("Show the list of used sending addresses and labels"));
|
||||
usedReceivingAddressesAction = new QAction(TextColorIcon(":/icons/address-book"), tr("&Receiving addresses..."), this);
|
||||
usedReceivingAddressesAction = new QAction(platformStyle->TextColorIcon(":/icons/address-book"), tr("&Receiving addresses..."), this);
|
||||
usedReceivingAddressesAction->setStatusTip(tr("Show the list of used receiving addresses and labels"));
|
||||
|
||||
openAction = new QAction(TextColorIcon(":/icons/open"), tr("Open &URI..."), this);
|
||||
openAction = new QAction(platformStyle->TextColorIcon(":/icons/open"), tr("Open &URI..."), this);
|
||||
openAction->setStatusTip(tr("Open a bitcoin: URI or payment request"));
|
||||
|
||||
showHelpMessageAction = new QAction(TextColorIcon(":/icons/info"), tr("&Command-line options"), this);
|
||||
showHelpMessageAction = new QAction(platformStyle->TextColorIcon(":/icons/info"), tr("&Command-line options"), this);
|
||||
showHelpMessageAction->setMenuRole(QAction::NoRole);
|
||||
showHelpMessageAction->setStatusTip(tr("Show the Bitcoin Core help message to get a list with possible Bitcoin command-line options"));
|
||||
|
||||
|
@ -650,7 +651,7 @@ void BitcoinGUI::setNumConnections(int count)
|
|||
case 7: case 8: case 9: icon = ":/icons/connect_3"; break;
|
||||
default: icon = ":/icons/connect_4"; break;
|
||||
}
|
||||
labelConnectionsIcon->setPixmap(SingleColorIcon(icon).pixmap(STATUSBAR_ICONSIZE,STATUSBAR_ICONSIZE));
|
||||
labelConnectionsIcon->setPixmap(platformStyle->SingleColorIcon(icon).pixmap(STATUSBAR_ICONSIZE,STATUSBAR_ICONSIZE));
|
||||
labelConnectionsIcon->setToolTip(tr("%n active connection(s) to Bitcoin network", "", count));
|
||||
}
|
||||
|
||||
|
@ -691,7 +692,7 @@ void BitcoinGUI::setNumBlocks(int count, const QDateTime& blockDate)
|
|||
if(secs < 90*60)
|
||||
{
|
||||
tooltip = tr("Up to date") + QString(".<br>") + tooltip;
|
||||
labelBlocksIcon->setPixmap(SingleColorIcon(":/icons/synced").pixmap(STATUSBAR_ICONSIZE, STATUSBAR_ICONSIZE));
|
||||
labelBlocksIcon->setPixmap(platformStyle->SingleColorIcon(":/icons/synced").pixmap(STATUSBAR_ICONSIZE, STATUSBAR_ICONSIZE));
|
||||
|
||||
#ifdef ENABLE_WALLET
|
||||
if(walletFrame)
|
||||
|
@ -737,7 +738,7 @@ void BitcoinGUI::setNumBlocks(int count, const QDateTime& blockDate)
|
|||
tooltip = tr("Catching up...") + QString("<br>") + tooltip;
|
||||
if(count != prevBlocks)
|
||||
{
|
||||
labelBlocksIcon->setPixmap(SingleColorIcon(QString(
|
||||
labelBlocksIcon->setPixmap(platformStyle->SingleColorIcon(QString(
|
||||
":/movies/spinner-%1").arg(spinnerFrame, 3, 10, QChar('0')))
|
||||
.pixmap(STATUSBAR_ICONSIZE, STATUSBAR_ICONSIZE));
|
||||
spinnerFrame = (spinnerFrame + 1) % SPINNER_FRAMES;
|
||||
|
@ -931,7 +932,7 @@ void BitcoinGUI::setEncryptionStatus(int status)
|
|||
break;
|
||||
case WalletModel::Unlocked:
|
||||
labelEncryptionIcon->show();
|
||||
labelEncryptionIcon->setPixmap(SingleColorIcon(":/icons/lock_open").pixmap(STATUSBAR_ICONSIZE,STATUSBAR_ICONSIZE));
|
||||
labelEncryptionIcon->setPixmap(platformStyle->SingleColorIcon(":/icons/lock_open").pixmap(STATUSBAR_ICONSIZE,STATUSBAR_ICONSIZE));
|
||||
labelEncryptionIcon->setToolTip(tr("Wallet is <b>encrypted</b> and currently <b>unlocked</b>"));
|
||||
encryptWalletAction->setChecked(true);
|
||||
changePassphraseAction->setEnabled(true);
|
||||
|
@ -939,7 +940,7 @@ void BitcoinGUI::setEncryptionStatus(int status)
|
|||
break;
|
||||
case WalletModel::Locked:
|
||||
labelEncryptionIcon->show();
|
||||
labelEncryptionIcon->setPixmap(SingleColorIcon(":/icons/lock_closed").pixmap(STATUSBAR_ICONSIZE,STATUSBAR_ICONSIZE));
|
||||
labelEncryptionIcon->setPixmap(platformStyle->SingleColorIcon(":/icons/lock_closed").pixmap(STATUSBAR_ICONSIZE,STATUSBAR_ICONSIZE));
|
||||
labelEncryptionIcon->setToolTip(tr("Wallet is <b>encrypted</b> and currently <b>locked</b>"));
|
||||
encryptWalletAction->setChecked(true);
|
||||
changePassphraseAction->setEnabled(true);
|
||||
|
@ -1041,7 +1042,7 @@ void BitcoinGUI::unsubscribeFromCoreSignals()
|
|||
uiInterface.ThreadSafeMessageBox.disconnect(boost::bind(ThreadSafeMessageBox, this, _1, _2, _3));
|
||||
}
|
||||
|
||||
UnitDisplayStatusBarControl::UnitDisplayStatusBarControl() :
|
||||
UnitDisplayStatusBarControl::UnitDisplayStatusBarControl(const PlatformStyle *platformStyle) :
|
||||
optionsModel(0),
|
||||
menu(0)
|
||||
{
|
||||
|
@ -1056,7 +1057,7 @@ UnitDisplayStatusBarControl::UnitDisplayStatusBarControl() :
|
|||
}
|
||||
setMinimumSize(max_width, 0);
|
||||
setAlignment(Qt::AlignRight | Qt::AlignVCenter);
|
||||
setStyleSheet(QString("QLabel { color : %1 }").arg(SingleColor().name()));
|
||||
setStyleSheet(QString("QLabel { color : %1 }").arg(platformStyle->SingleColor().name()));
|
||||
}
|
||||
|
||||
/** So that it responds to button clicks */
|
||||
|
|
|
@ -22,6 +22,7 @@ class ClientModel;
|
|||
class NetworkStyle;
|
||||
class Notificator;
|
||||
class OptionsModel;
|
||||
class PlatformStyle;
|
||||
class RPCConsole;
|
||||
class SendCoinsRecipient;
|
||||
class UnitDisplayStatusBarControl;
|
||||
|
@ -47,7 +48,7 @@ class BitcoinGUI : public QMainWindow
|
|||
public:
|
||||
static const QString DEFAULT_WALLET;
|
||||
|
||||
explicit BitcoinGUI(const NetworkStyle *networkStyle, QWidget *parent = 0);
|
||||
explicit BitcoinGUI(const PlatformStyle *platformStyle, const NetworkStyle *networkStyle, QWidget *parent = 0);
|
||||
~BitcoinGUI();
|
||||
|
||||
/** Set the client model.
|
||||
|
@ -117,6 +118,8 @@ private:
|
|||
int prevBlocks;
|
||||
int spinnerFrame;
|
||||
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
/** Create the main UI actions. */
|
||||
void createActions();
|
||||
/** Create the menu bar and sub-menus. */
|
||||
|
@ -215,7 +218,7 @@ class UnitDisplayStatusBarControl : public QLabel
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit UnitDisplayStatusBarControl();
|
||||
explicit UnitDisplayStatusBarControl(const PlatformStyle *platformStyle);
|
||||
/** Lets the control know about the Options Model (and its signals) */
|
||||
void setOptionsModel(OptionsModel *optionsModel);
|
||||
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
#include "bitcoinunits.h"
|
||||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
#include "txmempool.h"
|
||||
#include "walletmodel.h"
|
||||
|
||||
|
@ -35,10 +35,11 @@ QList<CAmount> CoinControlDialog::payAmounts;
|
|||
CCoinControl* CoinControlDialog::coinControl = new CCoinControl();
|
||||
bool CoinControlDialog::fSubtractFeeFromAmount = false;
|
||||
|
||||
CoinControlDialog::CoinControlDialog(QWidget *parent) :
|
||||
CoinControlDialog::CoinControlDialog(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QDialog(parent),
|
||||
ui(new Ui::CoinControlDialog),
|
||||
model(0)
|
||||
model(0),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
|
@ -280,7 +281,7 @@ void CoinControlDialog::lockCoin()
|
|||
COutPoint outpt(uint256S(contextMenuItem->text(COLUMN_TXHASH).toStdString()), contextMenuItem->text(COLUMN_VOUT_INDEX).toUInt());
|
||||
model->lockCoin(outpt);
|
||||
contextMenuItem->setDisabled(true);
|
||||
contextMenuItem->setIcon(COLUMN_CHECKBOX, SingleColorIcon(":/icons/lock_closed"));
|
||||
contextMenuItem->setIcon(COLUMN_CHECKBOX, platformStyle->SingleColorIcon(":/icons/lock_closed"));
|
||||
updateLabelLocked();
|
||||
}
|
||||
|
||||
|
@ -791,7 +792,7 @@ void CoinControlDialog::updateView()
|
|||
COutPoint outpt(txhash, out.i);
|
||||
coinControl->UnSelect(outpt); // just to be sure
|
||||
itemOutput->setDisabled(true);
|
||||
itemOutput->setIcon(COLUMN_CHECKBOX, SingleColorIcon(":/icons/lock_closed"));
|
||||
itemOutput->setIcon(COLUMN_CHECKBOX, platformStyle->SingleColorIcon(":/icons/lock_closed"));
|
||||
}
|
||||
|
||||
// set checkbox
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
#include <QString>
|
||||
#include <QTreeWidgetItem>
|
||||
|
||||
class PlatformStyle;
|
||||
class WalletModel;
|
||||
|
||||
class CCoinControl;
|
||||
|
@ -32,7 +33,7 @@ class CoinControlDialog : public QDialog
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit CoinControlDialog(QWidget *parent = 0);
|
||||
explicit CoinControlDialog(const PlatformStyle *platformStyle, QWidget *parent = 0);
|
||||
~CoinControlDialog();
|
||||
|
||||
void setModel(WalletModel *model);
|
||||
|
@ -57,6 +58,8 @@ private:
|
|||
QAction *lockAction;
|
||||
QAction *unlockAction;
|
||||
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
QString strPad(QString, int, QString);
|
||||
void sortView(int, Qt::SortOrder);
|
||||
void updateView();
|
||||
|
|
|
@ -6,7 +6,6 @@
|
|||
#include "ui_intro.h"
|
||||
|
||||
#include "guiutil.h"
|
||||
#include "scicon.h"
|
||||
|
||||
#include "util.h"
|
||||
|
||||
|
@ -168,7 +167,7 @@ void Intro::pickDataDirectory()
|
|||
/* If current default data directory does not exist, let the user choose one */
|
||||
Intro intro;
|
||||
intro.setDataDirectory(dataDir);
|
||||
intro.setWindowIcon(SingleColorIcon(":icons/bitcoin"));
|
||||
intro.setWindowIcon(QIcon(":icons/bitcoin"));
|
||||
|
||||
while(true)
|
||||
{
|
||||
|
|
|
@ -5,7 +5,6 @@
|
|||
#include "networkstyle.h"
|
||||
|
||||
#include "guiconstants.h"
|
||||
#include "scicon.h"
|
||||
|
||||
#include <QApplication>
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
#include "guiconstants.h"
|
||||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
#include "transactionfilterproxy.h"
|
||||
#include "transactiontablemodel.h"
|
||||
#include "walletmodel.h"
|
||||
|
@ -25,7 +25,9 @@ class TxViewDelegate : public QAbstractItemDelegate
|
|||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
TxViewDelegate(): QAbstractItemDelegate(), unit(BitcoinUnits::BTC)
|
||||
TxViewDelegate(const PlatformStyle *platformStyle):
|
||||
QAbstractItemDelegate(), unit(BitcoinUnits::BTC),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
|
||||
}
|
||||
|
@ -43,7 +45,7 @@ public:
|
|||
int halfheight = (mainRect.height() - 2*ypad)/2;
|
||||
QRect amountRect(mainRect.left() + xspace, mainRect.top()+ypad, mainRect.width() - xspace, halfheight);
|
||||
QRect addressRect(mainRect.left() + xspace, mainRect.top()+ypad+halfheight, mainRect.width() - xspace, halfheight);
|
||||
icon = SingleColorIcon(icon, SingleColor());
|
||||
icon = platformStyle->SingleColorIcon(icon);
|
||||
icon.paint(painter, decorationRect);
|
||||
|
||||
QDateTime date = index.data(TransactionTableModel::DateRole).toDateTime();
|
||||
|
@ -101,11 +103,12 @@ public:
|
|||
}
|
||||
|
||||
int unit;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
};
|
||||
#include "overviewpage.moc"
|
||||
|
||||
OverviewPage::OverviewPage(QWidget *parent) :
|
||||
OverviewPage::OverviewPage(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QWidget(parent),
|
||||
ui(new Ui::OverviewPage),
|
||||
clientModel(0),
|
||||
|
@ -116,13 +119,13 @@ OverviewPage::OverviewPage(QWidget *parent) :
|
|||
currentWatchOnlyBalance(-1),
|
||||
currentWatchUnconfBalance(-1),
|
||||
currentWatchImmatureBalance(-1),
|
||||
txdelegate(new TxViewDelegate()),
|
||||
txdelegate(new TxViewDelegate(platformStyle)),
|
||||
filter(0)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
// use a SingleColorIcon for the "out of sync warning" icon
|
||||
QIcon icon = SingleColorIcon(":/icons/warning");
|
||||
QIcon icon = platformStyle->SingleColorIcon(":/icons/warning");
|
||||
icon.addPixmap(icon.pixmap(QSize(64,64), QIcon::Normal), QIcon::Disabled); // also set the disabled icon because we are using a disabled QPushButton to work around missing HiDPI support of QLabel (https://bugreports.qt.io/browse/QTBUG-42503)
|
||||
ui->labelTransactionsStatus->setIcon(icon);
|
||||
ui->labelWalletStatus->setIcon(icon);
|
||||
|
|
|
@ -12,6 +12,7 @@
|
|||
class ClientModel;
|
||||
class TransactionFilterProxy;
|
||||
class TxViewDelegate;
|
||||
class PlatformStyle;
|
||||
class WalletModel;
|
||||
|
||||
namespace Ui {
|
||||
|
@ -28,7 +29,7 @@ class OverviewPage : public QWidget
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit OverviewPage(QWidget *parent = 0);
|
||||
explicit OverviewPage(const PlatformStyle *platformStyle, QWidget *parent = 0);
|
||||
~OverviewPage();
|
||||
|
||||
void setClientModel(ClientModel *clientModel);
|
||||
|
|
147
src/qt/platformstyle.cpp
Normal file
147
src/qt/platformstyle.cpp
Normal file
|
@ -0,0 +1,147 @@
|
|||
// Copyright (c) 2015 The Bitcoin Core developers
|
||||
// Distributed under the MIT software license, see the accompanying
|
||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||
|
||||
#include "platformstyle.h"
|
||||
|
||||
#include "guiconstants.h"
|
||||
|
||||
#include <QApplication>
|
||||
#include <QColor>
|
||||
#include <QIcon>
|
||||
#include <QImage>
|
||||
#include <QPalette>
|
||||
#include <QPixmap>
|
||||
|
||||
static const struct {
|
||||
const char *platformId;
|
||||
/** Show images on push buttons */
|
||||
const bool imagesOnButtons;
|
||||
/** Colorize single-color icons */
|
||||
const bool colorizeIcons;
|
||||
/** Extra padding/spacing in transactionview */
|
||||
const bool useExtraSpacing;
|
||||
} platform_styles[] = {
|
||||
{"macosx", false, false, true},
|
||||
{"windows", true, false, false},
|
||||
/* Other: linux, unix, ... */
|
||||
{"other", true, true, false}
|
||||
};
|
||||
static const unsigned platform_styles_count = sizeof(platform_styles)/sizeof(*platform_styles);
|
||||
|
||||
namespace {
|
||||
/* Local functions for colorizing single-color images */
|
||||
|
||||
void MakeSingleColorImage(QImage& img, const QColor& colorbase)
|
||||
{
|
||||
img = img.convertToFormat(QImage::Format_ARGB32);
|
||||
for (int x = img.width(); x--; )
|
||||
{
|
||||
for (int y = img.height(); y--; )
|
||||
{
|
||||
const QRgb rgb = img.pixel(x, y);
|
||||
img.setPixel(x, y, qRgba(colorbase.red(), colorbase.green(), colorbase.blue(), qAlpha(rgb)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QIcon ColorizeIcon(const QIcon& ico, const QColor& colorbase)
|
||||
{
|
||||
QIcon new_ico;
|
||||
QSize sz;
|
||||
Q_FOREACH(sz, ico.availableSizes())
|
||||
{
|
||||
QImage img(ico.pixmap(sz).toImage());
|
||||
MakeSingleColorImage(img, colorbase);
|
||||
new_ico.addPixmap(QPixmap::fromImage(img));
|
||||
}
|
||||
return new_ico;
|
||||
}
|
||||
|
||||
QImage ColorizeImage(const QString& filename, const QColor& colorbase)
|
||||
{
|
||||
QImage img(filename);
|
||||
MakeSingleColorImage(img, colorbase);
|
||||
return img;
|
||||
}
|
||||
|
||||
QIcon ColorizeIcon(const QString& filename, const QColor& colorbase)
|
||||
{
|
||||
return QIcon(QPixmap::fromImage(ColorizeImage(filename, colorbase)));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
PlatformStyle::PlatformStyle(const QString &name, bool imagesOnButtons, bool colorizeIcons, bool useExtraSpacing):
|
||||
name(name),
|
||||
imagesOnButtons(imagesOnButtons),
|
||||
colorizeIcons(colorizeIcons),
|
||||
useExtraSpacing(useExtraSpacing),
|
||||
singleColor(0,0,0),
|
||||
textColor(0,0,0)
|
||||
{
|
||||
// Determine icon highlighting color
|
||||
if (colorizeIcons) {
|
||||
const QColor colorHighlightBg(QApplication::palette().color(QPalette::Highlight));
|
||||
const QColor colorHighlightFg(QApplication::palette().color(QPalette::HighlightedText));
|
||||
const QColor colorText(QApplication::palette().color(QPalette::WindowText));
|
||||
const int colorTextLightness = colorText.lightness();
|
||||
QColor colorbase;
|
||||
if (abs(colorHighlightBg.lightness() - colorTextLightness) < abs(colorHighlightFg.lightness() - colorTextLightness))
|
||||
colorbase = colorHighlightBg;
|
||||
else
|
||||
colorbase = colorHighlightFg;
|
||||
singleColor = colorbase;
|
||||
}
|
||||
// Determine text color
|
||||
textColor = QColor(QApplication::palette().color(QPalette::WindowText));
|
||||
}
|
||||
|
||||
QImage PlatformStyle::SingleColorImage(const QString& filename) const
|
||||
{
|
||||
if (!colorizeIcons)
|
||||
return QImage(filename);
|
||||
return ColorizeImage(filename, SingleColor());
|
||||
}
|
||||
|
||||
QIcon PlatformStyle::SingleColorIcon(const QString& filename) const
|
||||
{
|
||||
if (!colorizeIcons)
|
||||
return QIcon(filename);
|
||||
return ColorizeIcon(filename, SingleColor());
|
||||
}
|
||||
|
||||
QIcon PlatformStyle::SingleColorIcon(const QIcon& icon) const
|
||||
{
|
||||
if (!colorizeIcons)
|
||||
return icon;
|
||||
return ColorizeIcon(icon, SingleColor());
|
||||
}
|
||||
|
||||
QIcon PlatformStyle::TextColorIcon(const QString& filename) const
|
||||
{
|
||||
return ColorizeIcon(filename, TextColor());
|
||||
}
|
||||
|
||||
QIcon PlatformStyle::TextColorIcon(const QIcon& icon) const
|
||||
{
|
||||
return ColorizeIcon(icon, TextColor());
|
||||
}
|
||||
|
||||
const PlatformStyle *PlatformStyle::instantiate(const QString &platformId)
|
||||
{
|
||||
for (unsigned x=0; x<platform_styles_count; ++x)
|
||||
{
|
||||
if (platformId == platform_styles[x].platformId)
|
||||
{
|
||||
return new PlatformStyle(
|
||||
platform_styles[x].platformId,
|
||||
platform_styles[x].imagesOnButtons,
|
||||
platform_styles[x].colorizeIcons,
|
||||
platform_styles[x].useExtraSpacing);
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
55
src/qt/platformstyle.h
Normal file
55
src/qt/platformstyle.h
Normal file
|
@ -0,0 +1,55 @@
|
|||
// Copyright (c) 2015 The Bitcoin Core developers
|
||||
// Distributed under the MIT software license, see the accompanying
|
||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||
|
||||
#ifndef BITCOIN_QT_PLATFORMSTYLE_H
|
||||
#define BITCOIN_QT_PLATFORMSTYLE_H
|
||||
|
||||
#include <QIcon>
|
||||
#include <QPixmap>
|
||||
#include <QString>
|
||||
|
||||
/* Coin network-specific GUI style information */
|
||||
class PlatformStyle
|
||||
{
|
||||
public:
|
||||
/** Get style associated with provided platform name, or 0 if not known */
|
||||
static const PlatformStyle *instantiate(const QString &platformId);
|
||||
|
||||
const QString &getName() const { return name; }
|
||||
|
||||
bool getImagesOnButtons() const { return imagesOnButtons; }
|
||||
bool getUseExtraSpacing() const { return useExtraSpacing; }
|
||||
|
||||
QColor TextColor() const { return textColor; }
|
||||
QColor SingleColor() const { return singleColor; }
|
||||
|
||||
/** Colorize an image (given filename) with the icon color */
|
||||
QImage SingleColorImage(const QString& filename) const;
|
||||
|
||||
/** Colorize an icon (given filename) with the icon color */
|
||||
QIcon SingleColorIcon(const QString& filename) const;
|
||||
|
||||
/** Colorize an icon (given object) with the icon color */
|
||||
QIcon SingleColorIcon(const QIcon& icon) const;
|
||||
|
||||
/** Colorize an icon (given filename) with the text color */
|
||||
QIcon TextColorIcon(const QString& filename) const;
|
||||
|
||||
/** Colorize an icon (given object) with the text color */
|
||||
QIcon TextColorIcon(const QIcon& icon) const;
|
||||
|
||||
private:
|
||||
PlatformStyle(const QString &name, bool imagesOnButtons, bool colorizeIcons, bool useExtraSpacing);
|
||||
|
||||
QString name;
|
||||
bool imagesOnButtons;
|
||||
bool colorizeIcons;
|
||||
bool useExtraSpacing;
|
||||
QColor singleColor;
|
||||
QColor textColor;
|
||||
/* ... more to come later */
|
||||
};
|
||||
|
||||
#endif // BITCOIN_QT_PLATFORMSTYLE_H
|
||||
|
|
@ -10,9 +10,9 @@
|
|||
#include "bitcoinunits.h"
|
||||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "platformstyle.h"
|
||||
#include "receiverequestdialog.h"
|
||||
#include "recentrequeststablemodel.h"
|
||||
#include "scicon.h"
|
||||
#include "walletmodel.h"
|
||||
|
||||
#include <QAction>
|
||||
|
@ -22,24 +22,25 @@
|
|||
#include <QScrollBar>
|
||||
#include <QTextDocument>
|
||||
|
||||
ReceiveCoinsDialog::ReceiveCoinsDialog(QWidget *parent) :
|
||||
ReceiveCoinsDialog::ReceiveCoinsDialog(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QDialog(parent),
|
||||
ui(new Ui::ReceiveCoinsDialog),
|
||||
model(0)
|
||||
model(0),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
#ifdef Q_OS_MAC // Icons on push buttons are very uncommon on Mac
|
||||
ui->clearButton->setIcon(QIcon());
|
||||
ui->receiveButton->setIcon(QIcon());
|
||||
ui->showRequestButton->setIcon(QIcon());
|
||||
ui->removeRequestButton->setIcon(QIcon());
|
||||
#else
|
||||
ui->clearButton->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->receiveButton->setIcon(SingleColorIcon(":/icons/receiving_addresses"));
|
||||
ui->showRequestButton->setIcon(SingleColorIcon(":/icons/edit"));
|
||||
ui->removeRequestButton->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
#endif
|
||||
if (!platformStyle->getImagesOnButtons()) {
|
||||
ui->clearButton->setIcon(QIcon());
|
||||
ui->receiveButton->setIcon(QIcon());
|
||||
ui->showRequestButton->setIcon(QIcon());
|
||||
ui->removeRequestButton->setIcon(QIcon());
|
||||
} else {
|
||||
ui->clearButton->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
ui->receiveButton->setIcon(platformStyle->SingleColorIcon(":/icons/receiving_addresses"));
|
||||
ui->showRequestButton->setIcon(platformStyle->SingleColorIcon(":/icons/edit"));
|
||||
ui->removeRequestButton->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
}
|
||||
|
||||
// context menu actions
|
||||
QAction *copyLabelAction = new QAction(tr("Copy label"), this);
|
||||
|
@ -132,7 +133,7 @@ void ReceiveCoinsDialog::on_receiveButton_clicked()
|
|||
if(ui->reuseAddress->isChecked())
|
||||
{
|
||||
/* Choose existing receiving address */
|
||||
AddressBookPage dlg(AddressBookPage::ForSelection, AddressBookPage::ReceivingTab, this);
|
||||
AddressBookPage dlg(platformStyle, AddressBookPage::ForSelection, AddressBookPage::ReceivingTab, this);
|
||||
dlg.setModel(model->getAddressTableModel());
|
||||
if(dlg.exec())
|
||||
{
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
#include <QVariant>
|
||||
|
||||
class OptionsModel;
|
||||
class PlatformStyle;
|
||||
class WalletModel;
|
||||
|
||||
namespace Ui {
|
||||
|
@ -39,7 +40,7 @@ public:
|
|||
MINIMUM_COLUMN_WIDTH = 130
|
||||
};
|
||||
|
||||
explicit ReceiveCoinsDialog(QWidget *parent = 0);
|
||||
explicit ReceiveCoinsDialog(const PlatformStyle *platformStyle, QWidget *parent = 0);
|
||||
~ReceiveCoinsDialog();
|
||||
|
||||
void setModel(WalletModel *model);
|
||||
|
@ -57,6 +58,8 @@ private:
|
|||
GUIUtil::TableViewLastColumnResizingFixer *columnResizingFixer;
|
||||
WalletModel *model;
|
||||
QMenu *contextMenu;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
void copyColumnToClipboard(int column);
|
||||
virtual void resizeEvent(QResizeEvent *event);
|
||||
|
||||
|
|
|
@ -8,7 +8,7 @@
|
|||
#include "clientmodel.h"
|
||||
#include "guiutil.h"
|
||||
#include "peertablemodel.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
|
||||
#include "chainparams.h"
|
||||
#include "rpcserver.h"
|
||||
|
@ -200,21 +200,22 @@ void RPCExecutor::request(const QString &command)
|
|||
}
|
||||
}
|
||||
|
||||
RPCConsole::RPCConsole(QWidget *parent) :
|
||||
RPCConsole::RPCConsole(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QWidget(parent),
|
||||
ui(new Ui::RPCConsole),
|
||||
clientModel(0),
|
||||
historyPtr(0),
|
||||
cachedNodeid(-1),
|
||||
contextMenu(0)
|
||||
contextMenu(0),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
GUIUtil::restoreWindowGeometry("nRPCConsoleWindow", this->size(), this);
|
||||
|
||||
#ifndef Q_OS_MAC
|
||||
ui->openDebugLogfileButton->setIcon(SingleColorIcon(":/icons/export"));
|
||||
#endif
|
||||
ui->clearButton->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
if (platformStyle->getImagesOnButtons()) {
|
||||
ui->openDebugLogfileButton->setIcon(platformStyle->SingleColorIcon(":/icons/export"));
|
||||
}
|
||||
ui->clearButton->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
|
||||
// Install event filter for up and down arrow
|
||||
ui->lineEdit->installEventFilter(this);
|
||||
|
@ -363,7 +364,7 @@ void RPCConsole::clear()
|
|||
ui->messagesWidget->document()->addResource(
|
||||
QTextDocument::ImageResource,
|
||||
QUrl(ICON_MAPPING[i].url),
|
||||
SingleColorImage(ICON_MAPPING[i].source, SingleColor()).scaled(ICON_SIZE, Qt::IgnoreAspectRatio, Qt::SmoothTransformation));
|
||||
platformStyle->SingleColorImage(ICON_MAPPING[i].source).scaled(ICON_SIZE, Qt::IgnoreAspectRatio, Qt::SmoothTransformation));
|
||||
}
|
||||
|
||||
// Set default style sheet
|
||||
|
|
|
@ -13,6 +13,7 @@
|
|||
#include <QWidget>
|
||||
|
||||
class ClientModel;
|
||||
class PlatformStyle;
|
||||
|
||||
namespace Ui {
|
||||
class RPCConsole;
|
||||
|
@ -29,7 +30,7 @@ class RPCConsole: public QWidget
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit RPCConsole(QWidget *parent);
|
||||
explicit RPCConsole(const PlatformStyle *platformStyle, QWidget *parent);
|
||||
~RPCConsole();
|
||||
|
||||
void setClientModel(ClientModel *model);
|
||||
|
@ -106,6 +107,7 @@ private:
|
|||
int historyPtr;
|
||||
NodeId cachedNodeid;
|
||||
QMenu *contextMenu;
|
||||
const PlatformStyle *platformStyle;
|
||||
};
|
||||
|
||||
#endif // BITCOIN_QT_RPCCONSOLE_H
|
||||
|
|
|
@ -1,98 +0,0 @@
|
|||
// Copyright (c) 2014 The Bitcoin developers
|
||||
// Distributed under the MIT software license, see the accompanying
|
||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||
|
||||
#include "scicon.h"
|
||||
|
||||
#include <QApplication>
|
||||
#include <QColor>
|
||||
#include <QIcon>
|
||||
#include <QImage>
|
||||
#include <QPalette>
|
||||
#include <QPixmap>
|
||||
|
||||
namespace {
|
||||
|
||||
void MakeSingleColorImage(QImage& img, const QColor& colorbase)
|
||||
{
|
||||
img = img.convertToFormat(QImage::Format_ARGB32);
|
||||
for (int x = img.width(); x--; )
|
||||
{
|
||||
for (int y = img.height(); y--; )
|
||||
{
|
||||
const QRgb rgb = img.pixel(x, y);
|
||||
img.setPixel(x, y, qRgba(colorbase.red(), colorbase.green(), colorbase.blue(), qAlpha(rgb)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
QImage SingleColorImage(const QString& filename, const QColor& colorbase)
|
||||
{
|
||||
QImage img(filename);
|
||||
#if !defined(WIN32) && !defined(MAC_OSX)
|
||||
MakeSingleColorImage(img, colorbase);
|
||||
#endif
|
||||
return img;
|
||||
}
|
||||
|
||||
QIcon SingleColorIcon(const QIcon& ico, const QColor& colorbase)
|
||||
{
|
||||
#if defined(WIN32) || defined(MAC_OSX)
|
||||
return ico;
|
||||
#else
|
||||
QIcon new_ico;
|
||||
QSize sz;
|
||||
Q_FOREACH(sz, ico.availableSizes())
|
||||
{
|
||||
QImage img(ico.pixmap(sz).toImage());
|
||||
MakeSingleColorImage(img, colorbase);
|
||||
new_ico.addPixmap(QPixmap::fromImage(img));
|
||||
}
|
||||
return new_ico;
|
||||
#endif
|
||||
}
|
||||
|
||||
QIcon SingleColorIcon(const QString& filename, const QColor& colorbase)
|
||||
{
|
||||
return QIcon(QPixmap::fromImage(SingleColorImage(filename, colorbase)));
|
||||
}
|
||||
|
||||
QColor SingleColor()
|
||||
{
|
||||
#if defined(WIN32) || defined(MAC_OSX)
|
||||
return QColor(0,0,0);
|
||||
#else
|
||||
const QColor colorHighlightBg(QApplication::palette().color(QPalette::Highlight));
|
||||
const QColor colorHighlightFg(QApplication::palette().color(QPalette::HighlightedText));
|
||||
const QColor colorText(QApplication::palette().color(QPalette::WindowText));
|
||||
const int colorTextLightness = colorText.lightness();
|
||||
QColor colorbase;
|
||||
if (abs(colorHighlightBg.lightness() - colorTextLightness) < abs(colorHighlightFg.lightness() - colorTextLightness))
|
||||
colorbase = colorHighlightBg;
|
||||
else
|
||||
colorbase = colorHighlightFg;
|
||||
return colorbase;
|
||||
#endif
|
||||
}
|
||||
|
||||
QIcon SingleColorIcon(const QString& filename)
|
||||
{
|
||||
return SingleColorIcon(filename, SingleColor());
|
||||
}
|
||||
|
||||
static QColor TextColor()
|
||||
{
|
||||
return QColor(QApplication::palette().color(QPalette::WindowText));
|
||||
}
|
||||
|
||||
QIcon TextColorIcon(const QString& filename)
|
||||
{
|
||||
return SingleColorIcon(filename, TextColor());
|
||||
}
|
||||
|
||||
QIcon TextColorIcon(const QIcon& ico)
|
||||
{
|
||||
return SingleColorIcon(ico, TextColor());
|
||||
}
|
|
@ -1,24 +0,0 @@
|
|||
// Copyright (c) 2014 The Bitcoin developers
|
||||
// Distributed under the MIT software license, see the accompanying
|
||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||
|
||||
#ifndef BITCOIN_QT_SCICON_H
|
||||
#define BITCOIN_QT_SCICON_H
|
||||
|
||||
#include <QtCore>
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
class QColor;
|
||||
class QIcon;
|
||||
class QString;
|
||||
QT_END_NAMESPACE
|
||||
|
||||
QImage SingleColorImage(const QString& filename, const QColor&);
|
||||
QIcon SingleColorIcon(const QIcon&, const QColor&);
|
||||
QIcon SingleColorIcon(const QString& filename, const QColor&);
|
||||
QColor SingleColor();
|
||||
QIcon SingleColorIcon(const QString& filename);
|
||||
QIcon TextColorIcon(const QIcon&);
|
||||
QIcon TextColorIcon(const QString& filename);
|
||||
|
||||
#endif // BITCOIN_QT_SCICON_H
|
|
@ -11,7 +11,7 @@
|
|||
#include "coincontroldialog.h"
|
||||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
#include "sendcoinsentry.h"
|
||||
#include "walletmodel.h"
|
||||
|
||||
|
@ -27,25 +27,26 @@
|
|||
#include <QSettings>
|
||||
#include <QTextDocument>
|
||||
|
||||
SendCoinsDialog::SendCoinsDialog(QWidget *parent) :
|
||||
SendCoinsDialog::SendCoinsDialog(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QDialog(parent),
|
||||
ui(new Ui::SendCoinsDialog),
|
||||
clientModel(0),
|
||||
model(0),
|
||||
fNewRecipientAllowed(true),
|
||||
fFeeMinimized(true)
|
||||
fFeeMinimized(true),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
#ifdef Q_OS_MAC // Icons on push buttons are very uncommon on Mac
|
||||
ui->addButton->setIcon(QIcon());
|
||||
ui->clearButton->setIcon(QIcon());
|
||||
ui->sendButton->setIcon(QIcon());
|
||||
#else
|
||||
ui->addButton->setIcon(SingleColorIcon(":/icons/add"));
|
||||
ui->clearButton->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->sendButton->setIcon(SingleColorIcon(":/icons/send"));
|
||||
#endif
|
||||
if (!platformStyle->getImagesOnButtons()) {
|
||||
ui->addButton->setIcon(QIcon());
|
||||
ui->clearButton->setIcon(QIcon());
|
||||
ui->sendButton->setIcon(QIcon());
|
||||
} else {
|
||||
ui->addButton->setIcon(platformStyle->SingleColorIcon(":/icons/add"));
|
||||
ui->clearButton->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
ui->sendButton->setIcon(platformStyle->SingleColorIcon(":/icons/send"));
|
||||
}
|
||||
|
||||
GUIUtil::setupAddressWidget(ui->lineEditCoinControlChange, this);
|
||||
|
||||
|
@ -364,7 +365,7 @@ void SendCoinsDialog::accept()
|
|||
|
||||
SendCoinsEntry *SendCoinsDialog::addEntry()
|
||||
{
|
||||
SendCoinsEntry *entry = new SendCoinsEntry(this);
|
||||
SendCoinsEntry *entry = new SendCoinsEntry(platformStyle, this);
|
||||
entry->setModel(model);
|
||||
ui->entries->addWidget(entry);
|
||||
connect(entry, SIGNAL(removeEntry(SendCoinsEntry*)), this, SLOT(removeEntry(SendCoinsEntry*)));
|
||||
|
@ -711,7 +712,7 @@ void SendCoinsDialog::coinControlFeatureChanged(bool checked)
|
|||
// Coin Control: button inputs -> show actual coin control dialog
|
||||
void SendCoinsDialog::coinControlButtonClicked()
|
||||
{
|
||||
CoinControlDialog dlg;
|
||||
CoinControlDialog dlg(platformStyle);
|
||||
dlg.setModel(model);
|
||||
dlg.exec();
|
||||
coinControlUpdateLabels();
|
||||
|
|
|
@ -12,6 +12,7 @@
|
|||
|
||||
class ClientModel;
|
||||
class OptionsModel;
|
||||
class PlatformStyle;
|
||||
class SendCoinsEntry;
|
||||
class SendCoinsRecipient;
|
||||
|
||||
|
@ -31,7 +32,7 @@ class SendCoinsDialog : public QDialog
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit SendCoinsDialog(QWidget *parent = 0);
|
||||
explicit SendCoinsDialog(const PlatformStyle *platformStyle, QWidget *parent = 0);
|
||||
~SendCoinsDialog();
|
||||
|
||||
void setClientModel(ClientModel *clientModel);
|
||||
|
@ -60,6 +61,7 @@ private:
|
|||
WalletModel *model;
|
||||
bool fNewRecipientAllowed;
|
||||
bool fFeeMinimized;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
// Process WalletModel::SendCoinsReturn and generate a pair consisting
|
||||
// of a message and message flags for use in Q_EMIT message().
|
||||
|
|
|
@ -9,30 +9,30 @@
|
|||
#include "addresstablemodel.h"
|
||||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
#include "walletmodel.h"
|
||||
|
||||
#include <QApplication>
|
||||
#include <QClipboard>
|
||||
|
||||
SendCoinsEntry::SendCoinsEntry(QWidget *parent) :
|
||||
SendCoinsEntry::SendCoinsEntry(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QStackedWidget(parent),
|
||||
ui(new Ui::SendCoinsEntry),
|
||||
model(0)
|
||||
model(0),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
ui->addressBookButton->setIcon(SingleColorIcon(":/icons/address-book"));
|
||||
ui->pasteButton->setIcon(SingleColorIcon(":/icons/editpaste"));
|
||||
ui->deleteButton->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->deleteButton_is->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->deleteButton_s->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->addressBookButton->setIcon(platformStyle->SingleColorIcon(":/icons/address-book"));
|
||||
ui->pasteButton->setIcon(platformStyle->SingleColorIcon(":/icons/editpaste"));
|
||||
ui->deleteButton->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
ui->deleteButton_is->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
ui->deleteButton_s->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
|
||||
setCurrentWidget(ui->SendCoins);
|
||||
|
||||
#ifdef Q_OS_MAC
|
||||
ui->payToLayout->setSpacing(4);
|
||||
#endif
|
||||
if (platformStyle->getUseExtraSpacing())
|
||||
ui->payToLayout->setSpacing(4);
|
||||
#if QT_VERSION >= 0x040700
|
||||
ui->addAsLabel->setPlaceholderText(tr("Enter a label for this address to add it to your address book"));
|
||||
#endif
|
||||
|
@ -65,7 +65,7 @@ void SendCoinsEntry::on_addressBookButton_clicked()
|
|||
{
|
||||
if(!model)
|
||||
return;
|
||||
AddressBookPage dlg(AddressBookPage::ForSelection, AddressBookPage::SendingTab, this);
|
||||
AddressBookPage dlg(platformStyle, AddressBookPage::ForSelection, AddressBookPage::SendingTab, this);
|
||||
dlg.setModel(model->getAddressTableModel());
|
||||
if(dlg.exec())
|
||||
{
|
||||
|
|
|
@ -10,6 +10,7 @@
|
|||
#include <QStackedWidget>
|
||||
|
||||
class WalletModel;
|
||||
class PlatformStyle;
|
||||
|
||||
namespace Ui {
|
||||
class SendCoinsEntry;
|
||||
|
@ -25,7 +26,7 @@ class SendCoinsEntry : public QStackedWidget
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit SendCoinsEntry(QWidget *parent = 0);
|
||||
explicit SendCoinsEntry(const PlatformStyle *platformStyle, QWidget *parent = 0);
|
||||
~SendCoinsEntry();
|
||||
|
||||
void setModel(WalletModel *model);
|
||||
|
@ -64,6 +65,7 @@ private:
|
|||
SendCoinsRecipient recipient;
|
||||
Ui::SendCoinsEntry *ui;
|
||||
WalletModel *model;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
bool updateLabel(const QString &address);
|
||||
};
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
|
||||
#include "addressbookpage.h"
|
||||
#include "guiutil.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
#include "walletmodel.h"
|
||||
|
||||
#include "base58.h"
|
||||
|
@ -20,21 +20,22 @@
|
|||
|
||||
#include <QClipboard>
|
||||
|
||||
SignVerifyMessageDialog::SignVerifyMessageDialog(QWidget *parent) :
|
||||
SignVerifyMessageDialog::SignVerifyMessageDialog(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QDialog(parent),
|
||||
ui(new Ui::SignVerifyMessageDialog),
|
||||
model(0)
|
||||
model(0),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
ui->addressBookButton_SM->setIcon(SingleColorIcon(":/icons/address-book"));
|
||||
ui->pasteButton_SM->setIcon(SingleColorIcon(":/icons/editpaste"));
|
||||
ui->copySignatureButton_SM->setIcon(SingleColorIcon(":/icons/editcopy"));
|
||||
ui->signMessageButton_SM->setIcon(SingleColorIcon(":/icons/edit"));
|
||||
ui->clearButton_SM->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->addressBookButton_VM->setIcon(SingleColorIcon(":/icons/address-book"));
|
||||
ui->verifyMessageButton_VM->setIcon(SingleColorIcon(":/icons/transaction_0"));
|
||||
ui->clearButton_VM->setIcon(SingleColorIcon(":/icons/remove"));
|
||||
ui->addressBookButton_SM->setIcon(platformStyle->SingleColorIcon(":/icons/address-book"));
|
||||
ui->pasteButton_SM->setIcon(platformStyle->SingleColorIcon(":/icons/editpaste"));
|
||||
ui->copySignatureButton_SM->setIcon(platformStyle->SingleColorIcon(":/icons/editcopy"));
|
||||
ui->signMessageButton_SM->setIcon(platformStyle->SingleColorIcon(":/icons/edit"));
|
||||
ui->clearButton_SM->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
ui->addressBookButton_VM->setIcon(platformStyle->SingleColorIcon(":/icons/address-book"));
|
||||
ui->verifyMessageButton_VM->setIcon(platformStyle->SingleColorIcon(":/icons/transaction_0"));
|
||||
ui->clearButton_VM->setIcon(platformStyle->SingleColorIcon(":/icons/remove"));
|
||||
|
||||
#if QT_VERSION >= 0x040700
|
||||
ui->signatureOut_SM->setPlaceholderText(tr("Click \"Sign Message\" to generate signature"));
|
||||
|
@ -94,7 +95,7 @@ void SignVerifyMessageDialog::on_addressBookButton_SM_clicked()
|
|||
{
|
||||
if (model && model->getAddressTableModel())
|
||||
{
|
||||
AddressBookPage dlg(AddressBookPage::ForSelection, AddressBookPage::ReceivingTab, this);
|
||||
AddressBookPage dlg(platformStyle, AddressBookPage::ForSelection, AddressBookPage::ReceivingTab, this);
|
||||
dlg.setModel(model->getAddressTableModel());
|
||||
if (dlg.exec())
|
||||
{
|
||||
|
@ -185,7 +186,7 @@ void SignVerifyMessageDialog::on_addressBookButton_VM_clicked()
|
|||
{
|
||||
if (model && model->getAddressTableModel())
|
||||
{
|
||||
AddressBookPage dlg(AddressBookPage::ForSelection, AddressBookPage::SendingTab, this);
|
||||
AddressBookPage dlg(platformStyle, AddressBookPage::ForSelection, AddressBookPage::SendingTab, this);
|
||||
dlg.setModel(model->getAddressTableModel());
|
||||
if (dlg.exec())
|
||||
{
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
|
||||
#include <QDialog>
|
||||
|
||||
class PlatformStyle;
|
||||
class WalletModel;
|
||||
|
||||
namespace Ui {
|
||||
|
@ -18,7 +19,7 @@ class SignVerifyMessageDialog : public QDialog
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit SignVerifyMessageDialog(QWidget *parent);
|
||||
explicit SignVerifyMessageDialog(const PlatformStyle *platformStyle, QWidget *parent);
|
||||
~SignVerifyMessageDialog();
|
||||
|
||||
void setModel(WalletModel *model);
|
||||
|
@ -34,6 +35,7 @@ protected:
|
|||
private:
|
||||
Ui::SignVerifyMessageDialog *ui;
|
||||
WalletModel *model;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
private Q_SLOTS:
|
||||
/* sign message */
|
||||
|
|
|
@ -8,7 +8,7 @@
|
|||
#include "guiconstants.h"
|
||||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
#include "transactiondesc.h"
|
||||
#include "transactionrecord.h"
|
||||
#include "walletmodel.h"
|
||||
|
@ -222,12 +222,13 @@ public:
|
|||
}
|
||||
};
|
||||
|
||||
TransactionTableModel::TransactionTableModel(CWallet* wallet, WalletModel *parent):
|
||||
TransactionTableModel::TransactionTableModel(const PlatformStyle *platformStyle, CWallet* wallet, WalletModel *parent):
|
||||
QAbstractTableModel(parent),
|
||||
wallet(wallet),
|
||||
walletModel(parent),
|
||||
priv(new TransactionTablePriv(wallet, this)),
|
||||
fProcessingQueuedTransactions(false)
|
||||
fProcessingQueuedTransactions(false),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
columns << QString() << QString() << tr("Date") << tr("Type") << tr("Label") << BitcoinUnits::getAmountColumnTitle(walletModel->getOptionsModel()->getDisplayUnit());
|
||||
priv->refreshWallet();
|
||||
|
@ -521,7 +522,7 @@ QVariant TransactionTableModel::data(const QModelIndex &index, int role) const
|
|||
case Qt::DecorationRole:
|
||||
{
|
||||
QIcon icon = qvariant_cast<QIcon>(index.data(RawDecorationRole));
|
||||
return TextColorIcon(icon);
|
||||
return platformStyle->TextColorIcon(icon);
|
||||
}
|
||||
case Qt::DisplayRole:
|
||||
switch(index.column())
|
||||
|
|
|
@ -10,6 +10,7 @@
|
|||
#include <QAbstractTableModel>
|
||||
#include <QStringList>
|
||||
|
||||
class PlatformStyle;
|
||||
class TransactionRecord;
|
||||
class TransactionTablePriv;
|
||||
class WalletModel;
|
||||
|
@ -23,7 +24,7 @@ class TransactionTableModel : public QAbstractTableModel
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit TransactionTableModel(CWallet* wallet, WalletModel *parent = 0);
|
||||
explicit TransactionTableModel(const PlatformStyle *platformStyle, CWallet* wallet, WalletModel *parent = 0);
|
||||
~TransactionTableModel();
|
||||
|
||||
enum ColumnIndex {
|
||||
|
@ -82,6 +83,7 @@ private:
|
|||
QStringList columns;
|
||||
TransactionTablePriv *priv;
|
||||
bool fProcessingQueuedTransactions;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
void subscribeToCoreSignals();
|
||||
void unsubscribeFromCoreSignals();
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
#include "editaddressdialog.h"
|
||||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "scicon.h"
|
||||
#include "platformstyle.h"
|
||||
#include "transactiondescdialog.h"
|
||||
#include "transactionfilterproxy.h"
|
||||
#include "transactionrecord.h"
|
||||
|
@ -35,7 +35,7 @@
|
|||
#include <QUrl>
|
||||
#include <QVBoxLayout>
|
||||
|
||||
TransactionView::TransactionView(QWidget *parent) :
|
||||
TransactionView::TransactionView(const PlatformStyle *platformStyle, QWidget *parent) :
|
||||
QWidget(parent), model(0), transactionProxyModel(0),
|
||||
transactionView(0)
|
||||
{
|
||||
|
@ -44,27 +44,28 @@ TransactionView::TransactionView(QWidget *parent) :
|
|||
|
||||
QHBoxLayout *hlayout = new QHBoxLayout();
|
||||
hlayout->setContentsMargins(0,0,0,0);
|
||||
#ifdef Q_OS_MAC
|
||||
hlayout->setSpacing(5);
|
||||
hlayout->addSpacing(26);
|
||||
#else
|
||||
hlayout->setSpacing(0);
|
||||
hlayout->addSpacing(23);
|
||||
#endif
|
||||
|
||||
if (platformStyle->getUseExtraSpacing()) {
|
||||
hlayout->setSpacing(5);
|
||||
hlayout->addSpacing(26);
|
||||
} else {
|
||||
hlayout->setSpacing(0);
|
||||
hlayout->addSpacing(23);
|
||||
}
|
||||
|
||||
watchOnlyWidget = new QComboBox(this);
|
||||
watchOnlyWidget->setFixedWidth(24);
|
||||
watchOnlyWidget->addItem("", TransactionFilterProxy::WatchOnlyFilter_All);
|
||||
watchOnlyWidget->addItem(SingleColorIcon(":/icons/eye_plus"), "", TransactionFilterProxy::WatchOnlyFilter_Yes);
|
||||
watchOnlyWidget->addItem(SingleColorIcon(":/icons/eye_minus"), "", TransactionFilterProxy::WatchOnlyFilter_No);
|
||||
watchOnlyWidget->addItem(platformStyle->SingleColorIcon(":/icons/eye_plus"), "", TransactionFilterProxy::WatchOnlyFilter_Yes);
|
||||
watchOnlyWidget->addItem(platformStyle->SingleColorIcon(":/icons/eye_minus"), "", TransactionFilterProxy::WatchOnlyFilter_No);
|
||||
hlayout->addWidget(watchOnlyWidget);
|
||||
|
||||
dateWidget = new QComboBox(this);
|
||||
#ifdef Q_OS_MAC
|
||||
dateWidget->setFixedWidth(121);
|
||||
#else
|
||||
dateWidget->setFixedWidth(120);
|
||||
#endif
|
||||
if (platformStyle->getUseExtraSpacing()) {
|
||||
dateWidget->setFixedWidth(121);
|
||||
} else {
|
||||
dateWidget->setFixedWidth(120);
|
||||
}
|
||||
dateWidget->addItem(tr("All"), All);
|
||||
dateWidget->addItem(tr("Today"), Today);
|
||||
dateWidget->addItem(tr("This week"), ThisWeek);
|
||||
|
@ -75,11 +76,11 @@ TransactionView::TransactionView(QWidget *parent) :
|
|||
hlayout->addWidget(dateWidget);
|
||||
|
||||
typeWidget = new QComboBox(this);
|
||||
#ifdef Q_OS_MAC
|
||||
typeWidget->setFixedWidth(121);
|
||||
#else
|
||||
typeWidget->setFixedWidth(120);
|
||||
#endif
|
||||
if (platformStyle->getUseExtraSpacing()) {
|
||||
typeWidget->setFixedWidth(121);
|
||||
} else {
|
||||
typeWidget->setFixedWidth(120);
|
||||
}
|
||||
|
||||
typeWidget->addItem(tr("All"), TransactionFilterProxy::ALL_TYPES);
|
||||
typeWidget->addItem(tr("Received with"), TransactionFilterProxy::TYPE(TransactionRecord::RecvWithAddress) |
|
||||
|
@ -102,11 +103,11 @@ TransactionView::TransactionView(QWidget *parent) :
|
|||
#if QT_VERSION >= 0x040700
|
||||
amountWidget->setPlaceholderText(tr("Min amount"));
|
||||
#endif
|
||||
#ifdef Q_OS_MAC
|
||||
amountWidget->setFixedWidth(97);
|
||||
#else
|
||||
amountWidget->setFixedWidth(100);
|
||||
#endif
|
||||
if (platformStyle->getUseExtraSpacing()) {
|
||||
amountWidget->setFixedWidth(97);
|
||||
} else {
|
||||
amountWidget->setFixedWidth(100);
|
||||
}
|
||||
amountWidget->setValidator(new QDoubleValidator(0, 1e20, 8, this));
|
||||
hlayout->addWidget(amountWidget);
|
||||
|
||||
|
@ -121,11 +122,11 @@ TransactionView::TransactionView(QWidget *parent) :
|
|||
vlayout->setSpacing(0);
|
||||
int width = view->verticalScrollBar()->sizeHint().width();
|
||||
// Cover scroll bar width with spacing
|
||||
#ifdef Q_OS_MAC
|
||||
hlayout->addSpacing(width+2);
|
||||
#else
|
||||
hlayout->addSpacing(width);
|
||||
#endif
|
||||
if (platformStyle->getUseExtraSpacing()) {
|
||||
hlayout->addSpacing(width+2);
|
||||
} else {
|
||||
hlayout->addSpacing(width);
|
||||
}
|
||||
// Always show scroll bar
|
||||
view->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
|
||||
view->setTabKeyNavigation(false);
|
||||
|
|
|
@ -10,6 +10,7 @@
|
|||
#include <QWidget>
|
||||
#include <QKeyEvent>
|
||||
|
||||
class PlatformStyle;
|
||||
class TransactionFilterProxy;
|
||||
class WalletModel;
|
||||
|
||||
|
@ -32,7 +33,7 @@ class TransactionView : public QWidget
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit TransactionView(QWidget *parent = 0);
|
||||
explicit TransactionView(const PlatformStyle *platformStyle, QWidget *parent = 0);
|
||||
|
||||
void setModel(WalletModel *model);
|
||||
|
||||
|
|
|
@ -12,9 +12,10 @@
|
|||
#include <QHBoxLayout>
|
||||
#include <QLabel>
|
||||
|
||||
WalletFrame::WalletFrame(BitcoinGUI *_gui) :
|
||||
WalletFrame::WalletFrame(const PlatformStyle *platformStyle, BitcoinGUI *_gui) :
|
||||
QFrame(_gui),
|
||||
gui(_gui)
|
||||
gui(_gui),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
// Leave HBox hook for adding a list view later
|
||||
QHBoxLayout *walletFrameLayout = new QHBoxLayout(this);
|
||||
|
@ -42,7 +43,7 @@ bool WalletFrame::addWallet(const QString& name, WalletModel *walletModel)
|
|||
if (!gui || !clientModel || !walletModel || mapWalletViews.count(name) > 0)
|
||||
return false;
|
||||
|
||||
WalletView *walletView = new WalletView(this);
|
||||
WalletView *walletView = new WalletView(platformStyle, this);
|
||||
walletView->setBitcoinGUI(gui);
|
||||
walletView->setClientModel(clientModel);
|
||||
walletView->setWalletModel(walletModel);
|
||||
|
|
|
@ -10,6 +10,7 @@
|
|||
|
||||
class BitcoinGUI;
|
||||
class ClientModel;
|
||||
class PlatformStyle;
|
||||
class SendCoinsRecipient;
|
||||
class WalletModel;
|
||||
class WalletView;
|
||||
|
@ -23,7 +24,7 @@ class WalletFrame : public QFrame
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit WalletFrame(BitcoinGUI *_gui = 0);
|
||||
explicit WalletFrame(const PlatformStyle *platformStyle, BitcoinGUI *_gui = 0);
|
||||
~WalletFrame();
|
||||
|
||||
void setClientModel(ClientModel *clientModel);
|
||||
|
@ -45,6 +46,8 @@ private:
|
|||
|
||||
bool bOutOfSync;
|
||||
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
WalletView *currentWalletView();
|
||||
|
||||
public Q_SLOTS:
|
||||
|
|
|
@ -27,7 +27,7 @@
|
|||
|
||||
#include <boost/foreach.hpp>
|
||||
|
||||
WalletModel::WalletModel(CWallet *wallet, OptionsModel *optionsModel, QObject *parent) :
|
||||
WalletModel::WalletModel(const PlatformStyle *platformStyle, CWallet *wallet, OptionsModel *optionsModel, QObject *parent) :
|
||||
QObject(parent), wallet(wallet), optionsModel(optionsModel), addressTableModel(0),
|
||||
transactionTableModel(0),
|
||||
recentRequestsTableModel(0),
|
||||
|
@ -39,7 +39,7 @@ WalletModel::WalletModel(CWallet *wallet, OptionsModel *optionsModel, QObject *p
|
|||
fForceCheckBalanceChanged = false;
|
||||
|
||||
addressTableModel = new AddressTableModel(wallet, this);
|
||||
transactionTableModel = new TransactionTableModel(wallet, this);
|
||||
transactionTableModel = new TransactionTableModel(platformStyle, wallet, this);
|
||||
recentRequestsTableModel = new RecentRequestsTableModel(wallet, this);
|
||||
|
||||
// This timer will be fired repeatedly to update the balance
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
|
||||
class AddressTableModel;
|
||||
class OptionsModel;
|
||||
class PlatformStyle;
|
||||
class RecentRequestsTableModel;
|
||||
class TransactionTableModel;
|
||||
class WalletModelTransaction;
|
||||
|
@ -100,7 +101,7 @@ class WalletModel : public QObject
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit WalletModel(CWallet *wallet, OptionsModel *optionsModel, QObject *parent = 0);
|
||||
explicit WalletModel(const PlatformStyle *platformStyle, CWallet *wallet, OptionsModel *optionsModel, QObject *parent = 0);
|
||||
~WalletModel();
|
||||
|
||||
enum StatusCode // Returned by sendCoins
|
||||
|
|
|
@ -11,8 +11,8 @@
|
|||
#include "guiutil.h"
|
||||
#include "optionsmodel.h"
|
||||
#include "overviewpage.h"
|
||||
#include "platformstyle.h"
|
||||
#include "receivecoinsdialog.h"
|
||||
#include "scicon.h"
|
||||
#include "sendcoinsdialog.h"
|
||||
#include "signverifymessagedialog.h"
|
||||
#include "transactiontablemodel.h"
|
||||
|
@ -29,31 +29,32 @@
|
|||
#include <QPushButton>
|
||||
#include <QVBoxLayout>
|
||||
|
||||
WalletView::WalletView(QWidget *parent):
|
||||
WalletView::WalletView(const PlatformStyle *platformStyle, QWidget *parent):
|
||||
QStackedWidget(parent),
|
||||
clientModel(0),
|
||||
walletModel(0)
|
||||
walletModel(0),
|
||||
platformStyle(platformStyle)
|
||||
{
|
||||
// Create tabs
|
||||
overviewPage = new OverviewPage();
|
||||
overviewPage = new OverviewPage(platformStyle);
|
||||
|
||||
transactionsPage = new QWidget(this);
|
||||
QVBoxLayout *vbox = new QVBoxLayout();
|
||||
QHBoxLayout *hbox_buttons = new QHBoxLayout();
|
||||
transactionView = new TransactionView(this);
|
||||
transactionView = new TransactionView(platformStyle, this);
|
||||
vbox->addWidget(transactionView);
|
||||
QPushButton *exportButton = new QPushButton(tr("&Export"), this);
|
||||
exportButton->setToolTip(tr("Export the data in the current tab to a file"));
|
||||
#ifndef Q_OS_MAC // Icons on push buttons are very uncommon on Mac
|
||||
exportButton->setIcon(SingleColorIcon(":/icons/export"));
|
||||
#endif
|
||||
if (platformStyle->getImagesOnButtons()) {
|
||||
exportButton->setIcon(platformStyle->SingleColorIcon(":/icons/export"));
|
||||
}
|
||||
hbox_buttons->addStretch();
|
||||
hbox_buttons->addWidget(exportButton);
|
||||
vbox->addLayout(hbox_buttons);
|
||||
transactionsPage->setLayout(vbox);
|
||||
|
||||
receiveCoinsPage = new ReceiveCoinsDialog();
|
||||
sendCoinsPage = new SendCoinsDialog();
|
||||
receiveCoinsPage = new ReceiveCoinsDialog(platformStyle);
|
||||
sendCoinsPage = new SendCoinsDialog(platformStyle);
|
||||
|
||||
addWidget(overviewPage);
|
||||
addWidget(transactionsPage);
|
||||
|
@ -182,7 +183,7 @@ void WalletView::gotoSendCoinsPage(QString addr)
|
|||
void WalletView::gotoSignMessageTab(QString addr)
|
||||
{
|
||||
// calls show() in showTab_SM()
|
||||
SignVerifyMessageDialog *signVerifyMessageDialog = new SignVerifyMessageDialog(this);
|
||||
SignVerifyMessageDialog *signVerifyMessageDialog = new SignVerifyMessageDialog(platformStyle, this);
|
||||
signVerifyMessageDialog->setAttribute(Qt::WA_DeleteOnClose);
|
||||
signVerifyMessageDialog->setModel(walletModel);
|
||||
signVerifyMessageDialog->showTab_SM(true);
|
||||
|
@ -194,7 +195,7 @@ void WalletView::gotoSignMessageTab(QString addr)
|
|||
void WalletView::gotoVerifyMessageTab(QString addr)
|
||||
{
|
||||
// calls show() in showTab_VM()
|
||||
SignVerifyMessageDialog *signVerifyMessageDialog = new SignVerifyMessageDialog(this);
|
||||
SignVerifyMessageDialog *signVerifyMessageDialog = new SignVerifyMessageDialog(platformStyle, this);
|
||||
signVerifyMessageDialog->setAttribute(Qt::WA_DeleteOnClose);
|
||||
signVerifyMessageDialog->setModel(walletModel);
|
||||
signVerifyMessageDialog->showTab_VM(true);
|
||||
|
@ -272,7 +273,7 @@ void WalletView::usedSendingAddresses()
|
|||
{
|
||||
if(!walletModel)
|
||||
return;
|
||||
AddressBookPage *dlg = new AddressBookPage(AddressBookPage::ForEditing, AddressBookPage::SendingTab, this);
|
||||
AddressBookPage *dlg = new AddressBookPage(platformStyle, AddressBookPage::ForEditing, AddressBookPage::SendingTab, this);
|
||||
dlg->setAttribute(Qt::WA_DeleteOnClose);
|
||||
dlg->setModel(walletModel->getAddressTableModel());
|
||||
dlg->show();
|
||||
|
@ -282,7 +283,7 @@ void WalletView::usedReceivingAddresses()
|
|||
{
|
||||
if(!walletModel)
|
||||
return;
|
||||
AddressBookPage *dlg = new AddressBookPage(AddressBookPage::ForEditing, AddressBookPage::ReceivingTab, this);
|
||||
AddressBookPage *dlg = new AddressBookPage(platformStyle, AddressBookPage::ForEditing, AddressBookPage::ReceivingTab, this);
|
||||
dlg->setAttribute(Qt::WA_DeleteOnClose);
|
||||
dlg->setModel(walletModel->getAddressTableModel());
|
||||
dlg->show();
|
||||
|
|
|
@ -12,6 +12,7 @@
|
|||
class BitcoinGUI;
|
||||
class ClientModel;
|
||||
class OverviewPage;
|
||||
class PlatformStyle;
|
||||
class ReceiveCoinsDialog;
|
||||
class SendCoinsDialog;
|
||||
class SendCoinsRecipient;
|
||||
|
@ -34,7 +35,7 @@ class WalletView : public QStackedWidget
|
|||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit WalletView(QWidget *parent);
|
||||
explicit WalletView(const PlatformStyle *platformStyle, QWidget *parent);
|
||||
~WalletView();
|
||||
|
||||
void setBitcoinGUI(BitcoinGUI *gui);
|
||||
|
@ -64,6 +65,7 @@ private:
|
|||
TransactionView *transactionView;
|
||||
|
||||
QProgressDialog *progressDialog;
|
||||
const PlatformStyle *platformStyle;
|
||||
|
||||
public Q_SLOTS:
|
||||
/** Switch to overview (home) page */
|
||||
|
|
Loading…
Reference in a new issue