X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=d6916f99a96729ed759f3af324bc316f14a68ed7;hb=b79832bf9c4c21b05629cfd2fdbd008ad690572f;hp=68a6757ce4a64b4ca8bdab313c6a9d9711fd438c;hpb=76a276c472cb99032e2407d8e4bc2f2d693e8e67;p=quassel.git diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index 68a6757c..d6916f99 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -28,33 +28,20 @@ #include "nickviewfilter.h" #include "qtuisettings.h" +#include + NickListWidget::NickListWidget(QWidget *parent) - : AbstractItemView(parent), - _showNickListAction(new QAction(tr("Nicks"), this)), - _showDockAction(0) + : AbstractItemView(parent) { - _showNickListAction->setCheckable(true); - QtUiSettings s; - _showNickListAction->setChecked(s.value("ShowNickListAction", QVariant(true)).toBool()); ui.setupUi(this); - connect(_showNickListAction, SIGNAL(toggled(bool)), this, SLOT(showWidget(bool))); -} - -NickListWidget::~NickListWidget() { - QtUiSettings s; - s.setValue("ShowNickListAction", showNickListAction()->isChecked()); -} - -void NickListWidget::setShowDockAction(QAction *action) { - _showDockAction = action; } -QAction *NickListWidget::showDockAction() const { - return _showDockAction; -} - -QAction *NickListWidget::showNickListAction() const { - return _showNickListAction; +QDockWidget *NickListWidget::dock() const { + QDockWidget *dock = qobject_cast(parent()); + if(dock) + return dock; + else + return 0; } void NickListWidget::showWidget(bool visible) { @@ -62,21 +49,15 @@ void NickListWidget::showWidget(bool visible) { return; QModelIndex currentIndex = selectionModel()->currentIndex(); - if(currentIndex.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer && showDockAction()) { - if(visible != showDockAction()->isChecked()) { - // show or hide - showDockAction()->trigger(); - } - } -} - -void NickListWidget::changedVisibility(bool visible) { - if(!selectionModel()) - return; - - QModelIndex currentIndex = selectionModel()->currentIndex(); - if(currentIndex.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer && !visible) { - showNickListAction()->setChecked(false); + if(currentIndex.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer) { + QDockWidget *dock_ = dock(); + if(!dock_) + return; + + if(visible) + dock_->show(); + else + dock_->close(); } } @@ -85,19 +66,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); - if(showDockAction() && showDockAction()->isChecked()) { - // hide - showDockAction()->trigger(); + QDockWidget *dock_ = dock(); + if(dock_) { + dock_->close(); } return; } else { - if(showNickListAction()->isChecked()) - if(showDockAction()&& !showDockAction()->isChecked()) { - // show - showDockAction()->trigger(); - } + QDockWidget *dock_ = dock(); + if(dock_ && dock_->toggleViewAction()->isChecked()) { + dock_->show(); + } } if(newBufferId == oldBufferId)