diff options
Diffstat (limited to 'examples/GuiClient/profileDialog.cpp')
| -rw-r--r-- | examples/GuiClient/profileDialog.cpp | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/examples/GuiClient/profileDialog.cpp b/examples/GuiClient/profileDialog.cpp index 65743bf6..c1f4d668 100644 --- a/examples/GuiClient/profileDialog.cpp +++ b/examples/GuiClient/profileDialog.cpp @@ -7,6 +7,8 @@ #include "QXmppVersionManager.h" #include "QXmppRosterManager.h" #include "QXmppUtils.h" +#include "QXmppEntityTimeManager.h" +#include "QXmppEntityTimeIq.h" profileDialog::profileDialog(QWidget *parent, const QString& bareJid, QXmppClient& client) : QDialog(parent, Qt::WindowTitleHint|Qt::WindowSystemMenuHint), @@ -18,10 +20,22 @@ profileDialog::profileDialog(QWidget *parent, const QString& bareJid, QXmppClien SLOT(versionReceived(const QXmppVersionIq&))); Q_ASSERT(check); + QXmppEntityTimeManager* timeManager = m_xmppClient.findExtension<QXmppEntityTimeManager*>(); + + if(timeManager) + { + check = connect(timeManager, SIGNAL(timeReceived(const QXmppEntityTimeIq&)), + SLOT(timeReceived(const QXmppEntityTimeIq&))); + Q_ASSERT(check); + } + QStringList resources = m_xmppClient.rosterManager().getResources(bareJid); foreach(QString resource, resources) { - m_xmppClient.versionManager().requestVersion(bareJid + "/" + resource); + QString jid = bareJid + "/" + resource; + m_xmppClient.versionManager().requestVersion(jid); + if(timeManager) + timeManager->requestTime(jid); } updateText(); } @@ -64,6 +78,13 @@ void profileDialog::versionReceived(const QXmppVersionIq& ver) updateText(); } +void profileDialog::timeReceived(const QXmppEntityTimeIq& time) +{ + m_time[jidToResource(time.from())] = time; + if(time.type() == QXmppIq::Result) + updateText(); +} + void profileDialog::updateText() { QStringList resources = m_xmppClient.rosterManager().getResources(m_bareJid); @@ -81,6 +102,12 @@ void profileDialog::updateText() arg(m_versions[resource].name()). arg(m_versions[resource].version()). arg(m_versions[resource].os()); + statusText += "<BR>"; + + if(m_time.contains(resource)) + statusText += "<B>Time: </B>" + QString("utc=%1 [tzo=%2]"). + arg(m_time[resource].utc()). + arg(m_time[resource].tzo()); if(i < resources.count() - 1) // skip for the last item statusText += "<BR><BR>"; |
