summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/mainwindow.cpp1
-rw-r--r--qt-ui/models.cpp51
-rw-r--r--qt-ui/models.h14
-rw-r--r--qt-ui/simplewidgets.cpp5
4 files changed, 71 insertions, 0 deletions
diff --git a/qt-ui/mainwindow.cpp b/qt-ui/mainwindow.cpp
index 8cdf6de88..ec5fbd00f 100644
--- a/qt-ui/mainwindow.cpp
+++ b/qt-ui/mainwindow.cpp
@@ -181,6 +181,7 @@ void MainWindow::refreshDisplay(bool doRecreateDiveList)
void MainWindow::recreateDiveList()
{
ui.ListWidget->reload(DiveTripModel::CURRENT);
+ TagFilterModel::instance()->repopulate();
}
void MainWindow::current_dive_changed(int divenr)
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp
index 5266130b4..b22702795 100644
--- a/qt-ui/models.cpp
+++ b/qt-ui/models.cpp
@@ -2099,3 +2099,54 @@ int LanguageModel::rowCount(const QModelIndex &parent) const
{
return languages.count();
}
+
+
+TagFilterModel::TagFilterModel(QObject *parent): QStringListModel(parent), checkState(NULL)
+{
+}
+
+TagFilterModel *TagFilterModel::instance()
+{
+ static TagFilterModel *self = new TagFilterModel();
+ return self;
+}
+
+QVariant TagFilterModel::data(const QModelIndex &index, int role) const
+{
+ if(role == Qt::CheckStateRole){
+ return checkState[index.row()] ? Qt::Checked : Qt::Unchecked;
+ } else if (role == Qt::DisplayRole) {
+ return stringList()[index.row()];
+ }
+ return QVariant();
+}
+
+Qt::ItemFlags TagFilterModel::flags(const QModelIndex &index) const
+{
+ return QStringListModel::flags(index) | Qt::ItemIsUserCheckable;
+}
+
+void TagFilterModel::repopulate()
+{
+ if (g_tag_list == NULL)
+ return;
+ QStringList list;
+ struct tag_entry *current_tag_entry = g_tag_list->next;
+ while (current_tag_entry != NULL) {
+ list.append(QString(current_tag_entry->tag->name));
+ current_tag_entry = current_tag_entry->next;
+ }
+ setStringList(list);
+ delete[] checkState;
+ checkState = new bool[list.count()];
+ memset(checkState, false, list.count());
+}
+
+bool TagFilterModel::setData(const QModelIndex &index, const QVariant &value, int role)
+{
+ if(role == Qt::CheckStateRole){
+ checkState[index.row()] = value.toBool();
+ return true;
+ }
+ return false;
+}
diff --git a/qt-ui/models.h b/qt-ui/models.h
index c4a3a077d..c54a765ab 100644
--- a/qt-ui/models.h
+++ b/qt-ui/models.h
@@ -417,4 +417,18 @@ private:
QStringList languages;
};
+
+class TagFilterModel : public QStringListModel {
+ Q_OBJECT
+public:
+ static TagFilterModel *instance();
+ virtual QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const;
+ virtual bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole);
+ virtual Qt::ItemFlags flags(const QModelIndex &index) const;
+public slots:
+ void repopulate();
+private:
+ explicit TagFilterModel(QObject *parent = 0);
+ bool *checkState;
+};
#endif // MODELS_H
diff --git a/qt-ui/simplewidgets.cpp b/qt-ui/simplewidgets.cpp
index e9bfc3cba..2f762ba60 100644
--- a/qt-ui/simplewidgets.cpp
+++ b/qt-ui/simplewidgets.cpp
@@ -7,6 +7,7 @@
#include <QFileDialog>
#include <QShortcut>
#include <QCalendarWidget>
+#include <QSortFilterProxyModel>
#include "exif.h"
#include "dive.h"
#include "file.h"
@@ -459,4 +460,8 @@ void DiveComponentSelection::buttonClicked(QAbstractButton *button)
TagFilter::TagFilter(QWidget *parent): QWidget(parent)
{
ui.setupUi(this);
+ QSortFilterProxyModel *filter = new QSortFilterProxyModel();
+ filter->setSourceModel(TagFilterModel::instance());
+ connect(ui.filterTag, SIGNAL(textChanged(QString)), filter, SLOT(setFilterFixedString(QString)));
+ ui.tagView->setModel(filter);
}