X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=ebd1825faebca2440566541f4ce6a0f8ccf05205;hb=2ef12747a748a78311ee51b4bf833e1664347d47;hp=4cfd5b68ec91af21ecb58a97ab0ce4e87df0d7fc;hpb=e9f87d7542d4a9fe0e9c63dec96e93d270667ecd;p=quassel.git diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index 4cfd5b68..ebd1825f 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -26,38 +26,41 @@ #include "networkmodel.h" #include "buffermodel.h" #include "nickviewfilter.h" +#include "qtuisettings.h" + +#include +#include +#include +#include NickListWidget::NickListWidget(QWidget *parent) - : QWidget(parent), - _bufferModel(0), - _selectionModel(0) + : AbstractItemView(parent) { ui.setupUi(this); } -void NickListWidget::setModel(BufferModel *bufferModel) { - if(_bufferModel) { - disconnect(_bufferModel, 0, this, 0); - } - - _bufferModel = bufferModel; - - if(bufferModel) { - connect(bufferModel, SIGNAL(rowsAboutToBeRemoved(QModelIndex, int, int)), - this, SLOT(rowsAboutToBeRemoved(QModelIndex, int, int))); - } +QDockWidget *NickListWidget::dock() const { + QDockWidget *dock = qobject_cast(parent()); + if(dock) + return dock; + else + return 0; } -void NickListWidget::setSelectionModel(QItemSelectionModel *selectionModel) { - if(_selectionModel) { - disconnect(_selectionModel, 0, this, 0); - } +void NickListWidget::showWidget(bool visible) { + if(!selectionModel()) + return; - _selectionModel = selectionModel; + QModelIndex currentIndex = selectionModel()->currentIndex(); + if(currentIndex.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer) { + QDockWidget *dock_ = dock(); + if(!dock_) + return; - if(selectionModel) { - connect(selectionModel, SIGNAL(currentChanged(QModelIndex, QModelIndex)), - this, SLOT(currentChanged(QModelIndex, QModelIndex))); + if(visible) + dock_->show(); + else + dock_->close(); } } @@ -66,9 +69,19 @@ void NickListWidget::currentChanged(const QModelIndex ¤t, const QModelInde BufferId newBufferId = current.data(NetworkModel::BufferIdRole).value(); BufferId oldBufferId = previous.data(NetworkModel::BufferIdRole).value(); + if(bufferType != BufferInfo::ChannelBuffer) { ui.stackedWidget->setCurrentWidget(ui.emptyPage); + QDockWidget *dock_ = dock(); + if(dock_) { + dock_->close(); + } return; + } else { + QDockWidget *dock_ = dock(); + if(dock_ && dock_->toggleViewAction()->isChecked()) { + dock_->show(); + } } if(newBufferId == oldBufferId) @@ -142,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); + } +}