From afde4dce0dc89e4ac7edbbffd5dd68a9ce96c5f1 Mon Sep 17 00:00:00 2001 From: Berthold Stoeger Date: Fri, 12 Apr 2019 15:47:41 +0200 Subject: [PATCH] Filter: allow filtering multiple dive sites In the edit-dive-site tab the filter is switched to a particular mode where only dives at that site are shown. If we want to reuse this for the dive-site tab the mode has to be extended to allow for multiple dive sites. This is trivially done by replacing a pointer by a vector of pointers. Signed-off-by: Berthold Stoeger --- desktop-widgets/locationinformation.cpp | 4 ++-- qt-models/filtermodels.cpp | 19 +++++++++---------- qt-models/filtermodels.h | 7 ++++--- 3 files changed, 15 insertions(+), 15 deletions(-) diff --git a/desktop-widgets/locationinformation.cpp b/desktop-widgets/locationinformation.cpp index e5e14fadb..d935c4145 100644 --- a/desktop-widgets/locationinformation.cpp +++ b/desktop-widgets/locationinformation.cpp @@ -184,7 +184,7 @@ void LocationInformationWidget::acceptChanges() MainWindow::instance()->setApplicationState("Default"); MapWidget::instance()->endGetDiveCoordinates(); MapWidget::instance()->repopulateLabels(); - MultiFilterSortModel::instance()->stopFilterDiveSite(); + MultiFilterSortModel::instance()->stopFilterDiveSites(); } void LocationInformationWidget::initFields(dive_site *ds) @@ -195,7 +195,7 @@ void LocationInformationWidget::initFields(dive_site *ds) updateLabels(); enableLocationButtons(dive_site_has_gps_location(ds)); QSortFilterProxyModel *m = qobject_cast(ui.diveSiteListView->model()); - MultiFilterSortModel::instance()->startFilterDiveSite(ds); + MultiFilterSortModel::instance()->startFilterDiveSites(QVector{ ds }); if (m) m->invalidate(); } else { diff --git a/qt-models/filtermodels.cpp b/qt-models/filtermodels.cpp index 94b74d92d..bc454bcc9 100644 --- a/qt-models/filtermodels.cpp +++ b/qt-models/filtermodels.cpp @@ -105,8 +105,7 @@ MultiFilterSortModel *MultiFilterSortModel::instance() } MultiFilterSortModel::MultiFilterSortModel(QObject *parent) : QSortFilterProxyModel(parent), - divesDisplayed(0), - curr_dive_site(NULL) + divesDisplayed(0) { setFilterKeyColumn(-1); // filter all columns setFilterCaseSensitivity(Qt::CaseInsensitive); @@ -125,9 +124,9 @@ void MultiFilterSortModel::resetModel(DiveTripModelBase::Layout layout) bool MultiFilterSortModel::showDive(const struct dive *d) const { - // If curr_dive_site is set, we are in a special dive-site editing mode. - if (curr_dive_site) - return d->dive_site == curr_dive_site; + // If dive_sites is not empty, we are in a special dive-site filtering mode. + if (!dive_sites.isEmpty()) + return dive_sites.contains(d->dive_site); if (!filterData.validFilter) return true; @@ -245,7 +244,7 @@ void MultiFilterSortModel::myInvalidate() emit filterFinished(); #if !defined(SUBSURFACE_MOBILE) - if (curr_dive_site) + if (!dive_sites.isEmpty()) MainWindow::instance()->diveList->expandAll(); #endif } @@ -267,15 +266,15 @@ void MultiFilterSortModel::clearFilter() myInvalidate(); } -void MultiFilterSortModel::startFilterDiveSite(struct dive_site *ds) +void MultiFilterSortModel::startFilterDiveSites(QVector ds) { - curr_dive_site = ds; + dive_sites = ds; myInvalidate(); } -void MultiFilterSortModel::stopFilterDiveSite() +void MultiFilterSortModel::stopFilterDiveSites() { - curr_dive_site = NULL; + dive_sites.clear(); myInvalidate(); } diff --git a/qt-models/filtermodels.h b/qt-models/filtermodels.h index 45e1e7189..258b4186b 100644 --- a/qt-models/filtermodels.h +++ b/qt-models/filtermodels.h @@ -67,8 +67,8 @@ public slots: void myInvalidate(); void clearFilter(); - void startFilterDiveSite(struct dive_site *ds); - void stopFilterDiveSite(); + void startFilterDiveSites(QVector ds); + void stopFilterDiveSites(); void filterChanged(const QModelIndex &from, const QModelIndex &to, const QVector &roles); void resetModel(DiveTripModelBase::Layout layout); void filterDataChanged(const FilterData &data); @@ -80,7 +80,8 @@ signals: private: MultiFilterSortModel(QObject *parent = 0); - struct dive_site *curr_dive_site; + // Dive site filtering has priority over other filters + QVector dive_sites; void countsChanged(); FilterData filterData; };