#ifndef LOGSMODELNG_H #define LOGSMODELNG_H #include #include #include #include class LogEntry; class Engine; class LogsModelNg : public QAbstractListModel { Q_OBJECT Q_PROPERTY(Engine* engine READ engine WRITE setEngine NOTIFY engineChanged) Q_PROPERTY(bool busy READ busy NOTIFY busyChanged) Q_PROPERTY(bool live READ live WRITE setLive NOTIFY liveChanged) Q_PROPERTY(int count READ rowCount NOTIFY countChanged) Q_PROPERTY(QString deviceId READ deviceId WRITE setDeviceId NOTIFY deviceIdChanged) Q_PROPERTY(QStringList typeIds READ typeIds WRITE setTypeIds NOTIFY typeIdsChanged) Q_PROPERTY(QDateTime startTime READ startTime WRITE setStartTime NOTIFY startTimeChanged) Q_PROPERTY(QDateTime endTime READ endTime WRITE setEndTime NOTIFY endTimeChanged) Q_PROPERTY(QVariant minValue READ minValue NOTIFY minValueChanged) Q_PROPERTY(QVariant maxValue READ maxValue NOTIFY maxValueChanged) Q_PROPERTY(QtCharts::QXYSeries *graphSeries READ graphSeries WRITE setGraphSeries NOTIFY graphSeriesChanged) Q_PROPERTY(QDateTime viewStartTime READ viewStartTime WRITE setViewStartTime NOTIFY viewStartTimeChanged) public: enum Roles { RoleTimestamp, RoleValue, RoleDeviceId, RoleTypeId, RoleSource, RoleLoggingEventType }; explicit LogsModelNg(QObject *parent = nullptr); Engine *engine() const; void setEngine(Engine* jsonRpcClient); int rowCount(const QModelIndex &parent = QModelIndex()) const override; QVariant data(const QModelIndex &index, int role) const override; QHash roleNames() const override; bool busy() const; bool live() const; void setLive(bool live); QString deviceId() const; void setDeviceId(const QString &deviceId); QStringList typeIds() const; void setTypeIds(const QStringList &typeId); QDateTime startTime() const; void setStartTime(const QDateTime &startTime); QDateTime endTime() const; void setEndTime(const QDateTime &endTime); QtCharts::QXYSeries *graphSeries() const; void setGraphSeries(QtCharts::QXYSeries *lineSeries); QDateTime viewStartTime() const; void setViewStartTime(const QDateTime &viewStartTime); QVariant minValue() const; QVariant maxValue() const; Q_INVOKABLE LogEntry *get(int index) const; protected: virtual void fetchMore(const QModelIndex &parent = QModelIndex()) override; virtual bool canFetchMore(const QModelIndex &parent = QModelIndex()) const override; signals: void busyChanged(); void liveChanged(); void deviceIdChanged(); void typeIdsChanged(); void countChanged(); void startTimeChanged(); void endTimeChanged(); void engineChanged(); void graphSeriesChanged(); void viewStartTimeChanged(); void minValueChanged(); void maxValueChanged(); private slots: void newLogEntryReceived(const QVariantMap &data); void logsReply(const QVariantMap &data); private: QList m_list; Engine *m_engine = nullptr; bool m_busy = false; bool m_live = false; QString m_deviceId; QStringList m_typeIds; QDateTime m_startTime; QDateTime m_endTime; int m_blockSize = 100; bool m_canFetchMore = true; QDateTime m_viewStartTime; QVariant m_minValue; QVariant m_maxValue; QtCharts::QXYSeries *m_graphSeries = nullptr; QList > m_fetchedPeriods; }; #endif // LOGSMODELNG_H