summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/divefilter.cpp49
-rw-r--r--core/divefilter.h20
2 files changed, 66 insertions, 3 deletions
diff --git a/core/divefilter.cpp b/core/divefilter.cpp
index 2aec89dc5..31ab08ba2 100644
--- a/core/divefilter.cpp
+++ b/core/divefilter.cpp
@@ -15,28 +15,73 @@ static void updateDiveStatus(dive *d, bool newStatus, ShownChange &change)
#ifdef SUBSURFACE_MOBILE
+DiveFilter *DiveFilter::instance()
+{
+ static DiveFilter self;
+ return &self;
+}
+
DiveFilter::DiveFilter()
{
}
-ShownChange DiveFilter::update(const QVector<dive *> &) const
+ShownChange DiveFilter::update(const QVector<dive *> &dives) const
{
+ dive *old_current = current_dive;
+
ShownChange res;
+ switch (filterData.mode) {
+ default:
+ case FilterData::Mode::NONE:
+ for (dive *d: dives)
+ updateDiveStatus(d, true, res);
+ break;
+ case FilterData::Mode::FULLTEXT:
+ for (dive *d: dives)
+ updateDiveStatus(d, fulltext_dive_matches(d, filterData.fullText, StringFilterMode::STARTSWITH), res);
+ break;
+ }
+
+ res.currentChanged = old_current != current_dive;
return res;
}
ShownChange DiveFilter::updateAll() const
{
+ dive *old_current = current_dive;
+
ShownChange res;
+ int i;
+ dive *d;
+ switch (filterData.mode) {
+ default:
+ case FilterData::Mode::NONE:
+ for_each_dive(i, d)
+ updateDiveStatus(d, true, res);
+ break;
+ case FilterData::Mode::FULLTEXT: {
+ FullTextResult ft = fulltext_find_dives(filterData.fullText, StringFilterMode::STARTSWITH);
+ for_each_dive(i, d)
+ updateDiveStatus(d, ft.dive_matches(d), res);
+ break;
+ }
+ }
+
+ res.currentChanged = old_current != current_dive;
return res;
}
+void DiveFilter::setFilter(const FilterData &data)
+{
+ filterData = data;
+ //emit diveListNotifier.filterReset(); // Not yet using common models
+}
+
#else // SUBSURFACE_MOBILE
#include "desktop-widgets/mapwidget.h"
#include "desktop-widgets/mainwindow.h"
#include "desktop-widgets/divelistview.h"
-#include "core/fulltext.h"
#include "core/qthelper.h"
#include "core/trip.h"
#include "core/divesite.h"
diff --git a/core/divefilter.h b/core/divefilter.h
index ca17e3741..05add693e 100644
--- a/core/divefilter.h
+++ b/core/divefilter.h
@@ -4,6 +4,8 @@
#define DIVE_FILTER_H
#include <QVector>
+#include "fulltext.h"
+
struct dive;
// Structure describing changes of shown status upon applying the filter
@@ -18,19 +20,35 @@ struct ShownChange {
// This should be unified in the future.
#ifdef SUBSURFACE_MOBILE
+struct FilterData {
+ // On mobile, we support searching fulltext (all fields), people (buddies and divemasters) and tags
+ enum class Mode {
+ NONE = 0,
+ FULLTEXT = 1,
+ PEOPLE = 2,
+ TAGS = 3
+ };
+
+ Mode mode = Mode::NONE;
+ FullTextQuery fullText; // For fulltext
+ QString text; // For people and tags
+};
+
class DiveFilter {
public:
static DiveFilter *instance();
ShownChange update(const QVector<dive *> &dives) const; // Update filter status of given dives and return dives whose status changed
ShownChange updateAll() const; // Update filter status of all dives and return dives whose status changed
+ void setFilter(const FilterData &data);
private:
DiveFilter();
+
+ FilterData filterData;
};
#else
-#include "fulltext.h"
#include <QDateTime>
#include <QStringList>