aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--stats/chartlistmodel.cpp3
-rw-r--r--stats/chartlistmodel.h8
2 files changed, 9 insertions, 2 deletions
diff --git a/stats/chartlistmodel.cpp b/stats/chartlistmodel.cpp
index bce54ce25..7f7afe4d0 100644
--- a/stats/chartlistmodel.cpp
+++ b/stats/chartlistmodel.cpp
@@ -7,7 +7,7 @@
#include <QPainter>
ChartListModel::ChartListModel() :
- itemFont(defaultModelFont()),
+ itemFont(defaultModelFont()),
headerFont(itemFont.family(), itemFont.pointSize(), itemFont.weight(), true)
{
QFontMetrics fm(itemFont);
@@ -127,5 +127,6 @@ int ChartListModel::update(const StatsState::ChartList &charts)
items.push_back({ false, chart.subtypeName, fullName, chart.subtype, chart.id, chart.warning });
}
endResetModel();
+ emit countChanged();
return res;
}
diff --git a/stats/chartlistmodel.h b/stats/chartlistmodel.h
index 701dca50e..70484e0ad 100644
--- a/stats/chartlistmodel.h
+++ b/stats/chartlistmodel.h
@@ -24,6 +24,12 @@ public:
static const constexpr int IsHeaderRole = Qt::UserRole + 2;
static const constexpr int IconRole = Qt::UserRole + 3;
static const constexpr int IconSizeRole = Qt::UserRole + 4;
+
+ Q_PROPERTY(int count READ rowCount NOTIFY countChanged)
+
+signals:
+ void countChanged();
+
private:
struct Item {
bool isHeader;
@@ -45,7 +51,7 @@ private:
QFont headerFont;
std::vector<Item> items;
QHash<int, QByteArray> roleNames() const override;
- int rowCount(const QModelIndex &parent) const override;
+ int rowCount(const QModelIndex &parent = QModelIndex()) const override;
QVariant data(const QModelIndex &index, int role) const override;
Qt::ItemFlags flags(const QModelIndex &index) const override;
void initIcon(ChartSubType type, const char *name, int iconSize);