X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fuisupport%2Fbufferview.cpp;h=78d8bae0cdd215f12e531c18d1f1709b47acc75d;hb=8c61baf7286e42949d7d19517690628a2c550dd1;hp=48e75ba9d2bcf630c25d24bd02229cc808f72e23;hpb=997a62b68d7469a93f373476dd955c44eb051be0;p=quassel.git diff --git a/src/uisupport/bufferview.cpp b/src/uisupport/bufferview.cpp index 48e75ba9..78d8bae0 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(layoutChanged())); + } + 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(layoutChanged())); + QString sectionName; QAction *showSection; for(int i = 1; i < model->columnCount(); i++) { @@ -179,17 +187,44 @@ void BufferView::keyPressEvent(QKeyEvent *event) { QTreeView::keyPressEvent(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 - && (Global::SPUTDEV || parent.data(NetworkModel::ItemActiveRole) == true)) { + + // ensure that newly inserted network nodes are expanded per default + 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::layoutChanged() { + Q_ASSERT(model()); + + // expand all active networks + QModelIndex networkIdx; + for(int row = 0; row < model()->rowCount(); row++) { + networkIdx = model()->index(row, 0); + update(networkIdx); + if(model()->rowCount(networkIdx) > 0 && model()->data(networkIdx, NetworkModel::ItemActiveRole) == true) { + expand(networkIdx); + } else { + collapse(networkIdx); + } + } + + // update selection to current one + MappedSelectionModel *mappedSelectionModel = qobject_cast(selectionModel()); + if(!config() || !mappedSelectionModel) + 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); @@ -204,12 +239,11 @@ void BufferView::dataChanged(const QModelIndex &topLeft, const QModelIndex &bott continue; bool isActive = networkIdx.data(NetworkModel::ItemActiveRole).toBool(); - if(Global::SPUTDEV) { - if(isExpanded(networkIdx) != isActive) setExpanded(networkIdx, true); - } else { - if(isExpanded(networkIdx) != isActive) - setExpanded(networkIdx, isActive); - } +#ifdef SPUTDEV + if(isExpanded(networkIdx) != isActive) setExpanded(networkIdx, true); +#else + if(isExpanded(networkIdx) != isActive) setExpanded(networkIdx, isActive); +#endif } }