diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2019-03-03 17:10:09 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-04-12 18:19:07 +0300 |
commit | a2be015a43b9d0de710539ee3838bb3aafe6bb2c (patch) | |
tree | 3ea895a1ad0a7ddb167342d79c364177b99f124e /desktop-widgets/tab-widgets | |
parent | 2134d99d0c98603fa5182fe1946bc330e44ad9ed (diff) | |
download | subsurface-a2be015a43b9d0de710539ee3838bb3aafe6bb2c.tar.gz |
Undo: consider dive site in AddDive()
If a dive site was added for a new dive, remove it on undo.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'desktop-widgets/tab-widgets')
-rw-r--r-- | desktop-widgets/tab-widgets/maintab.cpp | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/desktop-widgets/tab-widgets/maintab.cpp b/desktop-widgets/tab-widgets/maintab.cpp index edabd41fe..18d424437 100644 --- a/desktop-widgets/tab-widgets/maintab.cpp +++ b/desktop-widgets/tab-widgets/maintab.cpp @@ -712,11 +712,19 @@ void MainTab::acceptChanges() hideMessage(); ui.equipmentTab->setEnabled(true); if (editMode == ADD) { - // make sure that the dive site is handled as well - updateDiveSite(ui.location->currDiveSite(), &displayed_dive); + // Handle dive site + struct dive_site *pickedDs = ui.location->currDiveSite(); + QString newDiveSiteName; + if (pickedDs == RECENTLY_ADDED_DIVESITE) { + newDiveSiteName = ui.location->text(); + displayed_dive.dive_site = nullptr; + } else { + displayed_dive.dive_site = pickedDs; + } + copyTagsToDisplayedDive(); - Command::addDive(&displayed_dive, autogroup, true); + Command::addDive(&displayed_dive, newDiveSiteName, autogroup, true); editMode = NONE; MainWindow::instance()->exitEditState(); |