In
f220e3b0783a24a6c7195f170297cf4b12a29d85 I made the keyboard
focus move to the places and terminal panel whenever they are
toggled visible. Unfortunately the QDockWidget::visibilityChanged()
signal is also emitted (at least on X11) simply when the window
containing that panel is minimized or restored. This commit
overrides the QDockWidget::event() method to ignore such
spontaneous show or hide events so QDockWidget won't emit the
visibilityChanged() signal then.
BUG: 497803
#include "dolphindockwidget.h"
+#include <QEvent>
#include <QStyle>
namespace
return m_locked;
}
+bool DolphinDockWidget::event(QEvent *event)
+{
+ switch (event->type()) {
+ case QEvent::Show:
+ case QEvent::Hide:
+ if (event->spontaneous()) {
+ // The Dolphin window has been minimized or restored. We do not want this to be interpreted like a user was toggling the visibility of this widget.
+ // We return here so no QDockWidget::visibilityChanged() signal is emitted. This does not seem to happen either way on Wayland.
+ return true;
+ }
+ [[fallthrough]];
+ default:
+ return QDockWidget::event(event);
+ }
+}
+
#include "dolphindockwidget.moc"
#include "moc_dolphindockwidget.cpp"
void setLocked(bool lock);
bool isLocked() const;
+protected:
+ /**
+ * Make sure we do not emit QDockWidget::visibilityChanged() signals whenever Dolphin's window is minimized or restored.
+ */
+ bool event(QEvent *event) override;
+
private:
bool m_locked;
QWidget *m_dockTitleBar;