bb976499bf
705c1f0648c72aa97e0ee699ff9a3da23fc9bd61 qt, refactor: Fix 'buttonClicked is deprecated' warnings (Hennadii Stepanov) c2f4e5ea1d6f01713ac69aaf6018884028aa55bd qt, refactor: Fix 'split is deprecated' warnings (Hennadii Stepanov) 8e12d6996116e786e928077b22d9f47cee27319e qt, refactor: Fix 'QFlags is deprecated' warnings (Hennadii Stepanov) fa5749c805878304c107bcae0ae5ffa401dc7c4d qt, refactor: Fix 'pixmap is deprecated' warnings (Hennadii Stepanov) b02264cb5dfcef50eec8a6346471cbaa25370e00 qt, refactor: Fix 'QDateTime is deprecated' warnings (Hennadii Stepanov) Pull request description: [What's New in Qt 5.15](https://doc.qt.io/qt-5/whatsnew515.html#deprecated-modules): > To help preparing for the transition to Qt 6, numerous classes and member functions that will be removed from Qt 6.0 have been marked as deprecated in the Qt 5.15 release. Fixes #36 ACKs for top commit: jonasschnelli: utACK 705c1f0648c72aa97e0ee699ff9a3da23fc9bd61 promag: Tested ACK 705c1f0648c72aa97e0ee699ff9a3da23fc9bd61 on macos with Apple clang version 11.0.3 (clang-1103.0.32.62) and brew qt 5.15.1. Tree-SHA512: 29e00535b4583ceec0dfb29612e86ee29bdea13651b548c6d22167917a4a10464af49160a12b05151030699f690f437ebb9c4ae9f130f66a722415222165b44f |
||
---|---|---|
.. | ||
android | ||
forms | ||
locale | ||
res | ||
test | ||
addressbookpage.cpp | ||
addressbookpage.h | ||
addresstablemodel.cpp | ||
addresstablemodel.h | ||
appearancewidget.cpp | ||
appearancewidget.h | ||
askpassphrasedialog.cpp | ||
askpassphrasedialog.h | ||
bantablemodel.cpp | ||
bantablemodel.h | ||
bitcoin.cpp | ||
bitcoin.h | ||
bitcoinaddressvalidator.cpp | ||
bitcoinaddressvalidator.h | ||
bitcoinamountfield.cpp | ||
bitcoinamountfield.h | ||
bitcoingui.cpp | ||
bitcoingui.h | ||
bitcoinunits.cpp | ||
bitcoinunits.h | ||
clientmodel.cpp | ||
clientmodel.h | ||
coincontroldialog.cpp | ||
coincontroldialog.h | ||
coincontroltreewidget.cpp | ||
coincontroltreewidget.h | ||
createwalletdialog.cpp | ||
createwalletdialog.h | ||
csvmodelwriter.cpp | ||
csvmodelwriter.h | ||
dash_locale.qrc | ||
dash.qrc | ||
dashstrings.cpp | ||
editaddressdialog.cpp | ||
editaddressdialog.h | ||
governancelist.cpp | ||
governancelist.h | ||
guiconstants.h | ||
guiutil.cpp | ||
guiutil.h | ||
intro.cpp | ||
intro.h | ||
macdockiconhandler.h | ||
macdockiconhandler.mm | ||
macnotificationhandler.h | ||
macnotificationhandler.mm | ||
macos_appnap.h | ||
macos_appnap.mm | ||
main.cpp | ||
masternodelist.cpp | ||
masternodelist.h | ||
modaloverlay.cpp | ||
modaloverlay.h | ||
networkstyle.cpp | ||
networkstyle.h | ||
notificator.cpp | ||
notificator.h | ||
openuridialog.cpp | ||
openuridialog.h | ||
optionsdialog.cpp | ||
optionsdialog.h | ||
optionsmodel.cpp | ||
optionsmodel.h | ||
overviewpage.cpp | ||
overviewpage.h | ||
paymentserver.cpp | ||
paymentserver.h | ||
peertablemodel.cpp | ||
peertablemodel.h | ||
qrdialog.cpp | ||
qrdialog.h | ||
qrimagewidget.cpp | ||
qrimagewidget.h | ||
qvalidatedlineedit.cpp | ||
qvalidatedlineedit.h | ||
qvaluecombobox.cpp | ||
qvaluecombobox.h | ||
README.md | ||
receivecoinsdialog.cpp | ||
receivecoinsdialog.h | ||
receiverequestdialog.cpp | ||
receiverequestdialog.h | ||
recentrequeststablemodel.cpp | ||
recentrequeststablemodel.h | ||
rpcconsole.cpp | ||
rpcconsole.h | ||
sendcoinsdialog.cpp | ||
sendcoinsdialog.h | ||
sendcoinsentry.cpp | ||
sendcoinsentry.h | ||
sendcoinsrecipient.h | ||
signverifymessagedialog.cpp | ||
signverifymessagedialog.h | ||
splashscreen.cpp | ||
splashscreen.h | ||
trafficgraphdata.cpp | ||
trafficgraphdata.h | ||
trafficgraphwidget.cpp | ||
trafficgraphwidget.h | ||
transactiondesc.cpp | ||
transactiondesc.h | ||
transactiondescdialog.cpp | ||
transactiondescdialog.h | ||
transactionfilterproxy.cpp | ||
transactionfilterproxy.h | ||
transactionrecord.cpp | ||
transactionrecord.h | ||
transactiontablemodel.cpp | ||
transactiontablemodel.h | ||
transactionview.cpp | ||
transactionview.h | ||
utilitydialog.cpp | ||
utilitydialog.h | ||
walletcontroller.cpp | ||
walletcontroller.h | ||
walletframe.cpp | ||
walletframe.h | ||
walletmodel.cpp | ||
walletmodel.h | ||
walletmodeltransaction.cpp | ||
walletmodeltransaction.h | ||
walletview.cpp | ||
walletview.h | ||
winshutdownmonitor.cpp | ||
winshutdownmonitor.h |
This directory contains the DashQT graphical user interface (GUI). It uses the cross-platform framework Qt.
The current precise version for Qt 5 is specified in qt.mk. Qt 4 is not supported.
Compile and run
See build instructions (macOS, Windows, Unix, etc).
To run:
./src/qt/dash-qt
Files and directories
forms
Contains Designer UI files. They are created with Qt Creator, but can be edited using any text editor.
locale
Contains translations. They are periodically updated. The process is described here.
res
Resources such as the icon.
test
Tests.
bitcoingui.(h/cpp)
Represents the main window of the Dash UI.
*model.(h/cpp)
The model. When it has a corresponding controller, it generally inherits from QAbstractTableModel. Models that are used by controllers as helpers inherit from other Qt classes like QValidator.
ClientModel is used by the main application bitcoingui
and several models like peertablemodel
.
*page.(h/cpp)
A controller. :NAMEpage.cpp
generally includes :NAMEmodel.h
and forms/:NAME.page.ui
with a similar :NAME
.
*dialog.(h/cpp)
Various dialogs, e.g. to open a URL. Inherit from QDialog.
paymentserver.(h/cpp)
Used to process BIP21 payment URI requests. Also handles URI based application switching (e.g. when following a dash:... link from a browser).
walletview.(h/cpp)
Represents the view to a single wallet.
Other .h/cpp files
- UI elements like BitcoinAmountField, which inherit from QWidget.
bitcoinstrings.cpp
: automatically generatedbitcoinunits.(h/cpp)
: BTC / mBTC / etc handlingcallback.h
guiconstants.h
: UI colors, app name, etcguiutil.h
: several helper functionsmacdockiconhandler.(h/mm)
: macOS dock icon handlermacnotificationhandler.(h/mm)
: display notifications in macOS
Contribute
See CONTRIBUTING.md for general guidelines. Specifically for Qt:
- don't change
local/dash_en.ts
; this happens automatically
Using Qt Creator as IDE
You can use Qt Creator as an IDE. This is especially useful if you want to change the UI layout.
Download and install the community edition of Qt Creator. Uncheck everything except Qt Creator during the installation process.
Instructions for macOS:
- Make sure you installed everything through Homebrew mentioned in the macOS build instructions
- Use
./configure
with the--enable-debug
flag - In Qt Creator do "New Project" -> Import Project -> Import Existing Project
- Enter "dash-qt" as project name, enter src/qt as location
- Leave the file selection as it is
- Confirm the "summary page"
- In the "Projects" tab select "Manage Kits..."
- Select the default "Desktop" kit and select "Clang (x86 64bit in /usr/bin)" as compiler
- Select LLDB as debugger (you might need to set the path to your installation)
- Start debugging with Qt Creator (you might need to the executable to "dash-qt" under "Run", which is where you can also add command line arguments)