summaryrefslogtreecommitdiffstats
path: root/qt-ui/maintab.cpp
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2014-07-06 12:36:25 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-07-06 12:50:30 -0700
commitcd5b2a372f70198823a7ca82a51fa38a977f1a80 (patch)
treeeaa8461ae3efa9c7056e89652411e4373854bd93 /qt-ui/maintab.cpp
parentd97c49ba39833275cf15a2753cb084efdfd5c923 (diff)
downloadsubsurface-cd5b2a372f70198823a7ca82a51fa38a977f1a80.tar.gz
UI restructure: cleanup the code when canceling an edit
This was way too complicated because we used to edit a "live" dive that was on the dive list. All we really need to do is systematically make sure that all the widgets are in the correct state. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/maintab.cpp')
-rw-r--r--qt-ui/maintab.cpp67
1 files changed, 14 insertions, 53 deletions
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp
index 0f8d885a8..5dd5a53f4 100644
--- a/qt-ui/maintab.cpp
+++ b/qt-ui/maintab.cpp
@@ -839,64 +839,25 @@ void MainTab::rejectChanges()
editMode = NONE;
tabBar()->setTabIcon(0, QIcon()); // Notes
tabBar()->setTabIcon(1, QIcon()); // Equipment
-
- if (MainWindow::instance() && MainWindow::instance()->dive_list()->selectedTrips().count() != 1) {
- if (lastMode == ADD) {
- // clean up
- DivePlannerPointsModel::instance()->cancelPlan();
- hideMessage();
- resetPallete();
- return;
- } else if (lastMode == MANUALLY_ADDED_DIVE) {
- // when we tried to edit a manually added dive, we destroyed
- // the dive we edited, so let's just restore it from backup
- DivePlannerPointsModel::instance()->restoreBackupDive();
- }
- if (selected_dive >= 0) {
- copy_dive(current_dive, &displayed_dive);
- cylindersModel->updateDive();
- weightModel->updateDive();
- } else {
- cylindersModel->clear();
- weightModel->clear();
- setEnabled(false);
- }
- }
-#if 0 // this makes no sense anymore - but let's make sure I think this through
- // now let's avoid memory leaks
- if (MainWindow::instance() && MainWindow::instance()->dive_list()->selectedTrips().count() == 1) {
- if (displayed_dive.location != current_dive->divetrip->location)
- free(displayed_dive.location);
- if (displayed_dive.notes != current_dive->divetrip->notes)
- free(displayed_dive.notes);
- } else {
- struct dive *cd = current_dive;
- FREE_IF_DIFFERENT(tag_list);
- FREE_IF_DIFFERENT(location);
- FREE_IF_DIFFERENT(buddy);
- FREE_IF_DIFFERENT(divemaster);
- FREE_IF_DIFFERENT(notes);
- FREE_IF_DIFFERENT(suit);
- }
-#endif
hideMessage();
- MainWindow::instance()->dive_list()->setEnabled(true);
- ui.dateEdit->setEnabled(true);
resetPallete();
- MainWindow::instance()->globe()->reload();
- if (lastMode == MANUALLY_ADDED_DIVE) {
- // more clean up
- updateDiveInfo();
- MainWindow::instance()->showProfile();
- // we already reloaded the divelist above, so don't recreate it or we'll lose the selection
- MainWindow::instance()->refreshDisplay(false);
- }
- MainWindow::instance()->dive_list()->setFocus();
+ // no harm done to call cancelPlan even if we were not in ADD or PLAN mode...
+ DivePlannerPointsModel::instance()->cancelPlan();
+
+ // now make sure that the correct dive is displayed
+ if (selected_dive >= 0)
+ copy_dive(current_dive, &displayed_dive);
+ else
+ clear_dive(&displayed_dive);
+ updateDiveInfo(selected_dive < 0);
// the user could have edited the location and then canceled the edit
// let's get the correct location back in view
MainWindow::instance()->globe()->centerOnCurrentDive();
- DivePlannerPointsModel::instance()->setPlanMode(DivePlannerPointsModel::NOTHING);
- updateDiveInfo();
+ MainWindow::instance()->globe()->reload();
+ // show the profile and dive info
+ MainWindow::instance()->graphics()->replot();
+ cylindersModel->updateDive();
+ weightModel->updateDive();
}
#undef EDIT_TEXT2