-added tray icon notification
[quassel.git] / src / qtui / nicklistwidget.cpp
index cb94161..68a6757 100644 (file)
 #include "nickview.h"
 #include "client.h"
 #include "networkmodel.h"
+#include "buffermodel.h"
 #include "nickviewfilter.h"
+#include "qtuisettings.h"
 
 NickListWidget::NickListWidget(QWidget *parent)
-  : QWidget(parent),
-    _bufferModel(0),
-    _selectionModel(0)
+  : 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)));
 }
 
-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)));
-  }
+NickListWidget::~NickListWidget() {
+  QtUiSettings s;
+  s.setValue("ShowNickListAction", showNickListAction()->isChecked());
 }
 
-void NickListWidget::setSelectionModel(QItemSelectionModel *selectionModel) {
-  if(_selectionModel) {
-    disconnect(_selectionModel, 0, this, 0);
-  }
+void NickListWidget::setShowDockAction(QAction *action) {
+  _showDockAction = action;
+}
 
-  _selectionModel = selectionModel;
+QAction *NickListWidget::showDockAction() const {
+  return _showDockAction;
+}
 
-  if(selectionModel) {
-    connect(selectionModel, SIGNAL(currentChanged(QModelIndex, QModelIndex)),
-           this, SLOT(currentChanged(QModelIndex, QModelIndex)));
-  }
+QAction *NickListWidget::showNickListAction() const {
+  return _showNickListAction;
 }
 
+void NickListWidget::showWidget(bool visible) {
+  if(!selectionModel())
+    return;
 
-void NickListWidget::reset() {
-  NickView *nickView;
-  QHash<BufferId, NickView *>::iterator iter = nickViews.begin();
-  while(iter != nickViews.end()) {
-    nickView = *iter;
-    iter = nickViews.erase(iter);
-    ui.stackedWidget->removeWidget(nickView);
-    nickView->deleteLater();
+  QModelIndex currentIndex = selectionModel()->currentIndex();
+  if(currentIndex.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer && showDockAction()) {
+    if(visible  != showDockAction()->isChecked()) {
+      // show or hide
+      showDockAction()->trigger();
+    }
   }
 }
 
-
-void NickListWidget::currentChanged(const QModelIndex &current, const QModelIndex &previous) {
-  Q_UNUSED(previous);
-  QVariant variant;
-
-  variant = current.data(NetworkModel::BufferIdRole);
-  if(!variant.isValid())
+void NickListWidget::changedVisibility(bool visible) {
+  if(!selectionModel())
     return;
-  setCurrentBuffer(variant.value<BufferId>());
+
+  QModelIndex currentIndex = selectionModel()->currentIndex();
+  if(currentIndex.data(NetworkModel::BufferTypeRole) == BufferInfo::ChannelBuffer && !visible) {
+    showNickListAction()->setChecked(false);
+  }
 }
 
+void NickListWidget::currentChanged(const QModelIndex &current, const QModelIndex &previous) {
+  BufferInfo::Type bufferType = (BufferInfo::Type)current.data(NetworkModel::BufferTypeRole).toInt();
+  BufferId newBufferId = current.data(NetworkModel::BufferIdRole).value<BufferId>();
+  BufferId oldBufferId = previous.data(NetworkModel::BufferIdRole).value<BufferId>();
 
-void NickListWidget::setCurrentBuffer(BufferId bufferId) {
-  QModelIndex bufferIdx = Client::networkModel()->bufferIndex(bufferId);
-  
-  if(bufferIdx.data(NetworkModel::BufferTypeRole) != BufferInfo::ChannelBuffer) {
+  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(nickViews.contains(bufferId)) {
-    ui.stackedWidget->setCurrentWidget(nickViews.value(bufferId));
+  if(newBufferId == oldBufferId)
+    return;
+
+  if(nickViews.contains(newBufferId)) {
+    ui.stackedWidget->setCurrentWidget(nickViews.value(newBufferId));
   } else {
     NickView *view = new NickView(this);
-    NickViewFilter *filter = new NickViewFilter(bufferId, Client::networkModel());
-    filter->setObjectName("Buffer " + QString::number(bufferId.toInt()));
+    NickViewFilter *filter = new NickViewFilter(newBufferId, Client::networkModel());
     view->setModel(filter);
-    view->setRootIndex(filter->mapFromSource(bufferIdx));
+    QModelIndex source_current = Client::bufferModel()->mapToSource(current);
+    view->setRootIndex(filter->mapFromSource(source_current));
     view->expandAll();
-    nickViews[bufferId] = view;
+    nickViews[newBufferId] = view;
     ui.stackedWidget->addWidget(view);
     ui.stackedWidget->setCurrentWidget(view);
   }
 }
 
-
 void NickListWidget::rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end) {
   Q_ASSERT(model());
   if(!parent.isValid()) {
     // ok this means that whole networks are about to be removed
     // we can't determine which buffers are affect, so we hope that all nets are removed
     // this is the most common case (for example disconnecting from the core or terminating the clint)
-    reset();
+    NickView *nickView;
+    QHash<BufferId, NickView *>::iterator iter = nickViews.begin();
+    while(iter != nickViews.end()) {
+      nickView = *iter;
+      iter = nickViews.erase(iter);
+      ui.stackedWidget->removeWidget(nickView);
+      QAbstractItemModel *model = nickView->model();
+      nickView->setModel(0);
+      if(QSortFilterProxyModel *filter = qobject_cast<QSortFilterProxyModel *>(model))
+       filter->setSourceModel(0);
+      model->deleteLater();
+      nickView->deleteLater();
+    }
   } else {
     // check if there are explicitly buffers removed
     for(int i = start; i <= end; i++) {
@@ -131,9 +153,14 @@ void NickListWidget::rowsAboutToBeRemoved(const QModelIndex &parent, int start,
 void NickListWidget::removeBuffer(BufferId bufferId) {
   if(!nickViews.contains(bufferId))
     return;
-  
+
   NickView *view = nickViews.take(bufferId);
   ui.stackedWidget->removeWidget(view);
+  QAbstractItemModel *model = view->model();
+  view->setModel(0);
+  if(QSortFilterProxyModel *filter = qobject_cast<QSortFilterProxyModel *>(model))
+    filter->setSourceModel(0);
+  model->deleteLater();
   view->deleteLater();
 }