X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=ebd1825faebca2440566541f4ce6a0f8ccf05205;hp=d6916f99a96729ed759f3af324bc316f14a68ed7;hb=db199a3d46e34a02e8a66046fd44bf53a988cdf8;hpb=a792fc63f7d774e817f7c0300b334a0da6d96c2e diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index d6916f99..ebd1825f 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -28,7 +28,10 @@ #include "nickviewfilter.h" #include "qtuisettings.h" -#include +#include +#include +#include +#include NickListWidget::NickListWidget(QWidget *parent) : AbstractItemView(parent) @@ -152,3 +155,36 @@ QSize NickListWidget::sizeHint() const { else return currentWidget->sizeHint(); } + + +// ============================== +// NickList Dock +// ============================== +NickListDock::NickListDock(const QString &title, QWidget *parent) + : QDockWidget(title, parent) +{ + QAction *toggleView = toggleViewAction(); + disconnect(toggleView, SIGNAL(triggered(bool)), this, 0); + toggleView->setChecked(QtUiSettings().value("ShowNickList", QVariant(true)).toBool()); + + // reconnecting the closebuttons clicked signal to the action + foreach(QAbstractButton *button, findChildren()) { + if(disconnect(button, SIGNAL(clicked()), this, SLOT(close()))) + connect(button, SIGNAL(clicked()), toggleView, SLOT(trigger())); + } +} + +NickListDock::~NickListDock() { + QtUiSettings().setValue("ShowNickList", toggleViewAction()->isChecked()); +} + +bool NickListDock::event(QEvent *event) { + switch (event->type()) { + case QEvent::Hide: + case QEvent::Show: + emit visibilityChanged(event->type() == QEvent::Show); + return QWidget::event(event); + default: + return QDockWidget::event(event); + } +}