summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2018-11-13 09:26:53 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-11-18 16:50:09 -0800
commit911edfca712a046944de6d033cc4b8dd50cedfc3 (patch)
tree249edec4b36a96a365f0a9bea928055fdec42d96
parent64e6e435f82801f4f440ef5b1caf58a91a7c9929 (diff)
downloadsubsurface-911edfca712a046944de6d033cc4b8dd50cedfc3.tar.gz
Dive list: update position of trip if data changed
If the date of a dive changed, it might be necessary to reorder the trips, as the date of the trip changed. Although this seems like an odd usecase, move the trip if necessary, for consistency's sake. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r--qt-models/divetripmodel.cpp45
-rw-r--r--qt-models/divetripmodel.h1
2 files changed, 39 insertions, 7 deletions
diff --git a/qt-models/divetripmodel.cpp b/qt-models/divetripmodel.cpp
index c83a14e7b..c2d9e62a9 100644
--- a/qt-models/divetripmodel.cpp
+++ b/qt-models/divetripmodel.cpp
@@ -688,6 +688,36 @@ int DiveTripModel::findInsertionIndex(const dive_trip *trip) const
return items.size();
}
+// After a top-level item changed (notably a trip), it might
+// need to be reordered. Move the item and send a "data-changed" signal.
+void DiveTripModel::topLevelChanged(int idx)
+{
+ if (idx < 0 || idx >= (int)items.size())
+ return;
+
+ // First, try to move backwards
+ int newIdx = idx;
+ while (newIdx > 0 && dive_or_trip_less_than(items[idx].d_or_t, items[newIdx - 1].d_or_t))
+ --newIdx;
+
+ // If that didn't change, try to move forward
+ if (newIdx == idx) {
+ while (newIdx <= (int)items.size() && !dive_or_trip_less_than(items[idx].d_or_t, items[newIdx + 1].d_or_t))
+ ++newIdx;
+ }
+
+ // If index changed, move items
+ if (newIdx != idx) {
+ beginMoveRows(QModelIndex(), idx, idx, QModelIndex(), newIdx);
+ moveInVector(items, idx, idx + 1, newIdx);
+ endMoveRows();
+ }
+
+ // Finally, inform UI of changed trip header
+ QModelIndex tripIdx = createIndex(newIdx, 0, noParent);
+ dataChanged(tripIdx, tripIdx);
+}
+
// Add items from vector "v2" to vector "v1" in batches of contiguous objects.
// The items are inserted at places according to a sort order determined by "comp".
// "v1" and "v2" are supposed to be ordered accordingly.
@@ -739,6 +769,9 @@ void DiveTripModel::addDivesToTrip(int trip, const QVector<dive *> &dives)
items.insert(items.begin() + idx, dives.begin() + from, dives.begin() + to);
endInsertRows();
});
+
+ // If necessary, move the trip
+ topLevelChanged(trip);
}
// This function is used to compare a dive to an arbitrary entry (dive or trip).
@@ -783,10 +816,6 @@ void DiveTripModel::divesAdded(dive_trip *trip, bool addTrip, const QVector<dive
// ...and add dives.
addDivesToTrip(idx, dives);
-
- // We have to signal that the trip changed, so that the number of dives in th header is updated
- QModelIndex tripIndex = createIndex(idx, 0, noParent);
- dataChanged(tripIndex, tripIndex);
}
}
@@ -833,9 +862,8 @@ void DiveTripModel::divesDeleted(dive_trip *trip, bool deleteTrip, const QVector
return from - to; // Delta: negate the number of items deleted
});
- // We have to signal that the trip changed, so that the number of dives in th header is updated
- QModelIndex tripIndex = createIndex(idx, 0, noParent);
- dataChanged(tripIndex, tripIndex);
+ // If necessary, move the trip
+ topLevelChanged(idx);
}
}
}
@@ -874,6 +902,9 @@ void DiveTripModel::divesChanged(dive_trip *trip, const QVector<dive *> &dives)
dataChanged(createIndex(from, 0, idx), createIndex(to - 1, COLUMNS - 1, idx));
return 0; // No items added or deleted
});
+
+ // If necessary, move the trip
+ topLevelChanged(idx);
}
}
diff --git a/qt-models/divetripmodel.h b/qt-models/divetripmodel.h
index 6d34d30bb..aab154069 100644
--- a/qt-models/divetripmodel.h
+++ b/qt-models/divetripmodel.h
@@ -115,6 +115,7 @@ private:
// Addition and deletion of dives
void addDivesToTrip(int idx, const QVector<dive *> &dives);
+ void topLevelChanged(int idx);
dive *diveOrNull(const QModelIndex &index) const; // Returns a dive if this index represents a dive, null otherwise
dive_or_trip tripOrDive(const QModelIndex &index) const;