diff options
-rw-r--r-- | qt-ui/models.cpp | 17 | ||||
-rw-r--r-- | qt-ui/models.h | 1 |
2 files changed, 16 insertions, 2 deletions
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp index 1d28373e1..2cdea6851 100644 --- a/qt-ui/models.cpp +++ b/qt-ui/models.cpp @@ -2171,14 +2171,22 @@ void TagFilterModel::repopulate() setStringList(list); delete[] checkState; checkState = new bool[list.count()]; - memset(checkState, true, list.count()); - checkState[list.count() - 1] = true; + memset(checkState, false, list.count()); + checkState[list.count() - 1] = false; + anyChecked = false; } bool TagFilterModel::setData(const QModelIndex &index, const QVariant &value, int role) { if (role == Qt::CheckStateRole) { checkState[index.row()] = value.toBool(); + anyChecked = false; + for (int i = 0; i < rowCount(); i++) { + if (checkState[i] == true) { + anyChecked = true; + break; + } + } dataChanged(index, index); return true; } @@ -2192,6 +2200,11 @@ TagFilterSortModel::TagFilterSortModel(QObject *parent) : QSortFilterProxyModel( bool TagFilterSortModel::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const { + // If there's nothing checked, this should show everythin. + if (!TagFilterModel::instance()->anyChecked) { + return true; + } + QModelIndex index0 = sourceModel()->index(source_row, 0, source_parent); QVariant diveVariant = sourceModel()->data(index0, DiveTripModel::DIVE_ROLE); struct dive *d = (struct dive *)diveVariant.value<void *>(); diff --git a/qt-ui/models.h b/qt-ui/models.h index fc762b6ad..18c26df44 100644 --- a/qt-ui/models.h +++ b/qt-ui/models.h @@ -425,6 +425,7 @@ public: virtual bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole); virtual Qt::ItemFlags flags(const QModelIndex &index) const; bool *checkState; + bool anyChecked; public slots: void repopulate(); |