summaryrefslogtreecommitdiffstats
path: root/qt-ui/models.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'qt-ui/models.cpp')
-rw-r--r--qt-ui/models.cpp41
1 files changed, 36 insertions, 5 deletions
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp
index 199a9c057..04611977f 100644
--- a/qt-ui/models.cpp
+++ b/qt-ui/models.cpp
@@ -2600,15 +2600,14 @@ MultiFilterSortModel *MultiFilterSortModel::instance()
return self;
}
-MultiFilterSortModel::MultiFilterSortModel(QObject *parent) : QSortFilterProxyModel(parent)
+MultiFilterSortModel::MultiFilterSortModel(QObject *parent) : QSortFilterProxyModel(parent), justCleared(false)
{
}
bool MultiFilterSortModel::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const
{
- if (models.isEmpty()) {
+ if (justCleared || models.isEmpty())
return true;
- }
bool shouldShow = true;
Q_FOREACH (MultiFilterInterface *model, models) {
@@ -2616,7 +2615,6 @@ bool MultiFilterSortModel::filterAcceptsRow(int source_row, const QModelIndex &s
shouldShow = false;
}
}
-
return shouldShow;
}
@@ -2627,7 +2625,6 @@ void MultiFilterSortModel::myInvalidate()
DiveListView *dlv = MainWindow::instance()->dive_list();
invalidate();
-
// first make sure the trips are no longer shown as selected
// (but without updating the selection state of the dives... this just cleans
// up an oddity in the filter handling)
@@ -2664,6 +2661,40 @@ void MultiFilterSortModel::removeFilterModel(MultiFilterInterface *model)
disconnect(itemModel, SIGNAL(dataChanged(QModelIndex, QModelIndex)), this, SLOT(myInvalidate()));
}
+void MultiFilterSortModel::clearFilter()
+{
+ justCleared = true;
+ Q_FOREACH(MultiFilterInterface *iface, models){
+ iface->clearFilter();
+ }
+ justCleared = false;
+ myInvalidate();
+}
+
+void BuddyFilterModel::clearFilter()
+{
+ memset(checkState, false, rowCount());
+ checkState[rowCount() - 1] = false;
+ anyChecked = false;
+ emit dataChanged(createIndex(0,0), createIndex(rowCount()-1, 0));
+}
+
+void LocationFilterModel::clearFilter()
+{
+ memset(checkState, false, rowCount());
+ checkState[rowCount() - 1] = false;
+ anyChecked = false;
+ emit dataChanged(createIndex(0,0), createIndex(rowCount()-1, 0));
+}
+
+void TagFilterModel::clearFilter()
+{
+ memset(checkState, false, rowCount());
+ checkState[rowCount() - 1] = false;
+ anyChecked = false;
+ emit dataChanged(createIndex(0,0), createIndex(rowCount()-1, 0));
+}
+
ExtraDataModel::ExtraDataModel(QObject *parent) : CleanerTableModel(parent),
rows(0)
{