summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--desktop-widgets/mainwindow.cpp3
-rw-r--r--qt-models/filtermodels.cpp61
-rw-r--r--qt-models/filtermodels.h14
3 files changed, 53 insertions, 25 deletions
diff --git a/desktop-widgets/mainwindow.cpp b/desktop-widgets/mainwindow.cpp
index f685a2b74..b0817b9f1 100644
--- a/desktop-widgets/mainwindow.cpp
+++ b/desktop-widgets/mainwindow.cpp
@@ -445,7 +445,7 @@ MainWindow *MainWindow::instance()
return m_Instance;
}
-// this gets called after we download dives from a divecomputer
+// This gets called after one or more dives were added, edited or downloaded for a dive computer
void MainWindow::refreshDisplay(bool doRecreateDiveList)
{
information()->reload();
@@ -469,6 +469,7 @@ void MainWindow::recreateDiveList()
BuddyFilterModel::instance()->repopulate();
LocationFilterModel::instance()->repopulate();
SuitsFilterModel::instance()->repopulate();
+ MultiFilterSortModel::instance()->myInvalidate();
}
void MainWindow::configureToolbar() {
diff --git a/qt-models/filtermodels.cpp b/qt-models/filtermodels.cpp
index 684999fbd..217d456bf 100644
--- a/qt-models/filtermodels.cpp
+++ b/qt-models/filtermodels.cpp
@@ -78,7 +78,40 @@ CREATE_COMMON_METHODS_FOR_FILTER(SuitsFilterModel, count_dives_with_suit)
CREATE_INSTANCE_METHOD(MultiFilterSortModel)
-SuitsFilterModel::SuitsFilterModel(QObject *parent) : QStringListModel(parent)
+FilterModelBase::FilterModelBase(QObject *parent) : QStringListModel(parent)
+{
+}
+
+// Update the stringList and the checkState array.
+// The last item is supposed to be the "Show Empty Tags" entry.
+void FilterModelBase::updateList(const QStringList &newList)
+{
+ // Keep copy of old checkState array to reimport them later.
+ std::vector<char> oldCheckState = checkState;
+ checkState.resize(newList.count());
+ std::fill(checkState.begin(), checkState.end(), false);
+ anyChecked = false;
+
+ // Ignore last item, since this is the "Show Empty Tags" entry.
+ for (int i = 0; i < rowCount() - 1; i++) {
+ if (oldCheckState[i]) {
+ int ind = newList.indexOf(stringList()[i]);
+ if (ind >= 0 && ind < newList.count() - 1) {
+ checkState[ind] = true;
+ anyChecked = true;
+ }
+ }
+ }
+
+ // On program startup, the old list is empty.
+ if (rowCount() > 0 && oldCheckState.back()) {
+ checkState.back() = true;
+ anyChecked = true;
+ }
+ setStringList(newList);
+}
+
+SuitsFilterModel::SuitsFilterModel(QObject *parent) : FilterModelBase(parent)
{
}
@@ -127,13 +160,10 @@ void SuitsFilterModel::repopulate()
}
qSort(list);
list << tr("No suit set");
- setStringList(list);
- checkState.resize(list.count());
- std::fill(checkState.begin(), checkState.end(), false);
- anyChecked = false;
+ updateList(list);
}
-TagFilterModel::TagFilterModel(QObject *parent) : QStringListModel(parent)
+TagFilterModel::TagFilterModel(QObject *parent) : FilterModelBase(parent)
{
}
@@ -150,10 +180,7 @@ void TagFilterModel::repopulate()
}
qSort(list);
list << tr("Empty tags");
- setStringList(list);
- checkState.resize(list.count());
- std::fill(checkState.begin(), checkState.end(), false);
- anyChecked = false;
+ updateList(list);
}
bool TagFilterModel::doFilter(dive *d, QModelIndex &index0, QAbstractItemModel *sourceModel) const
@@ -190,7 +217,7 @@ bool TagFilterModel::doFilter(dive *d, QModelIndex &index0, QAbstractItemModel *
return false;
}
-BuddyFilterModel::BuddyFilterModel(QObject *parent) : QStringListModel(parent)
+BuddyFilterModel::BuddyFilterModel(QObject *parent) : FilterModelBase(parent)
{
}
@@ -243,13 +270,10 @@ void BuddyFilterModel::repopulate()
}
qSort(list);
list << tr("No buddies");
- setStringList(list);
- checkState.resize(list.count());
- std::fill(checkState.begin(), checkState.end(), false);
- anyChecked = false;
+ updateList(list);
}
-LocationFilterModel::LocationFilterModel(QObject *parent) : QStringListModel(parent)
+LocationFilterModel::LocationFilterModel(QObject *parent) : FilterModelBase(parent)
{
}
@@ -294,10 +318,7 @@ void LocationFilterModel::repopulate()
}
qSort(list);
list << tr("No location set");
- setStringList(list);
- checkState.resize(list.count());
- std::fill(checkState.begin(), checkState.end(), false);
- anyChecked = false;
+ updateList(list);
}
MultiFilterSortModel::MultiFilterSortModel(QObject *parent) :
diff --git a/qt-models/filtermodels.h b/qt-models/filtermodels.h
index cda6e2369..3060f7cf3 100644
--- a/qt-models/filtermodels.h
+++ b/qt-models/filtermodels.h
@@ -16,7 +16,13 @@ public:
bool anyChecked;
};
-class TagFilterModel : public QStringListModel, public MultiFilterInterface {
+class FilterModelBase : public QStringListModel, public MultiFilterInterface {
+protected:
+ explicit FilterModelBase(QObject *parent = 0);
+ void updateList(const QStringList &new_list);
+};
+
+class TagFilterModel : public FilterModelBase {
Q_OBJECT
public:
static TagFilterModel *instance();
@@ -33,7 +39,7 @@ private:
explicit TagFilterModel(QObject *parent = 0);
};
-class BuddyFilterModel : public QStringListModel, public MultiFilterInterface {
+class BuddyFilterModel : public FilterModelBase {
Q_OBJECT
public:
static BuddyFilterModel *instance();
@@ -50,7 +56,7 @@ private:
explicit BuddyFilterModel(QObject *parent = 0);
};
-class LocationFilterModel : public QStringListModel, public MultiFilterInterface {
+class LocationFilterModel : public FilterModelBase {
Q_OBJECT
public:
static LocationFilterModel *instance();
@@ -67,7 +73,7 @@ private:
explicit LocationFilterModel(QObject *parent = 0);
};
-class SuitsFilterModel : public QStringListModel, public MultiFilterInterface {
+class SuitsFilterModel : public FilterModelBase {
Q_OBJECT
public:
static SuitsFilterModel *instance();