X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.h;h=e163641c4407f78de4e7eeb88464fc0759343718;hp=0d13e6488a6adde9dc8b683712a2f47c556c3e36;hb=a95ad2de573027f9bee36db972bcae4195168d0c;hpb=3abd4b7d5ab303f8d990c104748e5d5aef4db355 diff --git a/src/qtui/qtui.h b/src/qtui/qtui.h index 0d13e648..e163641c 100644 --- a/src/qtui/qtui.h +++ b/src/qtui/qtui.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2020 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -24,11 +24,10 @@ #include #include -#include - -#if QT_VERSION >= 0x050000 -# include -#endif +#include +#include +#include +#include #include "abstractnotificationbackend.h" #include "graphicalui.h" @@ -48,24 +47,26 @@ class QtUi : public GraphicalUi public: QtUi(); - ~QtUi(); + ~QtUi() override; + + MessageModel* createMessageModel(QObject* parent) override; + AbstractMessageProcessor* createMessageProcessor(QObject* parent) override; - MessageModel *createMessageModel(QObject *parent) override; - AbstractMessageProcessor *createMessageProcessor(QObject *parent) override; + static QtUi* instance(); + inline static QtUiStyle* style(); + inline static MainWin* mainWindow(); - inline static QtUi *instance(); - inline static QtUiStyle *style(); - inline static MainWin *mainWindow(); + QString debugLog() const; static bool haveSystemTray(); /* Notifications */ - static void registerNotificationBackend(AbstractNotificationBackend *); - static void unregisterNotificationBackend(AbstractNotificationBackend *); + static void registerNotificationBackend(AbstractNotificationBackend*); + static void unregisterNotificationBackend(AbstractNotificationBackend*); static void unregisterAllNotificationBackends(); - static const QList ¬ificationBackends(); - static const QList &activeNotifications(); + static const QList& notificationBackends(); + static const QList& activeNotifications(); /** * Determine available fallback icon themes. @@ -74,10 +75,23 @@ public: */ std::vector> availableIconThemes() const; + /** + * Determine the system icon theme set when Quassel was started. + * + * This property stores the icon theme initially configured in Qt when starting up (may be empty on platforms + * not supporting system icon themes). If the --icontheme option is given, uses that. + * + * Since Qt does not support notifications on theme changes, this property will not be updated when the theme + * changes at runtime. + * + * @returns The system icon theme at startup time + */ + QString systemIconTheme() const; + public slots: void init() override; - uint invokeNotification(BufferId bufId, AbstractNotificationBackend::NotificationType type, const QString &sender, const QString &text); + uint invokeNotification(BufferId bufId, AbstractNotificationBackend::NotificationType type, const QString& sender, const QString& text); void closeNotification(uint notificationId); void closeNotifications(BufferId bufferId = BufferId()); @@ -89,6 +103,9 @@ public slots: */ void refreshIconTheme(); +signals: + void iconThemeRefreshed(); + protected slots: void connectedToCore() override; void disconnectedFromCore() override; @@ -100,7 +117,7 @@ protected: bool isHidingMainWidgetAllowed() const override; private slots: - void useSystemTrayChanged(const QVariant &); + void useSystemTrayChanged(const QVariant&); private: /** @@ -109,21 +126,24 @@ private: void setupIconTheme(); private: - static QtUi *_instance; - static MainWin *_mainWin; - static QList _notificationBackends; + static QList _notificationBackends; static QList _notifications; + std::unique_ptr _mainWin; + QString _systemIconTheme; -#if QT_VERSION >= 0x050000 std::unique_ptr _dummyThemeDir; -#endif bool _useSystemTray; }; +QtUiStyle* QtUi::style() +{ + return qobject_cast(uiStyle()); +} -QtUi *QtUi::instance() { return _instance ? _instance : new QtUi(); } -QtUiStyle *QtUi::style() { return qobject_cast(uiStyle()); } -MainWin *QtUi::mainWindow() { return _mainWin; } +MainWin* QtUi::mainWindow() +{ + return instance()->_mainWin.get(); +}