X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=68a6757ce4a64b4ca8bdab313c6a9d9711fd438c;hp=24f07a9ae540ea8c3f6055b931be5bcc8a1912bd;hb=76a276c472cb99032e2407d8e4bc2f2d693e8e67;hpb=e226a532d5f6cb4ff58edd30421386c6f8dc7d4d diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index 24f07a9a..68a6757c 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -24,53 +24,150 @@ #include "nickview.h" #include "client.h" #include "networkmodel.h" -#include "nickmodel.h" +#include "buffermodel.h" +#include "nickviewfilter.h" +#include "qtuisettings.h" NickListWidget::NickListWidget(QWidget *parent) - : QWidget(parent), - _currentBuffer(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))); } +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(); + } + } +} -BufferId NickListWidget::currentBuffer() const { - return _currentBuffer; +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::setCurrentBuffer(BufferId bufferId) { - QModelIndex bufferIdx = Client::networkModel()->bufferIndex(bufferId); - - if(bufferIdx.data(NetworkModel::BufferTypeRole) != BufferItem::ChannelType) { +void NickListWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) { + BufferInfo::Type bufferType = (BufferInfo::Type)current.data(NetworkModel::BufferTypeRole).toInt(); + 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(); + } 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); - view->setModel(Client::nickModel()); - view->setRootIndex(Client::nickModel()->mapFromSource(bufferIdx)); - nickViews[bufferId] = view; + NickViewFilter *filter = new NickViewFilter(newBufferId, Client::networkModel()); + view->setModel(filter); + QModelIndex source_current = Client::bufferModel()->mapToSource(current); + view->setRootIndex(filter->mapFromSource(source_current)); + view->expandAll(); + nickViews[newBufferId] = view; ui.stackedWidget->addWidget(view); ui.stackedWidget->setCurrentWidget(view); } } -void NickListWidget::reset() { - foreach(NickView *view, nickViews.values()) { - ui.stackedWidget->removeWidget(view); - view->deleteLater(); +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) + NickView *nickView; + QHash::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(model)) + filter->setSourceModel(0); + model->deleteLater(); + nickView->deleteLater(); + } + } else { + // check if there are explicitly buffers removed + for(int i = start; i <= end; i++) { + QVariant variant = parent.child(i,0).data(NetworkModel::BufferIdRole); + if(!variant.isValid()) + continue; + + BufferId bufferId = qVariantValue(variant); + removeBuffer(bufferId); + } } - nickViews.clear(); } 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(model)) + filter->setSourceModel(0); + model->deleteLater(); view->deleteLater(); } + +QSize NickListWidget::sizeHint() const { + QWidget *currentWidget = ui.stackedWidget->currentWidget(); + if(!currentWidget || currentWidget == ui.emptyPage) + return QSize(100, height()); + else + return currentWidget->sizeHint(); +}