diff options
| author | João Barbosa <[email protected]> | 2019-05-27 19:07:05 +0100 |
|---|---|---|
| committer | João Barbosa <[email protected]> | 2019-07-08 15:03:49 +0100 |
| commit | 224eb9534a8d2b0f140ecb0cc00c61af8ba1da4e (patch) | |
| tree | 18a876a6a2ec1af930fa8e9e1300d4be89ca0424 /src/qt/bitcoingui.cpp | |
| parent | Merge #15687: test: tool wallet test coverage for unexpected writes to wallet (diff) | |
| download | discoin-224eb9534a8d2b0f140ecb0cc00c61af8ba1da4e.tar.xz discoin-224eb9534a8d2b0f140ecb0cc00c61af8ba1da4e.zip | |
gui: Sort wallets in open wallet menu
Diffstat (limited to 'src/qt/bitcoingui.cpp')
| -rw-r--r-- | src/qt/bitcoingui.cpp | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/src/qt/bitcoingui.cpp b/src/qt/bitcoingui.cpp index babb2ce51..1fa05d550 100644 --- a/src/qt/bitcoingui.cpp +++ b/src/qt/bitcoingui.cpp @@ -371,13 +371,12 @@ void BitcoinGUI::createActions() connect(openAction, &QAction::triggered, this, &BitcoinGUI::openClicked); connect(m_open_wallet_menu, &QMenu::aboutToShow, [this] { m_open_wallet_menu->clear(); - std::vector<std::string> available_wallets = m_wallet_controller->getWalletsAvailableToOpen(); - std::vector<std::string> wallets = m_node.listWalletDir(); - for (const auto& path : wallets) { + for (const std::pair<const std::string, bool>& i : m_wallet_controller->listWalletDir()) { + const std::string& path = i.first; QString name = path.empty() ? QString("["+tr("default wallet")+"]") : QString::fromStdString(path); QAction* action = m_open_wallet_menu->addAction(name); - if (std::find(available_wallets.begin(), available_wallets.end(), path) == available_wallets.end()) { + if (i.second) { // This wallet is already loaded action->setEnabled(false); continue; @@ -410,7 +409,7 @@ void BitcoinGUI::createActions() assert(invoked); }); } - if (wallets.empty()) { + if (m_open_wallet_menu->isEmpty()) { QAction* action = m_open_wallet_menu->addAction(tr("No wallets available")); action->setEnabled(false); } |