]> cloud.milkyroute.net Git - dolphin.git/commitdiff
Fixes MS Windows related issue that when opening a context menu above an item, that...
authorPeter Penz <peter.penz19@gmail.com>
Sun, 23 Nov 2008 11:54:24 +0000 (11:54 +0000)
committerPeter Penz <peter.penz19@gmail.com>
Sun, 23 Nov 2008 11:54:24 +0000 (11:54 +0000)
BUG: 168940

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

src/dolphincontroller.cpp
src/dolphincontroller.h

index 8493d877fa957b63b6d55ad87145d1965d66a31b..f6ee66634267940f58ae98edc17581e6bd069918 100644 (file)
@@ -29,7 +29,7 @@
 DolphinController::DolphinController(DolphinView* dolphinView) :
     QObject(dolphinView),
     m_zoomLevel(0),
-    m_openTab(false),
+    m_mouseButtons(Qt::NoButton),
     m_url(),
     m_dolphinView(dolphinView),
     m_itemView(0)
@@ -52,7 +52,7 @@ void DolphinController::setItemView(QAbstractItemView* view)
 {
     if (m_itemView != 0) {
         disconnect(m_itemView, SIGNAL(pressed(const QModelIndex&)),
-                   this, SLOT(updateOpenTabState()));
+                   this, SLOT(updateMouseButtonState()));
     }
 
     m_itemView = view;
@@ -62,7 +62,7 @@ void DolphinController::setItemView(QAbstractItemView* view)
         
         // TODO: this is a workaround until  Qt-issue 176832 has been fixed
         connect(m_itemView, SIGNAL(pressed(const QModelIndex&)),
-                this, SLOT(updateOpenTabState()));
+                this, SLOT(updateMouseButtonState()));
     }
 }
 
@@ -170,8 +170,13 @@ KFileItem DolphinController::itemForIndex(const QModelIndex& index) const
 
 void DolphinController::triggerItem(const QModelIndex& index)
 {
-    const bool openTab = m_openTab;
-    m_openTab = false;
+    if (m_mouseButtons & Qt::RightButton) {
+        // a context menu is opened - assure that no triggering is done
+        return;
+    }
+    
+    const bool openTab = m_mouseButtons & Qt::MidButton;
+    m_mouseButtons = Qt::NoButton;
 
     const KFileItem item = itemForIndex(index);
     if (index.isValid() && (index.column() == KDirModel::Name)) {
@@ -201,9 +206,9 @@ void DolphinController::emitViewportEntered()
     emit viewportEntered();
 }
 
-void DolphinController::updateOpenTabState()
+void DolphinController::updateMouseButtonState()
 {
-    m_openTab = QApplication::mouseButtons() & Qt::MidButton;
+    m_mouseButtons = QApplication::mouseButtons();
 }
 
 #include "dolphincontroller.moc"
index fd1b04ffcd87ba209b2f96fe19f5c506dde7653e..13a840a3806f848c5af9c2dba68f06bf1a5efb82 100644 (file)
@@ -345,11 +345,11 @@ signals:
     void hideToolTip();
 
 private slots:
-    void updateOpenTabState();
+    void updateMouseButtonState();
 
 private:
     int m_zoomLevel;
-    bool m_openTab; // TODO: this is a workaround until  Qt-issue 176832 has been fixed
+    Qt::MouseButtons m_mouseButtons; // TODO: this is a workaround until  Qt-issue 176832 has been fixed
     KUrl m_url;
     DolphinView* m_dolphinView;
     QAbstractItemView* m_itemView;