X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fsystemtray.h;h=91db1a5ac936495dc51ac238cbc4cc8fbbefd51e;hb=b8db3c55a7f66a8d6ecabf9039aabceff9ae4837;hp=1efdb4184c343937c68c9669abc8bdf260807dcf;hpb=b4b4d30567ea2d5c5bfaff8d019cf7ff5d023538;p=quassel.git diff --git a/src/qtui/systemtray.h b/src/qtui/systemtray.h index 1efdb418..91db1a5a 100644 --- a/src/qtui/systemtray.h +++ b/src/qtui/systemtray.h @@ -22,6 +22,7 @@ #include #include +#include class Action; class QMenu; @@ -32,20 +33,23 @@ class SystemTray : public QObject Q_ENUMS(State Mode MessageIcon ActivationReason) public: - enum State { + enum State + { Passive, Active, NeedsAttention }; - enum Mode { + enum Mode + { Invalid, Legacy, StatusNotifier }; // same as in QSystemTrayIcon - enum MessageIcon { + enum MessageIcon + { NoIcon, Information, Warning, @@ -53,7 +57,8 @@ public: }; // same as in QSystemTrayIcon - enum ActivationReason { + enum ActivationReason + { Unknown, Context, DoubleClick, @@ -61,32 +66,44 @@ public: MiddleClick }; - explicit SystemTray(QWidget *parent); + enum class AttentionBehavior + { + DoNothing, + ChangeColor, + Blink + }; + + explicit SystemTray(QWidget* parent); ~SystemTray() override; - virtual void init(); Mode mode() const; State state() const; + bool isVisible() const; bool isAlerted() const; - void setAlert(bool alerted); - virtual bool isVisible() const; virtual bool isSystemTrayAvailable() const; - QWidget *associatedWidget() const; + QWidget* associatedWidget() const; public slots: - virtual void setState(State); - virtual void setVisible(bool visible = true); - virtual void setToolTip(const QString &title, const QString &subtitle); - virtual void showMessage(const QString &title, const QString &message, MessageIcon icon = Information, int msTimeout = 10000, uint notificationId = 0); + void setVisible(bool visible = true); + void setState(State); + void setAlert(bool alerted); + + void setToolTip(const QString& title, const QString& subtitle); + virtual void showMessage( + const QString& title, const QString& message, MessageIcon icon = Information, int msTimeout = 10000, uint notificationId = 0); virtual void closeMessage(uint notificationId); signals: + void modeChanged(Mode mode); + void stateChanged(State state); + void visibilityChanged(bool isVisible); + void iconsChanged(); + void currentIconNameChanged(); + void toolTipChanged(const QString& title, const QString& subtitle); + void activated(SystemTray::ActivationReason); - void iconChanged(const QIcon &icon); - void animationEnabledChanged(bool); - void toolTipChanged(const QString &title, const QString &subtitle); void messageClicked(uint notificationId); void messageClosed(uint notificationId); @@ -94,32 +111,39 @@ protected slots: virtual void activate(SystemTray::ActivationReason = Trigger); protected: - virtual void setMode(Mode mode); - bool shouldBeVisible() const; - bool animationEnabled() const; + void setMode(Mode mode); QString toolTipTitle() const; QString toolTipSubTitle() const; - QMenu *trayMenu() const; + QMenu* trayMenu() const; QString iconName(State state) const; + QString currentIconName() const; + QString currentAttentionIconName() const; private slots: void minimizeRestore(); void trayMenuAboutToShow(); - void enableAnimationChanged(const QVariant &); - void invertTrayIconChanged(const QVariant &); + void invertTrayIconChanged(const QVariant&); + void enableChangeColorChanged(const QVariant&); + void enableBlinkChanged(const QVariant&); + + void onBlinkTimeout(); private: + bool _isVisible{false}; Mode _mode{Mode::Invalid}; State _state{State::Passive}; - bool _shouldBeVisible{true}; - bool _animationEnabled{true}; bool _trayIconInverted{false}; + AttentionBehavior _attentionBehavior{AttentionBehavior::ChangeColor}; + + QTimer _blinkTimer; + bool _blinkState{false}; - QString _toolTipTitle, _toolTipSubTitle; + QString _toolTipTitle; + QString _toolTipSubTitle; - QMenu *_trayMenu{nullptr}; - QWidget *_associatedWidget{nullptr}; - Action *_minimizeRestoreAction{nullptr}; + QMenu* _trayMenu{nullptr}; + QWidget* _associatedWidget{nullptr}; + Action* _minimizeRestoreAction{nullptr}; };