X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fsystraynotificationbackend.cpp;h=cb409ae2bee6bf5f968264813d0743372288c04a;hp=f3bd5a064e83c9cfda57188f9835f6852f16dff8;hb=0ec85b3e2ce83908af510a25d40eb2b9a0f0ffed;hpb=5ba28fb36a747bd9a2c05a58f0533d1e38c2a0de diff --git a/src/qtui/systraynotificationbackend.cpp b/src/qtui/systraynotificationbackend.cpp index f3bd5a06..cb409ae2 100644 --- a/src/qtui/systraynotificationbackend.cpp +++ b/src/qtui/systraynotificationbackend.cpp @@ -21,13 +21,14 @@ #include #include #include -#include +#include #include "systraynotificationbackend.h" #include "client.h" #include "clientsettings.h" #include "icon.h" +#include "iconloader.h" #include "mainwin.h" #include "networkmodel.h" #include "qtui.h" @@ -38,11 +39,8 @@ SystrayNotificationBackend::SystrayNotificationBackend(QObject *parent) _blockActivation(false) { NotificationSettings notificationSettings; - _showBubble = notificationSettings.value("Systray/ShowBubble", true).toBool(); - _animate = notificationSettings.value("Systray/Animate", true).toBool(); - - notificationSettings.notify("Systray/ShowBubble", this, SLOT(showBubbleChanged(const QVariant &))); - notificationSettings.notify("Systray/Animate", this, SLOT(animateChanged(const QVariant &))); + notificationSettings.initAndNotify("Systray/ShowBubble", this, SLOT(showBubbleChanged(QVariant)), true); + notificationSettings.initAndNotify("Systray/Animate", this, SLOT(animateChanged(QVariant)), true); connect(QtUi::mainWindow()->systemTray(), SIGNAL(messageClicked(uint)), SLOT(notificationActivated(uint))); connect(QtUi::mainWindow()->systemTray(), SIGNAL(activated(SystemTray::ActivationReason)), @@ -81,7 +79,7 @@ void SystrayNotificationBackend::close(uint notificationId) { QtUi::mainWindow()->systemTray()->closeMessage(notificationId); - if(!_notifications.count()) + //if(!_notifications.count()) //FIXME make configurable QtUi::mainWindow()->systemTray()->setAlert(false); updateToolTip(); @@ -89,8 +87,9 @@ void SystrayNotificationBackend::close(uint notificationId) { void SystrayNotificationBackend::notificationActivated(uint notificationId) { if(!_blockActivation) { - if(QtUi::mainWindow()->systemTray()->isAlerted()) { - _blockActivation = true; // prevent double activation because both tray icon and bubble might send a signal + if(_notifications.count()) { + if(QtUi::mainWindow()->systemTray()->mode() == SystemTray::Legacy) + _blockActivation = true; // prevent double activation because both tray icon and bubble might send a signal if(!notificationId) notificationId = _notifications.count()? _notifications.last().notificationId : 0; emit activated(notificationId); @@ -133,23 +132,17 @@ SettingsPage *SystrayNotificationBackend::createConfigWidget() const { /***************************************************************************/ SystrayNotificationBackend::ConfigWidget::ConfigWidget(QWidget *parent) : SettingsPage("Internal", "SystrayNotification", parent) { - QGroupBox *groupBox = new QGroupBox(tr("System Tray Icon"), this); - _animateBox = new QCheckBox(tr("Animate")); - connect(_animateBox, SIGNAL(toggled(bool)), this, SLOT(widgetChanged())); - _showBubbleBox = new QCheckBox(tr("Show bubble")); + _showBubbleBox = new QCheckBox(tr("Show a message in a popup")); + _showBubbleBox->setIcon(SmallIcon("dialog-information")); connect(_showBubbleBox, SIGNAL(toggled(bool)), this, SLOT(widgetChanged())); - QVBoxLayout *layout = new QVBoxLayout(groupBox); - layout->addWidget(_animateBox); + QHBoxLayout *layout = new QHBoxLayout(this); layout->addWidget(_showBubbleBox); - layout->addStretch(1); - QVBoxLayout *globalLayout = new QVBoxLayout(this); - globalLayout->addWidget(groupBox); - } void SystrayNotificationBackend::ConfigWidget::widgetChanged() { - bool changed = (_showBubble != _showBubbleBox->isChecked() || _animate != _animateBox->isChecked()); - if(changed != hasChanged()) setChangedState(changed); + bool changed = (_showBubble != _showBubbleBox->isChecked()); + if(changed != hasChanged()) + setChangedState(changed); } bool SystrayNotificationBackend::ConfigWidget::hasDefaults() const { @@ -157,23 +150,19 @@ bool SystrayNotificationBackend::ConfigWidget::hasDefaults() const { } void SystrayNotificationBackend::ConfigWidget::defaults() { - _animateBox->setChecked(true); _showBubbleBox->setChecked(false); widgetChanged(); } void SystrayNotificationBackend::ConfigWidget::load() { NotificationSettings s; - _animate = s.value("Systray/Animate", true).toBool(); _showBubble = s.value("Systray/ShowBubble", false).toBool(); - _animateBox->setChecked(_animate); _showBubbleBox->setChecked(_showBubble); setChangedState(false); } void SystrayNotificationBackend::ConfigWidget::save() { NotificationSettings s; - s.setValue("Systray/Animate", _animateBox->isChecked()); s.setValue("Systray/ShowBubble", _showBubbleBox->isChecked()); load(); }