diff options
Diffstat (limited to 'qt-models')
-rw-r--r-- | qt-models/divetripmodel.cpp | 45 | ||||
-rw-r--r-- | qt-models/divetripmodel.h | 1 |
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; |