diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2013-11-15 14:11:55 +0900 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-11-15 14:21:20 +0900 |
commit | 6bf12bde03c4d21a319fe1d2d63c7f6b010b4992 (patch) | |
tree | 71e0281fb44408276669d13df2124bbbd6662054 | |
parent | 7e859da939447031ea667bc3b293175dc842d297 (diff) | |
download | subsurface-6bf12bde03c4d21a319fe1d2d63c7f6b010b4992.tar.gz |
Make more context menu functions act on all selected dives
Remove from trip and delete both should deal with all selected dives.
Fixes #247
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | qt-ui/divelistview.cpp | 54 |
1 files changed, 32 insertions, 22 deletions
diff --git a/qt-ui/divelistview.cpp b/qt-ui/divelistview.cpp index ec8cac044..e750e72aa 100644 --- a/qt-ui/divelistview.cpp +++ b/qt-ui/divelistview.cpp @@ -452,10 +452,15 @@ void DiveListView::mergeTripBelow() void DiveListView::removeFromTrip() { + int i; struct dive *d = (struct dive *) contextMenuIndex.data(DiveTripModel::DIVE_ROLE).value<void*>(); if (!d) // shouldn't happen as we only are setting up this action if this is a dive return; - remove_dive_from_trip(d); + for_each_dive(i, d) { + if (d->selected) + remove_dive_from_trip(d); + } + mark_divelist_changed(TRUE); reload(currentLayout, false); } @@ -468,12 +473,9 @@ void DiveListView::newTripAbove() return; rememberSelection(); trip = create_and_hookup_trip_from_dive(d); - if (d->selected) { - for_each_dive(idx, d) { - if (!d->selected) - continue; + for_each_dive(idx, d) { + if (d->selected) add_dive_to_trip(d, trip); - } } trip->expanded = 1; mark_divelist_changed(TRUE); @@ -483,19 +485,27 @@ void DiveListView::newTripAbove() void DiveListView::deleteDive() { - int nr; + int i, nr; struct dive *d = (struct dive *) contextMenuIndex.data(DiveTripModel::DIVE_ROLE).value<void*>(); - if (d) { - nr = get_divenr(d); - delete_single_dive(get_index_for_dive(d)); - if (amount_selected == 0) { - if (nr > 0) - select_dive(nr - 1); - else - mainWindow()->cleanUpEmpty(); - } - mark_divelist_changed(TRUE); + if (!d) + return; + // after a dive is deleted the ones following it move forward in the dive_table + // so instead of using the for_each_dive macro I'm using an explicit for loop + // to make this easier to understand + for (i = 0; i < dive_table.nr; i++) { + d = get_dive(i); + if (!d->selected) + continue; + delete_single_dive(i); + i--; // so the next dive isn't skipped... it's now #i } + if (amount_selected == 0) { + if (i > 0) + select_dive(nr - 1); + else + mainWindow()->cleanUpEmpty(); + } + mark_divelist_changed(TRUE); mainWindow()->refreshDisplay(); reload(currentLayout, false); } @@ -528,16 +538,16 @@ void DiveListView::contextMenuEvent(QContextMenuEvent *event) popup.addAction(tr("collapse all"), this, SLOT(collapseAll())); collapseAction = popup.addAction(tr("collapse"), this, SLOT(collapseAll())); if (d) { - popup.addAction(tr("Remove dive from trip"), this, SLOT(removeFromTrip())); - popup.addAction(tr("Create new trip above"), this, SLOT(newTripAbove())); + popup.addAction(tr("remove dive(s) from trip"), this, SLOT(removeFromTrip())); + popup.addAction(tr("create new trip above"), this, SLOT(newTripAbove())); } if (trip) { - popup.addAction(tr("Merge trip with trip above"), this, SLOT(mergeTripAbove())); - popup.addAction(tr("Merge trip with trip below"), this, SLOT(mergeTripBelow())); + popup.addAction(tr("merge trip with trip above"), this, SLOT(mergeTripAbove())); + popup.addAction(tr("merge trip with trip below"), this, SLOT(mergeTripBelow())); } } if (d) - popup.addAction(tr("delete dive"), this, SLOT(deleteDive())); + popup.addAction(tr("delete dive(s)"), this, SLOT(deleteDive())); if (amount_selected > 1 && consecutive_selected()) popup.addAction(tr("merge selected dives"), this, SLOT(mergeDives())); if (amount_selected >= 1) { |