X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fabstractnotificationbackend.h;h=8e95c9189e76893ead45399c7debccbb5d573443;hp=c7112afa7fba5019eb6df567ef86f1ba6e20b8d3;hb=b324a124e384bd8c9f54d97c5b5d6a5cc50fd91b;hpb=5c78a50fa720e5f82fcaa03c0176feab71d74c8e diff --git a/src/uisupport/abstractnotificationbackend.h b/src/uisupport/abstractnotificationbackend.h index c7112afa..8e95c918 100644 --- a/src/uisupport/abstractnotificationbackend.h +++ b/src/uisupport/abstractnotificationbackend.h @@ -31,23 +31,33 @@ class SettingsPage; class AbstractNotificationBackend : public QObject { Q_OBJECT - public: - struct Notification { - uint notificationId; - BufferId bufferId; - QString sender; - QString message; - - Notification(uint id_, BufferId buf_, const QString &sender_, const QString &msg_) +public: + struct Notification { + uint notificationId; + BufferId bufferId; + QString sender; + QString message; + + Notification(uint id_, BufferId buf_, const QString &sender_, const QString &msg_) : notificationId(id_), bufferId(buf_), sender(sender_), message(msg_) {}; - }; + }; + + inline AbstractNotificationBackend(QObject *parent) : QObject(parent) {}; + virtual ~AbstractNotificationBackend() {}; + + virtual void notify(const Notification &) = 0; + virtual void close(uint notificationId) { Q_UNUSED(notificationId); } - inline AbstractNotificationBackend(QObject *parent) : QObject(parent) {}; - virtual ~AbstractNotificationBackend() {}; + //! Factory to create a configuration widget suitable for a specific notification backend + /** + * AbstractNotification will not take ownership of that configWidget! + * In case you need to communicate with the configWidget directly, make your connections here + */ + virtual SettingsPage *createConfigWidget() const = 0; - virtual void notify(const Notification &) = 0; - virtual void close(uint notificationId) { Q_UNUSED(notificationId); } - virtual SettingsPage *configWidget() const = 0; +signals: + //! May be emitted by the notification to tell the MainWin to raise itself + void activated(); };