X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Findicatornotificationbackend.cpp;h=84e767e6e78e382b5f2c9afa81cba49061bf0736;hp=8322b84d27f2e92405101c5ff02f7d9caa33088a;hb=96daf18d3b7d183d41d2ce2cb0f25f10b45030e4;hpb=dfdeb111e21d0456103bcb10eec399996d44bca4 diff --git a/src/qtui/indicatornotificationbackend.cpp b/src/qtui/indicatornotificationbackend.cpp index 8322b84d..84e767e6 100644 --- a/src/qtui/indicatornotificationbackend.cpp +++ b/src/qtui/indicatornotificationbackend.cpp @@ -21,7 +21,7 @@ #include "indicatornotificationbackend.h" #include -#include +#include #include "client.h" #include "clientsettings.h" @@ -29,7 +29,10 @@ #include "networkmodel.h" #include "qtui.h" -class Indicator : public QIndicate::IndicatorMessage { +#define STR(x) #x +#define XSTR(x) STR(x) + +class Indicator : public QIndicate::Indicator { public: uint lastNotificationId; }; @@ -38,13 +41,15 @@ IndicatorNotificationBackend::IndicatorNotificationBackend(QObject *parent) : AbstractNotificationBackend(parent) { NotificationSettings notificationSettings; - _enabled = notificationSettings.value("Indicator/Enabled", true).toBool(); + _enabled = notificationSettings.value("Indicator/Enabled", false).toBool(); notificationSettings.notify("Indicator/Enabled", this, SLOT(enabledChanged(const QVariant &))); _server = QIndicate::Server::defaultInstance(); - _server->setType("message.im"); - _server->setDesktopFile(DESKTOP_FILE); + _server->setType("message.irc"); + _server->setDesktopFile(XSTR(DESKTOP_FILE)); + connect(_server, SIGNAL(serverDisplay()), QtUi::mainWindow(), SLOT(toggleMinimizedToTray())); + if (_enabled) { _server->show(); } @@ -66,29 +71,32 @@ void IndicatorNotificationBackend::notify(const Notification ¬ification) { if(!indicator) { indicator = new Indicator; _indicatorHash.insert(bufferId, indicator); + connect(indicator, SIGNAL(display(QIndicate::Indicator*)), + SLOT(indicatorDisplayed(QIndicate::Indicator*))); } indicator->lastNotificationId = notification.notificationId; BufferInfo::Type type = Client::networkModel()->bufferType(bufferId); - QString sender; + QString name; if (type == BufferInfo::QueryBuffer) { - sender = notification.sender; + name = notification.sender; } else { - sender = QString("%1 (%2)") + name = QString("%1 (%2)") .arg(Client::networkModel()->bufferName(bufferId)) .arg(notification.sender); } - indicator->setProperty("sender", sender); + indicator->setNameProperty(name); - indicator->setProperty("time", QTime::currentTime()); + indicator->setTimeProperty(QDateTime::currentDateTime()); QModelIndex index = Client::networkModel()->bufferIndex(bufferId); QVariant icon = QtUi::style()->bufferViewItemData(index, Qt::DecorationRole); if (icon.canConvert()) { QImage image = icon.value().toImage(); - indicator->setProperty("icon", image); + indicator->setIconProperty(image); } + indicator->setDrawAttentionProperty(true); indicator->show(); } @@ -124,6 +132,11 @@ void IndicatorNotificationBackend::enabledChanged(const QVariant &v) { } } +void IndicatorNotificationBackend::indicatorDisplayed(QIndicate::Indicator *_indicator) { + Indicator *indicator = static_cast(_indicator); + emit activated(indicator->lastNotificationId); +} + SettingsPage *IndicatorNotificationBackend::createConfigWidget() const { return new ConfigWidget(); }