From e175b1d1ab76ee8edcd3beb1c027a58a336af96e Mon Sep 17 00:00:00 2001 From: Tomaz Canabrava Date: Tue, 26 Nov 2013 15:44:18 -0200 Subject: Remember Trip Selection. This patch remembers the trip selection across the Dive Tree Model. It's a tiny bit big because we used to have a variable 'selected trips' that's now calculed dynamically - this is more future proof. This is a start of Un-cluttering the view ( for 4.1 I hope to reduce the code in this class to nearly a half. ) Fixes #303 Signed-off-by: Tomaz Canabrava Signed-off-by: Dirk Hohndel --- qt-ui/divelistview.cpp | 56 +++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 46 insertions(+), 10 deletions(-) (limited to 'qt-ui/divelistview.cpp') diff --git a/qt-ui/divelistview.cpp b/qt-ui/divelistview.cpp index e646bab04..d8538a5fd 100644 --- a/qt-ui/divelistview.cpp +++ b/qt-ui/divelistview.cpp @@ -47,8 +47,6 @@ DiveListView::DiveListView(QWidget *parent) : QTreeView(parent), mouseClickSelec searchBox->hide(); connect(showSearchBox, SIGNAL(triggered(bool)), this, SLOT(showSearchEdit())); connect(searchBox, SIGNAL(textChanged(QString)), model, SLOT(setFilterFixedString(QString))); - selectedTrips.clear(); - setupUi(); } @@ -133,24 +131,66 @@ void DiveListView::rememberSelection() continue; struct dive *d = (struct dive *) index.data(DiveTripModel::DIVE_ROLE).value(); if (d) - selectedDives.push_front(get_divenr(d)); + selectedDives.insert(d->divetrip, get_divenr(d)); } } void DiveListView::restoreSelection() { unselectDives(); - selectedTrips.clear(); // I wish we didn't lose those... - Q_FOREACH(int i, selectedDives) { - selectDive(i); + Q_FOREACH(dive_trip_t *trip, selectedDives.keys()){ + QList divesOnTrip = getDivesInTrip(trip); + QList selectedDivesOnTrip = selectedDives.values(trip); + + // Trip was not selected, let's select single-dives. + if (trip == NULL || divesOnTrip.count() != selectedDivesOnTrip.count()){ + Q_FOREACH(int i, selectedDivesOnTrip){ + selectDive(i); + } + }else{ + selectTrip(trip); + Q_FOREACH(int i, selectedDivesOnTrip){ + selectDive(i); + } + } } } +void DiveListView::selectTrip ( dive_trip_t* trip ) +{ + if (!trip) + return; + + QSortFilterProxyModel *m = qobject_cast(model()); + QModelIndexList match = m->match(m->index(0,0), DiveTripModel::TRIP_ROLE, QVariant::fromValue(trip), 2, Qt::MatchRecursive); + QItemSelectionModel::SelectionFlags flags; + if (!match.count()) + return; + QModelIndex idx = match.first(); + flags = QItemSelectionModel::Select; + flags |= QItemSelectionModel::Rows; + selectionModel()->select(idx, flags); + expand(idx); +} + void DiveListView::unselectDives() { selectionModel()->clearSelection(); } +QList< dive_trip_t* > DiveListView::selectedTrips() +{ + QModelIndexList indexes = selectionModel()->selectedRows(); + QList ret; + Q_FOREACH(const QModelIndex& index, indexes){ + dive_trip_t *trip = static_cast(index.data(DiveTripModel::TRIP_ROLE).value()); + if(!trip) + continue; + ret.push_back(trip); + } + return ret; +} + void DiveListView::selectDive(int i, bool scrollto, bool toggle) { if( i == -1) @@ -347,8 +387,6 @@ void DiveListView::selectionChanged(const QItemSelection& selected, const QItemS if (!dive) { // it's a trip! if (model->rowCount(index)) { struct dive *child = (struct dive*) model->data(index.child(0,0), DiveTripModel::DIVE_ROLE).value(); - if (child && child->divetrip) - selectedTrips.remove(child->divetrip); while (child) { deselect_dive(get_divenr(child)); child = child->next; @@ -368,8 +406,6 @@ void DiveListView::selectionChanged(const QItemSelection& selected, const QItemS if (model->rowCount(index)) { QItemSelection selection; struct dive *child = (struct dive*) model->data(index.child(0,0), DiveTripModel::DIVE_ROLE).value(); - if (child && child->divetrip) - selectedTrips.insert(child->divetrip); while (child) { select_dive(get_divenr(child)); child = child->next; -- cgit v1.2.3-70-g09d2