X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fnicklistwidget.cpp;h=24f07a9ae540ea8c3f6055b931be5bcc8a1912bd;hp=024ebeb4136680e6fc9f159a7c199e0ba221c4a6;hb=e5ef65b239e9a128a5cf86e6eef9bce1fd098448;hpb=ec17201104f75eafaddccc174de8709b42b15ccb diff --git a/src/qtui/nicklistwidget.cpp b/src/qtui/nicklistwidget.cpp index 024ebeb4..24f07a9a 100644 --- a/src/qtui/nicklistwidget.cpp +++ b/src/qtui/nicklistwidget.cpp @@ -1,11 +1,11 @@ /*************************************************************************** - * 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 * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * + * (at your option) version 3. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * @@ -22,29 +22,39 @@ #include "buffer.h" #include "nickview.h" +#include "client.h" +#include "networkmodel.h" +#include "nickmodel.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); - } + NickView *view = new NickView(this); + view->setModel(Client::nickModel()); + view->setRootIndex(Client::nickModel()->mapFromSource(bufferIdx)); + nickViews[bufferId] = view; + ui.stackedWidget->addWidget(view); + ui.stackedWidget->setCurrentWidget(view); } } @@ -53,4 +63,14 @@ void NickListWidget::reset() { ui.stackedWidget->removeWidget(view); view->deleteLater(); } + nickViews.clear(); +} + +void NickListWidget::removeBuffer(BufferId bufferId) { + if(!nickViews.contains(bufferId)) + return; + + NickView *view = nickViews.take(bufferId); + ui.stackedWidget->removeWidget(view); + view->deleteLater(); }