X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=f3bb9a6df405c474ef1064b053625695d03e33e1;hp=ff676ad1685601fd1ab8ac19746e8a8b2c50761b;hb=647215f1dd8ea6fdb6e4fb747c5dc3e19c4ec3fc;hpb=4df7862b00b2113dabdf52342b2c15560313f476 diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index ff676ad1..f3bb9a6d 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-2010 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -20,41 +20,63 @@ #include "qtui.h" -#include - +#include "abstractnotificationbackend.h" +#include "buffermodel.h" #include "chatlinemodel.h" +#include "contextmenuactionprovider.h" #include "mainwin.h" #include "qtuimessageprocessor.h" -#include "uisettings.h" +#include "qtuisettings.h" +#include "qtuistyle.h" +#include "systemtray.h" +#include "toolbaractionprovider.h" +#include "types.h" #include "util.h" -QtUiStyle *QtUi::_style = 0; +#ifdef Q_WS_X11 +# include +#endif + +QtUi *QtUi::_instance = 0; +MainWin *QtUi::_mainWin = 0; +QList QtUi::_notificationBackends; +QList QtUi::_notifications; -QtUi::QtUi() - : AbstractUi() -{ - if(_style != 0) { +QtUi::QtUi() : GraphicalUi() { + if(_instance != 0) { qWarning() << "QtUi has been instantiated again!"; return; } - - UiSettings uiSettings; - loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); + _instance = 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(); - mainWin = new MainWin(); - _style = new QtUiStyle; + setMainWidget(_mainWin); - connect(mainWin, SIGNAL(connectToCore(const QVariantMap &)), this, SIGNAL(connectToCore(const QVariantMap &))); - connect(mainWin, SIGNAL(disconnectFromCore()), this, SIGNAL(disconnectFromCore())); + connect(_mainWin, SIGNAL(connectToCore(const QVariantMap &)), this, SIGNAL(connectToCore(const QVariantMap &))); + connect(_mainWin, SIGNAL(disconnectFromCore()), this, SIGNAL(disconnectFromCore())); } QtUi::~QtUi() { - delete _style; - delete mainWin; + unregisterAllNotificationBackends(); + delete _mainWin; + _mainWin = 0; + _instance = 0; } void QtUi::init() { - mainWin->init(); + _mainWin->init(); + QtUiSettings uiSettings; + uiSettings.initAndNotify("UseSystemTrayIcon", this, SLOT(useSystemTrayChanged(QVariant)), true); + + GraphicalUi::init(); // needs to be called after the mainWin is initialized } MessageModel *QtUi::createMessageModel(QObject *parent) { @@ -66,9 +88,115 @@ AbstractMessageProcessor *QtUi::createMessageProcessor(QObject *parent) { } void QtUi::connectedToCore() { - mainWin->connectedToCore(); + _mainWin->connectedToCore(); } void QtUi::disconnectedFromCore() { - mainWin->disconnectedFromCore(); + _mainWin->disconnectedFromCore(); + GraphicalUi::disconnectedFromCore(); +} + +void QtUi::useSystemTrayChanged(const QVariant &v) { + _useSystemTray = v.toBool(); + SystemTray *tray = mainWindow()->systemTray(); + if(_useSystemTray) { + if(tray->isSystemTrayAvailable()) + tray->setVisible(true); + } else { + if(tray->isSystemTrayAvailable() && mainWindow()->isVisible()) + tray->setVisible(false); + } +} + +bool QtUi::haveSystemTray() { + return mainWindow()->systemTray()->isSystemTrayAvailable() && instance()->_useSystemTray; +} + +bool QtUi::isHidingMainWidgetAllowed() const { + return haveSystemTray(); +} + +void QtUi::minimizeRestore(bool show) { + SystemTray *tray = mainWindow()->systemTray(); + if(show) { + if(tray && !_useSystemTray) + tray->setVisible(false); + } else { + if(tray && _useSystemTray) + tray->setVisible(true); + } + GraphicalUi::minimizeRestore(show); +} + +void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { + if(!_notificationBackends.contains(backend)) { + _notificationBackends.append(backend); + instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); + } +} + +void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) { + _notificationBackends.removeAll(backend); +} + +void QtUi::unregisterAllNotificationBackends() { + _notificationBackends.clear(); +} + +const QList &QtUi::notificationBackends() { + return _notificationBackends; +} + +uint QtUi::invokeNotification(BufferId bufId, AbstractNotificationBackend::NotificationType type, const QString &sender, const QString &text) { + static int notificationId = 0; + + AbstractNotificationBackend::Notification notification(++notificationId, bufId, type, sender, text); + _notifications.append(notification); + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->notify(notification); + return notificationId; +} + +void QtUi::closeNotification(uint notificationId) { + QList::iterator i = _notifications.begin(); + while(i != _notifications.end()) { + if(i->notificationId == notificationId) { + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->close(notificationId); + i = _notifications.erase(i); + } else ++i; + } +} + +void QtUi::closeNotifications(BufferId bufferId) { + QList::iterator i = _notifications.begin(); + while(i != _notifications.end()) { + if(!bufferId.isValid() || i->bufferId == bufferId) { + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->close(i->notificationId); + i = _notifications.erase(i); + } else ++i; + } +} + +const QList &QtUi::activeNotifications() { + return _notifications; +} + +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); + + activateMainWidget(); }