X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fbufferview.cpp;h=9887818b8737406cd413f99b102d74bff6678b01;hp=598686eceefdb2f299748deef2fd574eb29e5061;hb=c16309b21ea5aafca07b111567aa17be0f3155ea;hpb=c0e4730a50f812cd3795d47561357ff221094f8c diff --git a/src/uisupport/bufferview.cpp b/src/uisupport/bufferview.cpp index 598686ec..9887818b 100644 --- a/src/uisupport/bufferview.cpp +++ b/src/uisupport/bufferview.cpp @@ -20,9 +20,11 @@ #include "bufferview.h" +#include "buffermodel.h" #include "bufferviewfilter.h" #include "buffersyncer.h" #include "client.h" +#include "mappedselectionmodel.h" #include "network.h" #include "networkmodel.h" @@ -78,11 +80,12 @@ void BufferView::init() { void BufferView::setModel(QAbstractItemModel *model) { delete selectionModel(); + if(QTreeView::model()) { + disconnect(QTreeView::model(), SIGNAL(layoutChanged()), this, SLOT(updateSelection())); + } + QTreeView::setModel(model); init(); - if(!model) - return; - // remove old Actions QList oldactions = header()->actions(); foreach(QAction *action, oldactions) { @@ -90,6 +93,11 @@ void BufferView::setModel(QAbstractItemModel *model) { action->deleteLater(); } + if(!model) + return; + + connect(model, SIGNAL(layoutChanged()), this, SLOT(updateSelection())); + QString sectionName; QAction *showSection; for(int i = 1; i < model->columnCount(); i++) { @@ -182,14 +190,25 @@ void BufferView::keyPressEvent(QKeyEvent *event) { // ensure that newly inserted network nodes are expanded per default void BufferView::rowsInserted(const QModelIndex & parent, int start, int end) { QTreeView::rowsInserted(parent, start, end); - if(model()->rowCount(parent) == 1 && parent.data(NetworkModel::ItemTypeRole) == NetworkModel::NetworkItemType - && parent.data(NetworkModel::ItemActiveRole) == true) { + if(parent.data(NetworkModel::ItemTypeRole) != NetworkModel::NetworkItemType) + return; + + if(model()->rowCount(parent) == 1 && parent.data(NetworkModel::ItemActiveRole) == true) { // without updating the parent the expand will have no effect... Qt Bug? update(parent); expand(parent); } } +void BufferView::updateSelection() { + MappedSelectionModel *mappedSelectionModel = qobject_cast(selectionModel()); + if(!config()) + return; + + mappedSelectionModel->mappedSetCurrentIndex(Client::bufferModel()->standardSelectionModel()->currentIndex(), QItemSelectionModel::Current); + mappedSelectionModel->mappedSelect(Client::bufferModel()->standardSelectionModel()->selection(), QItemSelectionModel::ClearAndSelect | QItemSelectionModel::Rows); +} + void BufferView::dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight) { QTreeView::dataChanged(topLeft, bottomRight);