summaryrefslogtreecommitdiffstats
path: root/qt-mobile/qmlmanager.cpp
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2016-02-29 06:53:26 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2016-02-29 15:42:33 -0800
commitabab031ed2547d3bc9183a6e7c4c090ad0548463 (patch)
treea55139035a68ec802bc3fbab2924944af5aa50d3 /qt-mobile/qmlmanager.cpp
parente39e9eee3ba1a8192c2a643b0ecafc5e139c39f8 (diff)
downloadsubsurface-abab031ed2547d3bc9183a6e7c4c090ad0548463.tar.gz
QML UI: implement undelete
This code is very similar to the undo code in the desktop UI, but untangling that from the desktop seemed massive overkill; we don't have lists of dives to delete and undelete here - so this is actually much simpler and easier to maintain (I hope). Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-mobile/qmlmanager.cpp')
-rw-r--r--qt-mobile/qmlmanager.cpp54
1 files changed, 53 insertions, 1 deletions
diff --git a/qt-mobile/qmlmanager.cpp b/qt-mobile/qmlmanager.cpp
index b50b3c501..9a0a97f65 100644
--- a/qt-mobile/qmlmanager.cpp
+++ b/qt-mobile/qmlmanager.cpp
@@ -43,7 +43,9 @@ extern "C" int gitProgressCB(int percent)
QMLManager::QMLManager() : m_locationServiceEnabled(false),
m_verboseEnabled(false),
m_credentialStatus(UNKNOWN),
- reply(0)
+ reply(0),
+ deletedDive(0),
+ deletedTrip(0)
{
m_instance = this;
appendTextToLog(getUserAgent());
@@ -610,6 +612,34 @@ void QMLManager::saveChanges()
mark_divelist_changed(false);
}
+void QMLManager::undoDelete(int id)
+{
+ if (!deletedDive || deletedDive->id != id) {
+ qDebug() << "can't find the deleted dive";
+ return;
+ }
+ if (deletedTrip)
+ insert_trip(&deletedTrip);
+ if (deletedDive->divetrip) {
+ struct dive_trip *trip = deletedDive->divetrip;
+ tripflag_t tripflag = deletedDive->tripflag; // this gets overwritten in add_dive_to_trip()
+ deletedDive->divetrip = NULL;
+ deletedDive->next = NULL;
+ deletedDive->pprev = NULL;
+ add_dive_to_trip(deletedDive, trip);
+ deletedDive->tripflag = tripflag;
+ }
+ record_dive(deletedDive);
+ DiveListModel::instance()->addDive(deletedDive);
+ prefs.cloud_background_sync = false;
+ prefs.git_local_only = true;
+ saveChanges();
+ prefs.cloud_background_sync = true;
+ prefs.git_local_only = false;
+ deletedDive = NULL;
+ deletedTrip = NULL;
+}
+
void QMLManager::deleteDive(int id)
{
struct dive *d = get_dive_by_uniq_id(id);
@@ -617,6 +647,28 @@ void QMLManager::deleteDive(int id)
qDebug() << "oops, trying to delete non-existing dive";
return;
}
+ // clean up (or create) the storage for the deleted dive and trip (if applicable)
+ if (!deletedDive)
+ deletedDive = alloc_dive();
+ else
+ clear_dive(deletedDive);
+ copy_dive(d, deletedDive);
+ if (!deletedTrip) {
+ deletedTrip = (struct dive_trip *)calloc(1, sizeof(struct dive_trip));
+ } else {
+ free(deletedTrip->location);
+ free(deletedTrip->notes);
+ memset(deletedTrip, 0, sizeof(struct dive_trip));
+ }
+ // if this is the last dive in that trip, remember the trip as well
+ if (d->divetrip && d->divetrip->nrdives == 1) {
+ deletedTrip = (struct dive_trip *)calloc(1, sizeof(struct dive_trip));
+ *deletedTrip = *d->divetrip;
+ deletedTrip->location = copy_string(d->divetrip->location);
+ deletedTrip->notes = copy_string(d->divetrip->notes);
+ deletedTrip->nrdives = 0;
+ deletedDive->divetrip = deletedTrip;
+ }
DiveListModel::instance()->removeDiveById(id);
delete_single_dive(get_idx_by_uniq_id(id));
prefs.cloud_background_sync = false;