X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fcoresessionwidget.cpp;h=c0fb8c890c96193f5eabe6e13590744ba4b98312;hp=d31122db21db2f2177ca0b96f808fb55d229cb69;hb=HEAD;hpb=7fe7ca0631d2e8327351806947a1e030eb203cf7 diff --git a/src/qtui/coresessionwidget.cpp b/src/qtui/coresessionwidget.cpp index d31122db..a4c54654 100644 --- a/src/qtui/coresessionwidget.cpp +++ b/src/qtui/coresessionwidget.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2022 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -18,17 +18,18 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ +#include "coresessionwidget.h" + #include #include "client.h" -#include "coresessionwidget.h" +#include "util.h" - -CoreSessionWidget::CoreSessionWidget(QWidget *parent) +CoreSessionWidget::CoreSessionWidget(QWidget* parent) : QWidget(parent) { ui.setupUi(this); - connect(ui.disconnectButton, SIGNAL(released()), this, SLOT(disconnectClicked())); + connect(ui.disconnectButton, &QPushButton::released, this, &CoreSessionWidget::onDisconnectClicked); } void CoreSessionWidget::setData(QMap map) @@ -36,8 +37,13 @@ void CoreSessionWidget::setData(QMap map) ui.sessionGroup->setTitle(map["remoteAddress"].toString()); ui.labelLocation->setText(map["location"].toString()); ui.labelClient->setText(map["clientVersion"].toString()); - ui.labelVersionDate->setText(map["clientVersionDate"].toString()); - ui.labelUptime->setText(map["connectedSince"].toDateTime().toLocalTime().toString(Qt::DateFormat::SystemLocaleShortDate)); + if (map["clientVersionDate"].toString().isEmpty()) { + ui.labelVersionDate->setText(QString("%1").arg(tr("Unknown date"))); + } + else { + ui.labelVersionDate->setText(tryFormatUnixEpoch(map["clientVersionDate"].toString(), Qt::DateFormat::DefaultLocaleShortDate)); + } + ui.labelUptime->setText(map["connectedSince"].toDateTime().toLocalTime().toString(Qt::DateFormat::DefaultLocaleShortDate)); if (map["location"].toString().isEmpty()) { ui.labelLocation->hide(); ui.labelLocationTitle->hide(); @@ -49,37 +55,29 @@ void CoreSessionWidget::setData(QMap map) // 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 { + } + else { + // For any active sessions to be displayed, the core must support this feature. We can + // assume the client doesn't support being remotely disconnected. + // + // (During the development of 0.13, there was a period of time where active sessions existed + // but did not provide the disconnect option. We can overlook this.) + // 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("

%1

%2
%3

").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("

%1

%2

").arg( - tr("End the client's session, disconnecting it"), - tr("This client does not support being remotely disconnected"))); - } + // Assuming the client lacks support, set the tooltip accordingly + ui.disconnectButton->setToolTip( + QString("

%1

%2

") + .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); - if (!success) _peerId = -1; + if (!success) + _peerId = -1; } -void CoreSessionWidget::disconnectClicked() +void CoreSessionWidget::onDisconnectClicked() { // Don't allow the End Session button to be spammed; Quassel's protocol isn't lossy and it // should reach the destination eventually...