diff options
-rw-r--r-- | desktop-widgets/maintab.cpp | 25 | ||||
-rw-r--r-- | desktop-widgets/maintab.h | 1 |
2 files changed, 23 insertions, 3 deletions
diff --git a/desktop-widgets/maintab.cpp b/desktop-widgets/maintab.cpp index 7642213e1..42bc29c8d 100644 --- a/desktop-widgets/maintab.cpp +++ b/desktop-widgets/maintab.cpp @@ -1556,12 +1556,31 @@ void MainTab::photoDoubleClicked(const QString filePath) void MainTab::removeSelectedPhotos() { + bool last = false; if (!ui.photosView->selectionModel()->hasSelection()) return; + QModelIndexList indexes = ui.photosView->selectionModel()->selectedRows(); + if (indexes.count() == 0) + indexes = ui.photosView->selectionModel()->selectedIndexes(); + QModelIndex photo = indexes.first(); + do { + photo = indexes.first(); + last = indexes.count() == 1; + if (photo.isValid()) { + QString fileUrl = photo.data(Qt::DisplayPropertyRole).toString(); + if (fileUrl.length() > 0) + DivePictureModel::instance()->removePicture(fileUrl, last); + } + indexes.removeFirst(); + } while(!indexes.isEmpty()); +} - QModelIndex photoIndex = ui.photosView->selectionModel()->selectedIndexes().first(); - QString fileUrl = photoIndex.data(Qt::DisplayPropertyRole).toString(); - DivePictureModel::instance()->removePicture(fileUrl); +void MainTab::removeAllPhotos() +{ + if (QMessageBox::warning(this, tr("Deleting Images"), tr("Are you sure you want to delete all images?"), QMessageBox::Cancel | QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Cancel ) { + ui.photosView->selectAll(); + removeSelectedPhotos(); + } } #define SHOW_SELECTIVE(_component) \ diff --git a/desktop-widgets/maintab.h b/desktop-widgets/maintab.h index 7b2bb863b..c3f6649a8 100644 --- a/desktop-widgets/maintab.h +++ b/desktop-widgets/maintab.h @@ -97,6 +97,7 @@ slots: void escDetected(void); void photoDoubleClicked(const QString filePath); void removeSelectedPhotos(); + void removeAllPhotos(); void showLocation(); void enableGeoLookupEdition(); void disableGeoLookupEdition(); |