X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fmainpage.cpp;fp=src%2Fqtui%2Fmainpage.cpp;h=4838e251fb573d57ce433bb07ce873525ee61f3e;hp=15f83a89e7c0d12c4494e489f05e8b714831d179;hb=fa8ddc36d262e7de28f56793cebc0e2eb965c421;hpb=ba4218e0fc6775c96b76100712e6d705b197154e diff --git a/src/qtui/mainpage.cpp b/src/qtui/mainpage.cpp index 15f83a89..4838e251 100644 --- a/src/qtui/mainpage.cpp +++ b/src/qtui/mainpage.cpp @@ -37,24 +37,30 @@ MainPage::MainPage(QWidget *parent) : QWidget(parent) layout->addWidget(label); if (Quassel::runMode() != Quassel::Monolithic) { - QPushButton *connectButton = new QPushButton(QIcon::fromTheme("network-connect"), tr("Connect to Core...")); - connectButton->setEnabled(Client::coreConnection()->state() == CoreConnection::Disconnected); + _connectButton = new QPushButton(QIcon::fromTheme("network-connect"), tr("Connect to Core...")); + _connectButton->setEnabled(Client::coreConnection()->state() == CoreConnection::Disconnected); - connect(Client::coreConnection(), &CoreConnection::stateChanged, [connectButton](CoreConnection::ConnectionState state){ - if (state == CoreConnection::Disconnected) { - connectButton->setEnabled(true); - } else { - connectButton->setDisabled(true); - } - }); - connect(connectButton, &QPushButton::clicked, [this](){ - CoreConnectDlg dlg(this); - if (dlg.exec() == QDialog::Accepted) { - AccountId accId = dlg.selectedAccount(); - if (accId.isValid()) - Client::coreConnection()->connectToCore(accId); - } - }); - layout->addWidget(connectButton); + connect(Client::coreConnection(), SIGNAL(stateChanged(CoreConnection::ConnectionState)), this, SLOT(coreConnectionStateChanged())); + connect(_connectButton, SIGNAL(clicked(bool)), this, SLOT(showCoreConnectionDlg())); + layout->addWidget(_connectButton); + } +} + +void MainPage::showCoreConnectionDlg() +{ + CoreConnectDlg dlg(this); + if (dlg.exec() == QDialog::Accepted) { + AccountId accId = dlg.selectedAccount(); + if (accId.isValid()) + Client::coreConnection()->connectToCore(accId); + } +} + +void MainPage::coreConnectionStateChanged() +{ + if (Client::coreConnection()->state() == CoreConnection::Disconnected) { + _connectButton->setEnabled(true); + } else { + _connectButton->setDisabled(true); } }