]> cloud.milkyroute.net Git - dolphin.git/commitdiff
Fixed issue in details view, that "sometimes" the rubberband selection only selects...
authorPeter Penz <peter.penz19@gmail.com>
Mon, 11 Jan 2010 13:29:27 +0000 (13:29 +0000)
committerPeter Penz <peter.penz19@gmail.com>
Mon, 11 Jan 2010 13:29:27 +0000 (13:29 +0000)
It took me nearly 30 minutes to find out how to reproduce this issue 100 % reliable:
- a confirm dialog must be shown (thanks a lot to Dario for the hint!)
- the most important part: the keys (e. g. Shift + Del) must be pressed long enough until the confirm dialog grabs the focus from the details view...

BUG: 220898
BUG: 183386
BUG: 203112

svn path=/trunk/KDE/kdebase/apps/; revision=1073043

src/dolphindetailsview.cpp
src/dolphindetailsview.h

index 5df10534068ebafd3ea2379418483b16b91e5457..5a6342098de422d42c8e7cec0650d046bd078373 100644 (file)
@@ -171,7 +171,7 @@ QSet<KUrl> DolphinDetailsView::expandedUrls() const
     return m_expandedUrls;
 }
 
-QRegion DolphinDetailsView::visualRegionForSelection(const QItemSelection &selection) const
+QRegion DolphinDetailsView::visualRegionForSelection(const QItemSelectionselection) const
 {
     // We have to make sure that the visualRect of each model index is inside the region.
     // QTreeView::visualRegionForSelection does not do it right because it assumes implicitly
@@ -188,9 +188,21 @@ QRegion DolphinDetailsView::visualRegionForSelection(const QItemSelection &selec
 
 bool DolphinDetailsView::event(QEvent* event)
 {
-    if (event->type() == QEvent::Polish) {
+    switch (event->type()) {
+    case QEvent::Polish:
         header()->setResizeMode(QHeaderView::Interactive);
         updateColumnVisibility();
+        break;
+
+    case QEvent::FocusOut:
+        // If a key-press triggers an action that e. g. opens a dialog, the
+        // widget gets no key-release event. Assure that the pressed state
+        // is reset to prevent accidently setting the current index during a selection.
+        m_keyPressed = false;
+        break;
+
+    default:
+        break;
     }
 
     return QTreeView::event(event);
@@ -765,8 +777,7 @@ void DolphinDetailsView::updateElasticBandSelection()
                 return;
             }
         }
-    }
-    else {
+    } else {
         // This is the only piece of optimization data that needs to be explicitly
         // discarded.
         m_band.lastSelectionOrigin = QPoint();
@@ -880,6 +891,7 @@ void DolphinDetailsView::updateElasticBandSelection()
        currIndex = nextIndex;
     } while (!allItemsInBoundDone);
 
+
     selectionModel()->select(itemsToToggle, QItemSelectionModel::Toggle);
 
     m_band.lastSelectionOrigin = m_band.origin;
index 3bd62d33fc7f9f077a671a92029f502ebd9450ee..ddf47bfc3ec62329d5eecb9f188470e3b82cddd2 100644 (file)
@@ -52,7 +52,7 @@ public:
      */
     QSet<KUrl> expandedUrls() const;
 
-    virtual QRegion visualRegionForSelection(const QItemSelection & selection) const;
+    virtual QRegion visualRegionForSelection(const QItemSelection& selection) const;
 
 protected:
     virtual bool event(QEvent* event);