summaryrefslogtreecommitdiffstats
path: root/konqueror/listview/konq_listviewwidget.cc
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2014-10-09 11:11:44 -0500
committerTimothy Pearson <[email protected]>2014-10-09 11:11:44 -0500
commit4e5a99f6d298ecd31eb229b14fabaaf4fb5b8d8e (patch)
tree4ab6019fc3771a1a1a18c4723085939e5550c971 /konqueror/listview/konq_listviewwidget.cc
parentf4dab230c4d9f9e2aca86df98d2ee7398f9988aa (diff)
downloadtdebase-4e5a99f6d298ecd31eb229b14fabaaf4fb5b8d8e.tar.gz
tdebase-4e5a99f6d298ecd31eb229b14fabaaf4fb5b8d8e.zip
Reset keyboard selection when using mouse rubberband to select items
This relates to Bug 1961
Diffstat (limited to 'konqueror/listview/konq_listviewwidget.cc')
-rw-r--r--konqueror/listview/konq_listviewwidget.cc140
1 files changed, 69 insertions, 71 deletions
diff --git a/konqueror/listview/konq_listviewwidget.cc b/konqueror/listview/konq_listviewwidget.cc
index 1fdb86e74..75d2c995c 100644
--- a/konqueror/listview/konq_listviewwidget.cc
+++ b/konqueror/listview/konq_listviewwidget.cc
@@ -406,66 +406,60 @@ void KonqBaseListViewWidget::initConfig()
updateListContents();
}
-void KonqBaseListViewWidget::contentsMousePressEvent( TQMouseEvent *e )
-{
- if ( m_rubber )
- {
-
- TQRect r( m_rubber->normalize() );
- delete m_rubber;
- m_rubber = 0;
- repaintContents( r, FALSE );
- }
-
- delete m_selected;
- m_selected = new TQPtrList<KonqBaseListViewItem>;
-
- TQPoint vp = contentsToViewport( e->pos() );
- KonqBaseListViewItem* item = isExecuteArea( vp ) ?
- static_cast<KonqBaseListViewItem*>( itemAt( vp ) ) : 0L;
-
- if ( item ) {
- TDEListView::contentsMousePressEvent( e );
- }
- else {
- if ( e->button() == Qt::LeftButton )
- {
- m_rubber = new TQRect( e->x(), e->y(), 0, 0 );
- clearSelection();
- emit selectionChanged();
- m_fileTip->setItem( 0 );
- }
- if ( e->button() != Qt::RightButton )
- TQListView::contentsMousePressEvent( e );
- }
- // Store list of selected items at mouse-press time.
- // This is used when autoscrolling (why?)
- // and during dnd (the target item is temporarily selected)
- selectedItems( m_selected );
+void KonqBaseListViewWidget::contentsMousePressEvent( TQMouseEvent *e ) {
+ if ( m_rubber ) {
+ TQRect r( m_rubber->normalize() );
+ delete m_rubber;
+ m_rubber = 0;
+ repaintContents( r, FALSE );
+ }
+
+ delete m_selected;
+ m_selected = new TQPtrList<KonqBaseListViewItem>;
+
+ TQPoint vp = contentsToViewport( e->pos() );
+ KonqBaseListViewItem* item = isExecuteArea( vp ) ?
+ static_cast<KonqBaseListViewItem*>( itemAt( vp ) ) : 0L;
+
+ if ( item ) {
+ TDEListView::contentsMousePressEvent( e );
+ }
+ else {
+ if ( e->button() == Qt::LeftButton ) {
+ m_rubber = new TQRect( e->x(), e->y(), 0, 0 );
+ clearSelection();
+ emit selectionChanged();
+ m_fileTip->setItem( 0 );
+ }
+ if ( e->button() != Qt::RightButton ) {
+ TQListView::contentsMousePressEvent( e );
+ }
+ }
+
+ // Store list of selected items at mouse-press time.
+ // This is used when autoscrolling (why?)
+ // and during dnd (the target item is temporarily selected)
+ selectedItems( m_selected );
}
-void KonqBaseListViewWidget::contentsMouseReleaseEvent( TQMouseEvent *e )
-{
- if ( m_rubber )
- {
-
- TQRect r( m_rubber->normalize() );
- delete m_rubber;
- m_rubber = 0;
- repaintContents( r, FALSE );
- }
-
- if ( m_scrollTimer )
- {
- disconnect( m_scrollTimer, TQT_SIGNAL( timeout() ),
- this, TQT_SLOT( slotAutoScroll() ) );
- m_scrollTimer->stop();
- delete m_scrollTimer;
- m_scrollTimer = 0;
- }
-
- delete m_selected; m_selected = 0;
- TDEListView::contentsMouseReleaseEvent( e );
+void KonqBaseListViewWidget::contentsMouseReleaseEvent( TQMouseEvent *e ) {
+ if ( m_rubber ) {
+ resetKeyboardSelectionOperation();
+ TQRect r( m_rubber->normalize() );
+ delete m_rubber;
+ m_rubber = 0;
+ repaintContents( r, FALSE );
+ }
+
+ if ( m_scrollTimer ) {
+ disconnect( m_scrollTimer, TQT_SIGNAL( timeout() ), this, TQT_SLOT( slotAutoScroll() ) );
+ m_scrollTimer->stop();
+ delete m_scrollTimer;
+ m_scrollTimer = 0;
+ }
+
+ delete m_selected; m_selected = 0;
+ TDEListView::contentsMouseReleaseEvent( e );
}
void KonqBaseListViewWidget::contentsMouseMoveEvent( TQMouseEvent *e )
@@ -558,7 +552,6 @@ void KonqBaseListViewWidget::drawRubber( TQPainter *p )
style().tqdrawPrimitive( TQStyle::PE_RubberBand, p,
TQRect( pt.x(), pt.y(), m_rubber->width(), m_rubber->height() ),
colorGroup(), TQStyle::Style_Default, colorGroup().base() );
-
}
void KonqBaseListViewWidget::slotAutoScroll()
@@ -570,16 +563,17 @@ void KonqBaseListViewWidget::slotAutoScroll()
const TQPoint pos = viewport()->mapFromGlobal( TQCursor::pos() );
const TQPoint vc = viewportToContents( pos );
+ TQListViewItem *at = itemAt( vc );
if ( vc == m_rubber->bottomRight() )
return;
- TQRect oldRubber = *m_rubber;
-
+ TQRect oldRubber = *m_rubber;
+
const int oldTop = m_rubber->normalize().top();
const int oldBottom = m_rubber->normalize().bottom();
-
+
m_rubber->setBottomRight( vc );
TQListViewItem *cur = itemAt( TQPoint(0,0) );
@@ -590,7 +584,7 @@ void KonqBaseListViewWidget::slotAutoScroll()
TQRect rr;
TQRect nr = m_rubber->normalize();
bool changed = FALSE;
-
+
if ( cur )
{
TQRect rect;
@@ -600,7 +594,7 @@ void KonqBaseListViewWidget::slotAutoScroll()
rect = itemRect( cur );
rect.setWidth( executeArea( cur ) );
}
-
+
rect = TQRect( viewportToContents( rect.topLeft() ),
viewportToContents( rect.bottomRight() ) );
@@ -626,24 +620,26 @@ void KonqBaseListViewWidget::slotAutoScroll()
if ( !cur->isSelected() && cur->isSelectable() )
{
setSelected( cur, true );
+ setActiveMultiSelectItem( at );
changed = TRUE;
rr = rr.unite( itemRect( cur ) );
}
- }
- else
+ }
+ else
{
if ( cur->isSelected() )
{
changed = TRUE;
rr = rr.unite( itemRect( cur ) );
}
-
+
if ( !m_selected || !m_selected->contains( (KonqBaseListViewItem*)cur ) )
{
setSelected( cur, false );
+ setActiveMultiSelectItem( at );
}
}
-
+
cur = cur->itemBelow();
if (cur && !allColumnsShowFocus())
@@ -662,6 +658,7 @@ void KonqBaseListViewWidget::slotAutoScroll()
if ( !cur->isSelected() && cur->isSelectable() )
{
setSelected( cur, true );
+ setActiveMultiSelectItem( at );
changed = TRUE;
rr = rr.unite( itemRect( cur ) );
}
@@ -677,6 +674,7 @@ void KonqBaseListViewWidget::slotAutoScroll()
if ( !m_selected || !m_selected->contains( (KonqBaseListViewItem*)cur ) )
{
setSelected( cur, false );
+ setActiveMultiSelectItem( at );
}
}
@@ -705,7 +703,7 @@ void KonqBaseListViewWidget::slotAutoScroll()
TQPixmap backrubber( viewport()->rect().size() );
backrubber.fill( viewport(), viewport()->rect().topLeft() );
- TQPainter p( &backrubber );
+ TQPainter p( &backrubber );
p.save();
drawContentsOffset( &p,
contentsX(),
@@ -745,9 +743,9 @@ void KonqBaseListViewWidget::slotAutoScroll()
void KonqBaseListViewWidget::viewportPaintEvent( TQPaintEvent *e )
{
-
+
TDEListView::viewportPaintEvent( e );
-
+
TQPainter p( viewport() );
drawRubber( &p );
p.end();