X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=0a2de598bd189d44717f05f4e5dbf30010088e1c;hp=2efdf72ea229d67874f3200ea9887cf5aeb51ac8;hb=901cf3dc46cb72c79a1f479f50c4cba0023530f6;hpb=ab16c77fe03b73a863d9b52b11919bcbac903f58 diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 2efdf72e..0a2de598 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -21,6 +21,7 @@ #include "qtui.h" #include "abstractnotificationbackend.h" +#include "buffermodel.h" #include "chatlinemodel.h" #include "contextmenuactionprovider.h" #include "mainwin.h" @@ -31,11 +32,14 @@ #include "types.h" #include "util.h" +#ifdef Q_WS_X11 +# include +#endif + QPointer QtUi::_instance = 0; QPointer QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; -QtUiStyle *QtUi::_style = 0; QtUi::QtUi() : GraphicalUi() { if(_instance != 0) { @@ -44,14 +48,14 @@ QtUi::QtUi() : GraphicalUi() { } _instance = this; - setContextMenuActionProvider(new ContextMenuActionProvider(this)); - setToolBarActionProvider(new ToolBarActionProvider(this)); - QtUiSettings uiSettings; Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); + setContextMenuActionProvider(new ContextMenuActionProvider(this)); + setToolBarActionProvider(new ToolBarActionProvider(this)); + + setUiStyle(new QtUiStyle(this)); _mainWin = new MainWin(); - _style = new QtUiStyle; setMainWidget(_mainWin); @@ -61,7 +65,6 @@ QtUi::QtUi() : GraphicalUi() { QtUi::~QtUi() { unregisterAllNotificationBackends(); - delete _style; delete _mainWin; } @@ -88,7 +91,7 @@ void QtUi::disconnectedFromCore() { void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { if(!_notificationBackends.contains(backend)) { _notificationBackends.append(backend); - instance()->connect(backend, SIGNAL(activated()), SLOT(notificationActivated())); + instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); } } @@ -104,10 +107,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); @@ -117,27 +120,22 @@ uint QtUi::invokeNotification(BufferId bufId, const QString &sender, const QStri void QtUi::closeNotification(uint notificationId) { QList::iterator i = _notifications.begin(); while(i != _notifications.end()) { - if((*i).notificationId == notificationId) { + if(i->notificationId == notificationId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close(notificationId); i = _notifications.erase(i); - break; - } else { - ++i; - } + } else ++i; } } void QtUi::closeNotifications(BufferId bufferId) { QList::iterator i = _notifications.begin(); while(i != _notifications.end()) { - if(!bufferId.isValid() || (*i).bufferId == bufferId) { + if(!bufferId.isValid() || i->bufferId == bufferId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) - backend->close((*i).notificationId); + backend->close(i->notificationId); i = _notifications.erase(i); - } else { - ++i; - } + } else ++i; } } @@ -145,8 +143,20 @@ const QList &QtUi::activeNotification return _notifications; } -void QtUi::notificationActivated() { - // this might not work with some window managers - _mainWin->raise(); - _mainWin->activateWindow(); +void QtUi::notificationActivated(uint notificationId) { + if(notificationId != 0) { + QList::iterator i = _notifications.begin(); + while(i != _notifications.end()) { + if(i->notificationId == notificationId) { + BufferId bufId = i->bufferId; + if(bufId.isValid()) + Client::bufferModel()->switchToBuffer(bufId); + break; + } + ++i; + } + } + closeNotification(notificationId); + + mainWindow()->forceActivated(); }