diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2019-01-28 21:42:59 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-04-12 18:19:07 +0300 |
commit | 512a2e6b684e237c5e6aacd3cba42fb7d2093e0a (patch) | |
tree | 54b065e2a1f29d99be890df5ed2f916bf2c6ce22 /desktop-widgets/tab-widgets/maintab.cpp | |
parent | f11ac405933f2bc124dcff05ec44dd6860cf712c (diff) | |
download | subsurface-512a2e6b684e237c5e6aacd3cba42fb7d2093e0a.tar.gz |
Undo: implement undo of suit editing
This one was trivially modelled after notes editing. Only difference:
the textChanged() signal was replaced by the editingFinished()
signal so that we're not generating undo-commands on every key-press.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'desktop-widgets/tab-widgets/maintab.cpp')
-rw-r--r-- | desktop-widgets/tab-widgets/maintab.cpp | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/desktop-widgets/tab-widgets/maintab.cpp b/desktop-widgets/tab-widgets/maintab.cpp index 49cf5312c..962cdc645 100644 --- a/desktop-widgets/tab-widgets/maintab.cpp +++ b/desktop-widgets/tab-widgets/maintab.cpp @@ -342,6 +342,9 @@ void MainTab::divesEdited(const QVector<dive *> &, DiveField field) return; switch(field) { + case DiveField::SUIT: + ui.suit->setText(QString(current_dive->suit)); + break; case DiveField::NOTES: updateNotes(current_dive); break; @@ -795,8 +798,6 @@ void MainTab::acceptChanges() struct dive *cd = current_dive; // now check if something has changed and if yes, edit the selected dives that // were identical with the master dive shown (and mark the divelist as changed) - if (!same_string(displayed_dive.suit, cd->suit)) - MODIFY_DIVES(selectedDives, EDIT_TEXT(suit)); if (displayed_dive.rating != cd->rating) MODIFY_DIVES(selectedDives, EDIT_VALUE(rating)); if (displayed_dive.visibility != cd->visibility) @@ -1343,13 +1344,12 @@ void MainTab::on_diveTripLocation_textEdited(const QString& text) } } -void MainTab::on_suit_textChanged(const QString &text) +void MainTab::on_suit_editingFinished() { - if (editMode == IGNORE || acceptingEdit == true) + if (editMode == IGNORE || acceptingEdit == true || !current_dive) return; - free(displayed_dive.suit); - displayed_dive.suit = copy_qstring(text); - markChangedWidget(ui.suit); + + Command::editSuit(getSelectedDivesCurrentLast(), ui.suit->text(), QString(current_dive->suit)); } void MainTab::on_notes_textChanged() |