X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=22973215f6cfb49e6cea1b1227cd84cbf8748df9;hp=4623142ccbbc1961714edde6133fbe9425496313;hb=9fb25d34cfc4dee02159b112c72e018c6e26e63f;hpb=5941801a1a5a61dc6d3e409ba33ab413adc9005f diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 4623142c..22973215 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -55,8 +55,8 @@ QtUi::QtUi() : GraphicalUi() { QtUiSettings uiSettings; Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); - _mainWin = new MainWin(); _style = new QtUiStyle; + _mainWin = new MainWin(); setMainWidget(_mainWin); @@ -66,8 +66,8 @@ QtUi::QtUi() : GraphicalUi() { QtUi::~QtUi() { unregisterAllNotificationBackends(); - delete _style; delete _mainWin; + delete _style; } void QtUi::init() { @@ -109,10 +109,10 @@ const QList &QtUi::notificationBackends() { return _notificationBackends; } -uint QtUi::invokeNotification(BufferId bufId, const QString &sender, const QString &text) { +uint QtUi::invokeNotification(BufferId bufId, AbstractNotificationBackend::NotificationType type, const QString &sender, const QString &text) { static int notificationId = 0; //notificationId++; - AbstractNotificationBackend::Notification notification(++notificationId, bufId, sender, text); + AbstractNotificationBackend::Notification notification(++notificationId, bufId, type, sender, text); _notifications.append(notification); foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->notify(notification); @@ -127,9 +127,7 @@ void QtUi::closeNotification(uint notificationId) { backend->close(notificationId); i = _notifications.erase(i); break; - } else { - ++i; - } + } else ++i; } } @@ -140,9 +138,7 @@ void QtUi::closeNotifications(BufferId bufferId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close((*i).notificationId); i = _notifications.erase(i); - } else { - ++i; - } + } else ++i; } } @@ -158,22 +154,13 @@ void QtUi::notificationActivated(uint notificationId) { BufferId bufId = (*i).bufferId; if(bufId.isValid()) Client::bufferModel()->switchToBuffer(bufId); + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->close(notificationId); _notifications.erase(i); break; - } + } else ++i; } } -#ifdef Q_WS_X11 - // Bypass focus stealing prevention - QX11Info::setAppUserTime(QX11Info::appTime()); -#endif - - if(_mainWin->windowState() & Qt::WindowMinimized) { - // restore - _mainWin->setWindowState((_mainWin->windowState() & ~Qt::WindowMinimized) | Qt::WindowActive); - _mainWin->show(); - } - _mainWin->raise(); - _mainWin->activateWindow(); + mainWindow()->forceActivated(); }