X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=68a6757ce4a64b4ca8bdab313c6a9d9711fd438c;hp=714731a961c7336573285bfea11fd7f3993633fa;hb=76a276c472cb99032e2407d8e4bc2f2d693e8e67;hpb=f28f0cf83c0aee7700334e0251165f0f3794f57c diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index 714731a9..68a6757c 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -26,11 +26,58 @@ #include "networkmodel.h" #include "buffermodel.h" #include "nickviewfilter.h" +#include "qtuisettings.h" NickListWidget::NickListWidget(QWidget *parent) - : AbstractItemView(parent) + : AbstractItemView(parent), + _showNickListAction(new QAction(tr("Nicks"), this)), + _showDockAction(0) { + _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; +} + +void NickListWidget::showWidget(bool visible) { + if(!selectionModel()) + 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); + } } void NickListWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) { @@ -40,7 +87,17 @@ void NickListWidget::currentChanged(const QModelIndex ¤t, const QModelInde if(bufferType != BufferInfo::ChannelBuffer) { ui.stackedWidget->setCurrentWidget(ui.emptyPage); + if(showDockAction() && showDockAction()->isChecked()) { + // hide + showDockAction()->trigger(); + } return; + } else { + if(showNickListAction()->isChecked()) + if(showDockAction()&& !showDockAction()->isChecked()) { + // show + showDockAction()->trigger(); + } } if(newBufferId == oldBufferId)