ui.labelSecure->setText(map["secure"].toBool() ? tr("Yes") : tr("No"));
auto features = Quassel::Features{map["featureList"].toStringList(), static_cast<Quassel::LegacyFeatures>(map["features"].toUInt())};
- ui.disconnectButton->setVisible(features.isEnabled(Quassel::Feature::RemoteDisconnect));
+ if (features.isEnabled(Quassel::Feature::RemoteDisconnect)) {
+ // Both client and core support it, enable the button
+ ui.disconnectButton->setEnabled(true);
+ ui.disconnectButton->setToolTip(tr("End the client's session, disconnecting it"));
+ } else {
+ // Either core or client doesn't support it, disable the option
+ ui.disconnectButton->setEnabled(false);
+ if (!Client::isCoreFeatureEnabled(Quassel::Feature::RemoteDisconnect)) {
+ // Until RemoteDisconnect was implemented, the Quassel core didn't forward client
+ // features. A client might support features and we'll never hear about it.
+ // This check shouldn't be necessary for later features if the core supports at least
+ // RemoteDisconnect.
+
+ // Core doesn't support this feature (we don't know about the client)
+ ui.disconnectButton->setToolTip(
+ QString("<p>%1</p><p><b>%2</b><br/>%3</p>").arg(
+ tr("End the client's session, disconnecting it"),
+ tr("Your Quassel core does not support this feature"),
+ tr("You need a Quassel core v0.13.0 or newer in order to end connected "
+ "sessions.")));
+ } else {
+ // Client doesn't support this feature
+ ui.disconnectButton->setToolTip(
+ QString("<p>%1</p><p><b>%2</b></p>").arg(
+ tr("End the client's session, disconnecting it"),
+ tr("This client does not support being remotely disconnected")));
+ }
+ }
bool success = false;
_peerId = map["id"].toInt(&success);
void CoreSessionWidget::disconnectClicked()
{
+ // Don't allow the End Session button to be spammed; Quassel's protocol isn't lossy and it
+ // should reach the destination eventually...
+ ui.disconnectButton->setEnabled(false);
+ ui.disconnectButton->setText(tr("Ending session..."));
+
emit disconnectClicked(_peerId);
}