summaryrefslogtreecommitdiffstats
path: root/profile-widget/profilewidget2.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'profile-widget/profilewidget2.cpp')
-rw-r--r--profile-widget/profilewidget2.cpp44
1 files changed, 19 insertions, 25 deletions
diff --git a/profile-widget/profilewidget2.cpp b/profile-widget/profilewidget2.cpp
index 5cc5a3a18..11dddaa41 100644
--- a/profile-widget/profilewidget2.cpp
+++ b/profile-widget/profilewidget2.cpp
@@ -2202,8 +2202,17 @@ void ProfileWidget2::dropEvent(QDropEvent *event)
QDataStream dataStream(&itemData, QIODevice::ReadOnly);
QString filename;
- QPoint pos;
- dataStream >> filename >> pos;
+ int diveId;
+ dataStream >> filename >> diveId;
+
+ // If the id of the drag & dropped picture belongs to a different dive, then
+ // the offset we determine makes no sense what so ever. Simply ignore such an event.
+ // In the future, we might think about duplicating the picture or moving the picture
+ // from one dive to the other.
+ if (!current_dive || displayed_dive.id != diveId) {
+ event->ignore();
+ return;
+ }
#ifndef SUBSURFACE_MOBILE
// Calculate time in dive where picture was dropped and whether the new position is during the dive.
@@ -2211,19 +2220,15 @@ void ProfileWidget2::dropEvent(QDropEvent *event)
offset_t offset { (int32_t)lrint(timeAxis->valueAt(mappedPos)) };
bool duringDive = current_dive && offset.seconds > 0 && offset.seconds < current_dive->duration.seconds;
- // Flag which states whether the drag&dropped picture actually belongs to this dive.
- // If this is not the case, the calculated offset makes no sense whatsoever and we must ignore the event.
- bool belongsToDive = true;
-
// A picture was drag&dropped onto the profile: We have four cases to consider:
// 1a) The image was already shown on the profile and is moved to a different position on the profile.
// Calculate the new position and move the picture.
// 1b) The image was on the profile and is moved outside of the dive time.
// Remove the picture.
- // 2a) The image was not on the profile, but belongs to the current dive.
- // Add the picture to the profile if it is during the dive.
- // 2b) The picture does not belong to the current dive.
- // For now, do nothing. We may think about adding the picture to the dive.
+ // 2a) The image was not on the profile and is moved into the dive time.
+ // Add the picture to the profile.
+ // 2b) The image was not on the profile and is moved outside of the dive time.
+ // Do nothing.
auto oldPos = std::find_if(pictures.begin(), pictures.end(), [filename](const PictureEntry &e)
{ return e.filename == filename; });
if (oldPos != pictures.end()) {
@@ -2250,16 +2255,9 @@ void ProfileWidget2::dropEvent(QDropEvent *event)
// In both cases the picture list changed, therefore we must recalculate the y-coordinatesA.
calculatePictureYPositions();
} else {
- // Cases 2a) and 2b): picture not on profile. Check if it belongs to current dive.
- // Note that FOR_EACH_PICTURE handles current_dive being null gracefully.
- bool found = false;
- FOR_EACH_PICTURE(current_dive) {
- if (picture->filename == filename) {
- found = true;
- break;
- }
- }
- if (found && duringDive) {
+ // Cases 2a) and 2b): picture not on profile. We only have to take action for
+ // the first case: picture is moved into dive-time.
+ if (duringDive) {
// Case 2a): add the picture at the appropriate position.
// The case move from outside-to-outside of the profile plot was handled by
// the "&& duringDive" condition in the if above.
@@ -2273,15 +2271,11 @@ void ProfileWidget2::dropEvent(QDropEvent *event)
newPos = pictures.emplace(newPos, offset, filename, scene());
updateThumbnailXPos(*newPos);
calculatePictureYPositions();
- } else if (!found) {
- // Case 2b): Unknown picture. Ignore.
- belongsToDive = false;
}
}
// Only signal the drag&drop action if the picture actually belongs to the dive.
- if (belongsToDive)
- DivePictureModel::instance()->updateDivePictureOffset(displayed_dive.id, filename, offset.seconds);
+ DivePictureModel::instance()->updateDivePictureOffset(displayed_dive.id, filename, offset.seconds);
#endif
if (event->source() == this) {