X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fbufferview.cpp;h=ed530edb947d6a19b248a4d34cc66e013590ba0f;hp=7f690e17152c6e75521c9941084c9298ca4ed05d;hb=a1bcca1c86e88406a0c5495b08731e6b11dd987e;hpb=c79539bee8761bcabe057d8d72594d16da24528f diff --git a/src/uisupport/bufferview.cpp b/src/uisupport/bufferview.cpp index 7f690e17..ed530edb 100644 --- a/src/uisupport/bufferview.cpp +++ b/src/uisupport/bufferview.cpp @@ -54,7 +54,8 @@ BufferView::BufferView(QWidget *parent) _joinBufferAction(tr("Join"), this), _partBufferAction(tr("Part"), this), - _hideBufferAction(tr("Hide selected buffers"), this), + _hideBufferTemporarilyAction(tr("Hide buffers"), this), + _hideBufferPermanentlyAction(tr("Hide buffers permanently"), this), _removeBufferAction(tr("Delete buffer"), this), _ignoreListAction(tr("Ignore list"), this), @@ -158,8 +159,6 @@ void BufferView::setFilteredModel(QAbstractItemModel *model_, BufferViewConfig * } else { BufferViewFilter *filter = new BufferViewFilter(model_, config); setModel(filter); - connect(this, SIGNAL(removeBuffer(const QModelIndex &)), - filter, SLOT(removeBuffer(const QModelIndex &))); } setConfig(config); } @@ -227,13 +226,26 @@ void BufferView::keyPressEvent(QKeyEvent *event) { QTreeView::keyPressEvent(event); } -void BufferView::removeSelectedBuffers() { - QSet removedRows; +void BufferView::removeSelectedBuffers(bool permanently) { + if(!config()) + return; + + BufferId bufferId; + QSet removedRows; foreach(QModelIndex index, selectionModel()->selectedIndexes()) { - if(index.data(NetworkModel::ItemTypeRole) == NetworkModel::BufferItemType && !removedRows.contains(index.row())) { - removedRows << index.row(); - emit removeBuffer(index); - } + if(index.data(NetworkModel::ItemTypeRole) != NetworkModel::BufferItemType) + continue; + + bufferId = index.data(NetworkModel::BufferIdRole).value(); + if(removedRows.contains(bufferId)) + continue; + + removedRows << bufferId; + + if(permanently) + config()->requestRemoveBufferPermanently(bufferId); + else + config()->requestRemoveBuffer(bufferId); } } @@ -405,18 +417,21 @@ void BufferView::contextMenuEvent(QContextMenuEvent *event) { case BufferInfo::ChannelBuffer: addItemToMenu(_joinBufferAction, contextMenu, index, InactiveState); addItemToMenu(_partBufferAction, contextMenu, index, ActiveState); - addItemToMenu(_hideBufferAction, contextMenu, (bool)config()); + addItemToMenu(_hideBufferTemporarilyAction, contextMenu, (bool)config()); + addItemToMenu(_hideBufferPermanentlyAction, contextMenu, (bool)config()); addItemToMenu(_removeBufferAction, contextMenu, index, InactiveState); createHideEventsSubMenu(contextMenu); addItemToMenu(_ignoreListAction, contextMenu); break; case BufferInfo::QueryBuffer: - addItemToMenu(_hideBufferAction, contextMenu, (bool)config()); + addItemToMenu(_hideBufferTemporarilyAction, contextMenu, (bool)config()); + addItemToMenu(_hideBufferPermanentlyAction, contextMenu, (bool)config()); addItemToMenu(_removeBufferAction, contextMenu); createHideEventsSubMenu(contextMenu); break; default: - addItemToMenu(_hideBufferAction, contextMenu, (bool)config()); + addItemToMenu(_hideBufferTemporarilyAction, contextMenu, (bool)config()); + addItemToMenu(_hideBufferPermanentlyAction, contextMenu, (bool)config()); break; } } @@ -467,11 +482,16 @@ void BufferView::contextMenuEvent(QContextMenuEvent *event) { return; } - if(result == &_hideBufferAction) { + if(result == &_hideBufferTemporarilyAction) { removeSelectedBuffers(); return; } + if(result == &_hideBufferPermanentlyAction) { + removeSelectedBuffers(true); + return; + } + if(result == &_removeBufferAction) { BufferInfo bufferInfo = index.data(NetworkModel::BufferInfoRole).value(); int res = QMessageBox::question(this, tr("Remove buffer permanently?"),