summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--desktop-widgets/divelistview.cpp36
-rw-r--r--desktop-widgets/divelistview.h1
2 files changed, 36 insertions, 1 deletions
diff --git a/desktop-widgets/divelistview.cpp b/desktop-widgets/divelistview.cpp
index 6cb4a81c3..4af42e713 100644
--- a/desktop-widgets/divelistview.cpp
+++ b/desktop-widgets/divelistview.cpp
@@ -533,10 +533,44 @@ void DiveListView::currentChanged(const QModelIndex &current, const QModelIndex&
scrollTo(current);
}
+void DiveListView::mouseReleaseEvent(QMouseEvent *event)
+{
+ // Oy vey. We hook into QTreeView's setSelection() to update the UI
+ // after selection changes. However, there is a case when this doesn't
+ // work: when narrowing the selection. If multiple dives are selected,
+ // and the user clicks on one of them, the selection is unchanged.
+ // Only on mouse-release the selection is changed, but then
+ // setSelection() is not called.
+ // Notably, this happens when the user selects a trip and the clicks
+ // on a dive in the same trip.
+ // To solve this, we hook into the mouseReleseEvent here and detect
+ // selection changes changes by comparing the selection before and after
+ // processing of the event.
+ // We really should find another way to solve this.
+ QModelIndexList selectionBefore = selectionModel()->selectedRows();
+ QTreeView::mouseReleaseEvent(event);
+ QModelIndexList selectionAfter = selectionModel()->selectedRows();
+ if (selectionBefore != selectionAfter)
+ selectionChangeDone();
+}
+
void DiveListView::setSelection(const QRect &rect, QItemSelectionModel::SelectionFlags flags)
{
+ // We hook into QTreeView's setSelection() to update the UI
+ // after selection changes. However, we must be careful:
+ // when the user clicks on an already selected dive, this is called
+ // with the QItemSelectionModel::NoUpdate flags. In this case, just
+ // route through. Moreover, we get setSelection() calls on every
+ // mouseMove event. To avoid excessive reloading of the UI check
+ // if the selection changed by comparing before and after processing
+ // the selection.
+ if (flags == QItemSelectionModel::NoUpdate)
+ return QTreeView::setSelection(rect, flags);
+ QModelIndexList selectionBefore = selectionModel()->selectedRows();
QTreeView::setSelection(rect, flags);
- selectionChangeDone();
+ QModelIndexList selectionAfter = selectionModel()->selectedRows();
+ if (selectionBefore != selectionAfter)
+ selectionChangeDone();
}
void DiveListView::selectAll()
diff --git a/desktop-widgets/divelistview.h b/desktop-widgets/divelistview.h
index ca6c61e9e..20f568479 100644
--- a/desktop-widgets/divelistview.h
+++ b/desktop-widgets/divelistview.h
@@ -65,6 +65,7 @@ slots:
void tripChanged(dive_trip *trip, TripField);
private:
void setSelection(const QRect &rect, QItemSelectionModel::SelectionFlags flags) override;
+ void mouseReleaseEvent(QMouseEvent *event) override;
void selectAll() override;
void selectionChangeDone();
DiveTripModelBase::Layout currentLayout;