X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=df14b46cf404480517c63099d847f860cca25708;hp=f2c51306e28689b3329a4bbe423e38822b45abdf;hb=50706d89d4d60e258ebb6873d3778383621898e4;hpb=36b2b9680ff608f41c681b8c23865abb06a2464c diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index f2c51306..df14b46c 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-07 by the Quassel IRC Team * + * Copyright (C) 2005-08 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -22,30 +22,38 @@ #include "buffer.h" #include "nickview.h" +#include "client.h" +#include "networkmodel.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) != BufferItem::ChannelType) { 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); + view->setModel(Client::networkModel()); + view->setRootIndex(bufferIdx); + nickViews[bufferId] = view; + ui.stackedWidget->addWidget(view); + ui.stackedWidget->setCurrentWidget(view); } } @@ -57,10 +65,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(); }