aboutsummaryrefslogtreecommitdiffstats
path: root/qt-models
diff options
context:
space:
mode:
Diffstat (limited to 'qt-models')
-rw-r--r--qt-models/divepicturemodel.cpp46
-rw-r--r--qt-models/divepicturemodel.h3
-rw-r--r--qt-models/diveplannermodel.cpp1
3 files changed, 43 insertions, 7 deletions
diff --git a/qt-models/divepicturemodel.cpp b/qt-models/divepicturemodel.cpp
index f080138cf..0aaf8f868 100644
--- a/qt-models/divepicturemodel.cpp
+++ b/qt-models/divepicturemodel.cpp
@@ -56,8 +56,14 @@ void DivePictureModel::updateDivePictures()
struct dive *dive;
for_each_dive (i, dive) {
if (dive->selected) {
+ int first = pictures.count();
FOR_EACH_PICTURE(dive)
- pictures.push_back({picture, picture->filename, {}, picture->offset.seconds});
+ pictures.push_back({ dive->id, picture, picture->filename, {}, picture->offset.seconds });
+
+ // Sort pictures of this dive by offset.
+ // Thus, the list will be sorted by (diveId, offset).
+ std::sort(pictures.begin() + first, pictures.end(),
+ [](const PictureEntry &a, const PictureEntry &b) { return a.offsetSeconds < b.offsetSeconds; });
}
}
@@ -166,11 +172,39 @@ void DivePictureModel::updateThumbnail(QString filename, QImage thumbnail)
}
}
-void DivePictureModel::updateDivePictureOffset(const QString &filename, int offsetSeconds)
+void DivePictureModel::updateDivePictureOffset(int diveId, const QString &filename, int offsetSeconds)
{
- int i = findPictureId(filename);
- if (i >= 0) {
- pictures[i].offsetSeconds = offsetSeconds;
- emit dataChanged(createIndex(i, 0), createIndex(i, 1));
+ // Find the pictures of the given dive.
+ auto from = std::find_if(pictures.begin(), pictures.end(), [diveId](const PictureEntry &e) { return e.diveId == diveId; });
+ auto to = std::find_if(from, pictures.end(), [diveId](const PictureEntry &e) { return e.diveId != diveId; });
+
+ // Find picture with the given filename
+ auto oldPos = std::find_if(from, to, [filename](const PictureEntry &e) { return e.filename == filename; });
+ if (oldPos == to)
+ return;
+
+ // Find new position
+ auto newPos = std::find_if(from, to, [offsetSeconds](const PictureEntry &e) { return e.offsetSeconds > offsetSeconds; });
+
+ // Update the offset here and in the backend
+ oldPos->offsetSeconds = offsetSeconds;
+ if (struct dive *dive = get_dive_by_uniq_id(diveId)) {
+ FOR_EACH_PICTURE(dive) {
+ if (picture->filename == filename) {
+ picture->offset.seconds = offsetSeconds;
+ mark_divelist_changed(true);
+ break;
+ }
+ }
+ copy_dive(current_dive, &displayed_dive);
}
+
+ // Henceforth we will work with indices instead of iterators
+ int oldIndex = oldPos - pictures.begin();
+ int newIndex = newPos - pictures.begin();
+ if (oldIndex == newIndex || oldIndex + 1 == newIndex)
+ return;
+ beginMoveRows(QModelIndex(), oldIndex, oldIndex, QModelIndex(), newIndex);
+ moveInVector(pictures, oldIndex, oldIndex + 1, newIndex);
+ endMoveRows();
}
diff --git a/qt-models/divepicturemodel.h b/qt-models/divepicturemodel.h
index 427ab0158..6dc633fb2 100644
--- a/qt-models/divepicturemodel.h
+++ b/qt-models/divepicturemodel.h
@@ -7,6 +7,7 @@
#include <QFuture>
struct PictureEntry {
+ int diveId;
struct picture *picture;
QString filename;
QImage image;
@@ -22,7 +23,7 @@ public:
virtual int rowCount(const QModelIndex &parent = QModelIndex()) const;
virtual void updateDivePictures();
void removePictures(const QVector<QString> &fileUrls);
- void updateDivePictureOffset(const QString &filename, int offsetSeconds);
+ void updateDivePictureOffset(int diveId, const QString &filename, int offsetSeconds);
signals:
void picturesRemoved(const QVector<QString> &fileUrls);
public slots:
diff --git a/qt-models/diveplannermodel.cpp b/qt-models/diveplannermodel.cpp
index 435571e46..52c87071e 100644
--- a/qt-models/diveplannermodel.cpp
+++ b/qt-models/diveplannermodel.cpp
@@ -141,6 +141,7 @@ void DivePlannerPointsModel::loadFromDive(dive *d)
if (!hasMarkedSamples && !dc->last_manual_time.seconds)
addStop(0, d->dc.duration.seconds,cylinderid, last_sp.mbar, true, current_divemode);
recalc = oldRec;
+ DiveTypeSelectionModel::instance()->repopulate();
emitDataChanged();
}