X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=04e6e22a8fd4c659c9b2a92e750b48a7f4743967;hb=1f02b7201ab7b86238e705d2ce5b22f50bf6acfe;hp=490f9b60468cca94b3bbdedaf8b94275a96155d4;hpb=8699dd758516d0ded076811e8ea656adc95e69d0;p=quassel.git diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index 490f9b60..04e6e22a 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -22,30 +22,40 @@ #include "buffer.h" #include "nickview.h" +#include "client.h" +#include "networkmodel.h" +#include "nickviewfilter.h" -NickListWidget::NickListWidget(QWidget *parent) : QWidget(parent) { +NickListWidget::NickListWidget(QWidget *parent) + : QWidget(parent), + _currentBuffer(0) +{ ui.setupUi(this); +} + +BufferId NickListWidget::currentBuffer() const { + return _currentBuffer; } -void NickListWidget::setBuffer(Buffer *buf) { - if(!buf) { +void NickListWidget::setCurrentBuffer(BufferId bufferId) { + QModelIndex bufferIdx = Client::networkModel()->bufferIndex(bufferId); + + if(bufferIdx.data(NetworkModel::BufferTypeRole) != BufferInfo::ChannelBuffer) { ui.stackedWidget->setCurrentWidget(ui.emptyPage); return; } - if(buf->bufferType() != Buffer::ChannelType) { - ui.stackedWidget->setCurrentWidget(ui.emptyPage); + + if(nickViews.contains(bufferId)) { + ui.stackedWidget->setCurrentWidget(nickViews.value(bufferId)); } else { - if(nickViews.contains(buf)) { - ui.stackedWidget->setCurrentWidget(nickViews.value(buf)); - } else { - NickView *view = new NickView(this); - view->setModel(buf->nickModel()); - nickViews[buf] = view; - ui.stackedWidget->addWidget(view); - ui.stackedWidget->setCurrentWidget(view); - connect(buf, SIGNAL(destroyed(QObject *)), this, SLOT(bufferDestroyed(QObject *))); - } + NickView *view = new NickView(this); + NickViewFilter *filter = new NickViewFilter(Client::networkModel()); + view->setModel(filter); + view->setRootIndex(filter->mapFromSource(bufferIdx)); + nickViews[bufferId] = view; + ui.stackedWidget->addWidget(view); + ui.stackedWidget->setCurrentWidget(view); } } @@ -57,10 +67,11 @@ void NickListWidget::reset() { nickViews.clear(); } -void NickListWidget::bufferDestroyed(QObject *buf) { - if(nickViews.contains((Buffer *)buf)) { - NickView *view = nickViews.take((Buffer *)buf); - ui.stackedWidget->removeWidget(view); - view->deleteLater(); - } +void NickListWidget::removeBuffer(BufferId bufferId) { + if(!nickViews.contains(bufferId)) + return; + + NickView *view = nickViews.take(bufferId); + ui.stackedWidget->removeWidget(view); + view->deleteLater(); }