summaryrefslogtreecommitdiffstats
path: root/src/widgets
diff options
context:
space:
mode:
authorSlávek Banko <slavek.banko@axis.cz>2017-07-02 15:37:41 +0200
committerSlávek Banko <slavek.banko@axis.cz>2017-07-02 15:37:41 +0200
commit2af0620bfcb7547a7786ac2ee209e0dd6e39ec60 (patch)
treeec64e97f65ab053e084c6d5410cf12ecc8b464d4 /src/widgets
parent5b1f451dd66adcc83b49001e56d79ea06163a1b2 (diff)
downloadtqt3-2af0620bfcb7547a7786ac2ee209e0dd6e39ec60.tar.gz
tqt3-2af0620bfcb7547a7786ac2ee209e0dd6e39ec60.zip
ListView: Deselect items that are hidden by the filter
during selectAll and invertSelection Signed-off-by: Slávek Banko <slavek.banko@axis.cz>
Diffstat (limited to 'src/widgets')
-rw-r--r--src/widgets/qlistview.cpp26
1 files changed, 21 insertions, 5 deletions
diff --git a/src/widgets/qlistview.cpp b/src/widgets/qlistview.cpp
index 774c97306..c4a974369 100644
--- a/src/widgets/qlistview.cpp
+++ b/src/widgets/qlistview.cpp
@@ -5366,9 +5366,17 @@ void TQListView::selectAll( bool select )
TQListViewItemIterator it( this );
while ( it.current() ) {
TQListViewItem *i = it.current();
- if ( (bool)i->selected != select ) {
- i->setSelected( select );
- anything = TRUE;
+ if ( i->isVisible()) {
+ if ( (bool)i->selected != select ) {
+ i->setSelected( select );
+ anything = TRUE;
+ }
+ }
+ else {
+ if ( (bool)i->selected != FALSE ) {
+ i->setSelected( FALSE );
+ anything = TRUE;
+ }
}
++it;
}
@@ -5398,8 +5406,16 @@ void TQListView::invertSelection()
bool b = signalsBlocked();
blockSignals( TRUE );
TQListViewItemIterator it( this );
- for ( ; it.current(); ++it )
- it.current()->setSelected( !it.current()->isSelected() );
+ for ( ; it.current(); ++it ) {
+ if (it.current()->isVisible()) {
+ it.current()->setSelected( !it.current()->isSelected() );
+ }
+ else {
+ if ( FALSE != it.current()->isSelected() ) {
+ it.current()->setSelected( FALSE );
+ }
+ }
+ }
blockSignals( b );
emit selectionChanged();
triggerUpdate();