20#ifndef ORES_QT_CLIENT_CONCURRENCY_POLICY_MODEL_HPP
21#define ORES_QT_CLIENT_CONCURRENCY_POLICY_MODEL_HPP
24#include <QFutureWatcher>
25#include <QAbstractTableModel>
26#include "ores.qt/AbstractClientModel.hpp"
27#include "ores.qt/ClientManager.hpp"
28#include "ores.qt/RecencyPulseManager.hpp"
29#include "ores.qt/RecencyTracker.hpp"
30#include "ores.logging/make_logger.hpp"
31#include "ores.reporting.api/domain/concurrency_policy.hpp"
45 inline static std::string_view logger_name =
46 "ores.qt.client_concurrency_policy_model";
48 [[nodiscard]]
static auto& lg() {
50 static auto instance = make_logger(logger_name);
70 QObject* parent =
nullptr);
74 int rowCount(
const QModelIndex& parent = QModelIndex())
const override;
75 int columnCount(
const QModelIndex& parent = QModelIndex())
const override;
76 QVariant data(
const QModelIndex& index,
int role = Qt::DisplayRole)
const override;
77 QVariant headerData(
int section, Qt::Orientation orientation,
78 int role = Qt::DisplayRole)
const override;
96 void load_page(std::uint32_t offset, std::uint32_t limit);
123 void onPolicysLoaded();
124 void onPulseStateChanged(
bool isOn);
125 void onPulsingComplete();
128 QVariant recency_foreground_color(
const std::string& code)
const;
132 std::vector<reporting::domain::concurrency_policy> policies;
133 std::uint32_t total_available_count;
134 QString error_message;
135 QString error_details;
138 void fetch_policies(std::uint32_t offset, std::uint32_t limit);
140 ClientManager* clientManager_;
141 std::vector<reporting::domain::concurrency_policy> policies_;
142 QFutureWatcher<FetchResult>* watcher_;
143 std::uint32_t page_size_{100};
144 std::uint32_t total_available_count_{0};
145 bool is_fetching_{
false};
148 RecencyTracker<reporting::domain::concurrency_policy, ConcurrencyPolicyKeyExtractor> recencyTracker_;
149 RecencyPulseManager* pulseManager_;
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
Qt-based graphical user interface for ORE Studio.
Definition AboutDialog.hpp:29
Base class for all client-side entity models.
Definition AbstractClientModel.hpp:36
Model for displaying concurrency policies fetched from the server.
Definition ClientConcurrencyPolicyModel.hpp:41
void set_page_size(std::uint32_t size)
Set the page size for pagination.
Definition ClientConcurrencyPolicyModel.cpp:263
void refresh()
Refresh concurrency policy data from server asynchronously.
Definition ClientConcurrencyPolicyModel.cpp:131
std::uint32_t total_available_count() const
Get the total number of records available on the server.
Definition ClientConcurrencyPolicyModel.hpp:111
void load_page(std::uint32_t offset, std::uint32_t limit)
Load a specific page of data.
Definition ClientConcurrencyPolicyModel.cpp:157
std::uint32_t page_size() const
Get the page size used for pagination.
Definition ClientConcurrencyPolicyModel.hpp:101
const reporting::domain::concurrency_policy * getPolicy(int row) const
Get concurrency policy at the specified row.
Definition ClientConcurrencyPolicyModel.cpp:275
Column
Enumeration of table columns for type-safe column access.
Definition ClientConcurrencyPolicyModel.hpp:58
Manages the lifecycle of the NATS client and login state.
Definition ClientManager.hpp:109
Report instance concurrency behaviour when a new trigger fires.
Definition concurrency_policy.hpp:37