setFlags(flags);
}
-const BufferInfo &BufferItem::bufferInfo() const {
- return _bufferInfo;
-}
-
quint64 BufferItem::id() const {
return qHash(bufferInfo().bufferId());
}
-bool BufferItem::isStatusBuffer() const {
- return bufferType() == BufferInfo::StatusBuffer;
-}
-
-BufferInfo::Type BufferItem::bufferType() const {
- return bufferInfo().type();
-}
+// bool BufferItem::isStatusBuffer() const {
+// return bufferType() == BufferInfo::StatusBuffer;
+// }
bool BufferItem::isActive() const {
if(bufferType() == BufferInfo::ChannelBuffer)
this, SLOT(attachIrcChannel(QString)));
connect(network, SIGNAL(connectedSet(bool)),
this, SIGNAL(dataChanged()));
-
- // FIXME: connect this and that...
emit dataChanged();
}
public:
BufferItem(BufferInfo bufferInfo, AbstractTreeItem *parent = 0);
- const BufferInfo &bufferInfo() const;
+ inline const BufferInfo &bufferInfo() const { return _bufferInfo; }
virtual quint64 id() const;
virtual QVariant data(int column, int role) const;
virtual bool setData(int column, const QVariant &value, int role);
void attachIrcChannel(IrcChannel *ircChannel);
QString bufferName() const;
+ inline BufferId bufferId() const { return _bufferInfo.bufferId(); }
+ inline BufferInfo::Type bufferType() const { return _bufferInfo.type(); }
+
void setBufferName(const QString &name);
QString topic() const;
int nickCount() const;
- bool isStatusBuffer() const;
- BufferInfo::Type bufferType() const;
+ // bool isStatusBuffer() const;
bool isActive() const;
NetworkItem(const NetworkId &netid, AbstractTreeItem *parent = 0);
virtual quint64 id() const;
- inline const NetworkId &networkId() const { return _networkId; }
virtual QVariant data(int column, int row) const;
bool isActive() const;
+ inline const NetworkId &networkId() const { return _networkId; }
QString networkName() const;
QString currentServer() const;
int nickCount() const;
}
void BufferWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) {
- Q_UNUSED(previous);
- QVariant variant;
-
- variant = current.data(NetworkModel::BufferIdRole);
- if(!variant.isValid())
- return;
- setCurrentBuffer(variant.value<BufferId>());
+ BufferId newBufferId = current.data(NetworkModel::BufferIdRole).value<BufferId>();
+ BufferId oldBufferId = previous.data(NetworkModel::BufferIdRole).value<BufferId>();
+ if(newBufferId != oldBufferId)
+ setCurrentBuffer(newBufferId);
}
void BufferWidget::setCurrentBuffer(BufferId bufferId) {
+ if(!bufferId.isValid()) {
+ ui.stackedWidget->setCurrentWidget(ui.page);
+ return;
+ }
+
ChatWidget *chatWidget = 0;
Buffer *buf = Client::buffer(bufferId);
if(!buf) {
#include "nickview.h"
#include "client.h"
#include "networkmodel.h"
+#include "buffermodel.h"
#include "nickviewfilter.h"
NickListWidget::NickListWidget(QWidget *parent)
}
}
-
-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();
- }
-}
-
-
void NickListWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) {
- Q_UNUSED(previous);
- QVariant variant;
-
- variant = current.data(NetworkModel::BufferIdRole);
- if(!variant.isValid())
- return;
- setCurrentBuffer(variant.value<BufferId>());
-}
+ 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);
return;
}
- 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++) {
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();
}